:root{
  --bg:#06110c;
  --panel:rgba(5,22,14,.78);
  --panel2:rgba(5,18,14,.64);
  --line:rgba(145,255,160,.18);
  --line-strong:rgba(115,255,136,.42);
  --text:#f4fff7;
  --muted:#bed6c3;
  --green:#67ff69;
  --green2:#18b83d;
  --wood:#ffb33e;
  --stone:#58d6ff;
  --food:#ffd64a;
  --coin:#c864ff;
  --danger:#ff6868;
  --shadow:0 24px 80px rgba(0,0,0,.55);
}
*{box-sizing:border-box}
html{color-scheme:dark;scroll-behavior:smooth}
body{margin:0;min-height:100vh;color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:#06110c url('bg.webp') center/cover fixed no-repeat;overflow-x:hidden}
body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 48% 18%,rgba(120,255,116,.16),transparent 24%),linear-gradient(180deg,rgba(0,0,0,.42),rgba(0,12,8,.82) 56%,rgba(0,0,0,.94));pointer-events:none;z-index:-2}
body:after{content:"";position:fixed;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.7),transparent 22%,transparent 74%,rgba(0,0,0,.7));pointer-events:none;z-index:-1}
a{color:inherit}.wrap{width:min(1180px,94vw);margin:0 auto;padding:18px 0 26px}.top{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:20px;animation:dropIn .65s ease both}.brand{display:flex;align-items:center;gap:12px;text-decoration:none}.brand img{width:50px;height:50px;border-radius:14px;box-shadow:0 0 22px rgba(89,255,88,.45)}.brand-text{display:flex;flex-direction:column;line-height:1}.brand strong{font-size:32px;font-weight:950;letter-spacing:-1px;text-shadow:0 2px 20px #000}.brand span{margin-top:7px;color:var(--green);font-weight:900;font-size:15px}.nav{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}.btn,a.btn,button{border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));color:var(--text);padding:13px 20px;border-radius:12px;text-decoration:none;font-weight:900;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 10px 26px rgba(0,0,0,.28);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.btn:hover,button:hover{transform:translateY(-2px);border-color:var(--line-strong);box-shadow:0 0 22px rgba(76,255,96,.18),0 12px 28px rgba(0,0,0,.35)}.btn.active{background:linear-gradient(180deg,rgba(55,255,77,.20),rgba(0,75,22,.28));border-color:rgba(97,255,104,.46);box-shadow:0 0 22px rgba(68,255,81,.35)}button:disabled{opacity:.48;cursor:not-allowed;filter:grayscale(.4);transform:none}.card,.hero-panel,.resource-card,.building-card,.info-strip{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line);box-shadow:var(--shadow)}.card{background:var(--panel);border-radius:24px;padding:24px;margin:18px 0}.notice{border-color:rgba(103,255,105,.35)}.notice.err{border-color:rgba(255,104,104,.45);color:#ffd4d4}.auth{max-width:480px;margin:42px auto}.auth input{width:100%;display:block;margin:11px 0;padding:15px 16px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.38);color:var(--text);font-size:16px}.auth button{width:100%;margin-top:10px;background:linear-gradient(135deg,#5cff5e,#139d37);color:#06110c}.hero-panel{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:stretch;min-height:315px;border-radius:22px;overflow:hidden;background:linear-gradient(90deg,rgba(6,30,17,.92),rgba(8,30,20,.72));animation:fadeUp .75s ease both}.hero-copy{padding:42px 44px;position:relative;z-index:2}.leaf{font-size:28px;color:var(--green);filter:drop-shadow(0 0 12px rgba(94,255,103,.5));margin-bottom:18px}.hero-panel h1{font-size:clamp(34px,5vw,50px);line-height:1.02;letter-spacing:-1.4px;margin:0 0 18px}.hero-panel p{max-width:520px;margin:0;color:#e6f3e8;font-size:17px;line-height:1.62}.hero-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:28px;max-width:500px}.meta-box{min-width:205px;display:flex;align-items:center;gap:12px;padding:15px 18px;border-radius:12px;background:rgba(0,0,0,.22);border:1px solid var(--line)}.meta-icon{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(255,255,255,.18);color:var(--green)}.meta-box small{display:block;color:var(--muted);font-weight:700}.meta-box b{display:block;color:var(--green);font-size:18px}.hero-art{min-height:315px;background:linear-gradient(90deg,rgba(5,24,15,.22),transparent),url('img/hero-house.webp') center/cover no-repeat}.resource-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:24px 0 28px}.resource-grid.mini{grid-template-columns:repeat(3,1fr)}.resource-card{position:relative;overflow:hidden;display:flex;align-items:center;gap:22px;min-height:140px;border-radius:16px;padding:24px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(0,0,0,.46));animation:fadeUp .75s ease both;transition:transform .22s ease,box-shadow .22s ease}.resource-card:before{content:"";position:absolute;inset:auto 14% -2px 14%;height:3px;border-radius:99px;filter:blur(.3px);opacity:.9}.resource-card:after{content:"";position:absolute;inset:-40% -20% auto auto;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.07);filter:blur(18px)}.resource-card:hover{transform:translateY(-4px) scale(1.01)}.res-icon{width:76px;height:76px;flex:0 0 76px;border-radius:50%;display:grid;place-items:center;font-size:34px;font-weight:950;border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.28);box-shadow:inset 0 0 22px rgba(255,255,255,.08),0 10px 28px rgba(0,0,0,.38)}.resource-card span{display:block;color:#fff;font-weight:900;font-size:18px}.resource-card strong{display:block;font-size:34px;margin-top:4px;letter-spacing:.4px}.resource-card em{display:block;margin-top:4px;color:var(--green);font-style:normal;font-weight:900}.resource-card.wood{border-color:rgba(255,179,62,.35);box-shadow:0 0 0 1px rgba(255,179,62,.05),0 0 28px rgba(255,179,62,.13),var(--shadow)}.resource-card.wood:before{background:var(--wood);box-shadow:0 0 20px var(--wood)}.resource-card.wood strong{color:var(--wood)}.resource-card.stone{border-color:rgba(88,214,255,.35);box-shadow:0 0 0 1px rgba(88,214,255,.05),0 0 28px rgba(88,214,255,.13),var(--shadow)}.resource-card.stone:before{background:var(--stone);box-shadow:0 0 20px var(--stone)}.resource-card.stone strong{color:var(--stone)}.resource-card.food{border-color:rgba(255,214,74,.35);box-shadow:0 0 0 1px rgba(255,214,74,.05),0 0 28px rgba(255,214,74,.14),var(--shadow)}.resource-card.food:before{background:var(--food);box-shadow:0 0 20px var(--food)}.resource-card.food strong{color:var(--food)}.resource-card.coins{border-color:rgba(200,100,255,.38);box-shadow:0 0 0 1px rgba(200,100,255,.05),0 0 28px rgba(200,100,255,.14),var(--shadow)}.resource-card.coins:before{background:var(--coin);box-shadow:0 0 20px var(--coin)}.resource-card.coins strong{color:var(--coin)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:18px;margin:28px 0 16px}.section-head h2{font-size:28px;margin:0;position:relative}.section-head h2:after{content:"";display:block;width:140px;height:4px;margin-top:8px;border-radius:99px;background:linear-gradient(90deg,var(--green),rgba(103,255,105,0));box-shadow:0 0 14px rgba(103,255,105,.55)}.section-head span{color:var(--muted)}.building-grid,.village{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.building-card,.building-tile{position:relative;border-radius:16px;overflow:hidden;background:linear-gradient(180deg,rgba(7,24,17,.72),rgba(5,18,14,.88));transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease;animation:fadeUp .75s ease both}.building-card:hover,.building-tile:hover{transform:translateY(-6px);box-shadow:0 0 32px rgba(103,255,105,.16),var(--shadow)}.building-card.wood{border-color:rgba(103,255,105,.42)}.building-card.stone{border-color:rgba(88,214,255,.38)}.building-card.food{border-color:rgba(255,181,28,.40)}.building-image{height:250px;background-size:cover;background-position:center;position:relative}.building-image:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.12) 45%,rgba(2,15,9,.92))}.building-title{position:absolute;z-index:2;left:22px;top:20px;display:flex;align-items:center;gap:12px;font-weight:950;font-size:26px;text-shadow:0 2px 14px #000}.build-icon{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;background:rgba(0,0,0,.35);box-shadow:0 0 16px rgba(255,255,255,.10)}.level-pill{position:absolute;z-index:2;left:22px;bottom:20px;padding:8px 16px;border-radius:9px;background:linear-gradient(135deg,rgba(103,255,105,.42),rgba(18,122,35,.62));font-weight:950;color:#eaffea}.building-body{padding:22px}.prod-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}.prod-row small{display:block;color:var(--muted);margin-bottom:6px}.prod-row b{color:var(--green);font-size:17px}.upgrade-row{display:grid;grid-template-columns:1fr 1fr 1.7fr;gap:10px;align-items:center}.price{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 8px;border-radius:10px;background:rgba(0,0,0,.22);border:1px solid var(--line);font-weight:950}.upgrade-btn{padding:14px 16px;border-radius:10px;border:0;background:linear-gradient(135deg,#69ff6b,#179b39);color:#06110c;font-size:17px;font-weight:950}.building-card.stone .upgrade-btn{background:linear-gradient(135deg,#58d6ff,#177c9b);color:#effcff}.building-card.food .upgrade-btn{background:linear-gradient(135deg,#ffd64a,#a96c00);color:#fff9d5}.village .building-tile{min-height:260px;text-decoration:none;padding:0;border:1px solid var(--line)}.building-tile .building-body{position:absolute;z-index:2;left:0;right:0;bottom:0}.info-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:28px 0;border-radius:16px;background:rgba(9,38,20,.72);padding:22px}.info-item{display:flex;align-items:center;gap:16px}.info-icon{width:58px;height:58px;display:grid;place-items:center;border-radius:50%;background:rgba(103,255,105,.12);border:1px solid rgba(103,255,105,.24);font-size:28px}.info-item b{display:block;font-size:18px}.info-item span{display:block;color:var(--muted);margin-top:5px}.toast{position:fixed;right:20px;bottom:20px;z-index:20;display:none;max-width:330px;padding:14px 18px;border-radius:14px;background:rgba(9,38,20,.95);border:1px solid var(--line-strong);box-shadow:0 14px 40px rgba(0,0,0,.45);font-weight:800}.toast.show{display:block;animation:toastIn .25s ease both}.footer{display:flex;justify-content:space-between;gap:12px;color:rgba(255,255,255,.72);padding:18px 0 0;font-size:16px}.pulse{animation:pulse .45s ease}.float-gain{position:fixed;z-index:30;color:var(--green);font-weight:950;text-shadow:0 0 14px rgba(103,255,105,.75);pointer-events:none;animation:floatGain 1s ease forwards}@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}@keyframes dropIn{from{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:none}}@keyframes pulse{50%{transform:scale(1.12);filter:brightness(1.25)}}@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes floatGain{0%{opacity:0;transform:translateY(0) scale(.85)}15%{opacity:1}100%{opacity:0;transform:translateY(-55px) scale(1.08)}}
@media(max-width:900px){.top{align-items:flex-start;flex-direction:column}.nav{width:100%;display:grid;grid-template-columns:repeat(3,1fr)}.nav .btn{text-align:center;padding:12px 10px}.hero-panel{grid-template-columns:1fr}.hero-copy{padding:28px}.hero-art{min-height:230px;order:-1}.resource-grid{grid-template-columns:repeat(2,1fr)}.building-grid,.village{grid-template-columns:1fr}.info-strip{grid-template-columns:1fr}.footer{flex-direction:column;text-align:center}.building-image{height:230px}}
@media(max-width:560px){.wrap{width:min(94vw,430px);padding-top:12px}.brand strong{font-size:26px}.brand img{width:44px;height:44px}.nav{grid-template-columns:repeat(2,1fr);gap:8px}.hero-copy{padding:24px 20px}.hero-panel h1{font-size:36px}.meta-box{min-width:100%;}.resource-grid,.resource-grid.mini{grid-template-columns:1fr}.resource-card{min-height:112px;padding:18px}.res-icon{width:60px;height:60px;flex-basis:60px}.resource-card strong{font-size:30px}.upgrade-row{grid-template-columns:1fr 1fr}.upgrade-btn{grid-column:1/-1}.section-head{align-items:flex-start;flex-direction:column}.building-image{height:210px}}


/* === Metsaelu polish patch: remove code letters + add living forest animations === */
.build-icon{font-size:0;position:relative;overflow:hidden}
.build-icon:before{content:"";width:18px;height:18px;border-radius:50%;display:block;background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.9),rgba(103,255,105,.55) 38%,rgba(3,42,18,.25) 70%);box-shadow:0 0 16px rgba(103,255,105,.55)}
.building-card.stone .build-icon:before{background:radial-gradient(circle at 35% 35%,#fff,#58d6ff 42%,rgba(8,46,61,.3) 75%);box-shadow:0 0 16px rgba(88,214,255,.5)}
.building-card.food .build-icon:before{background:radial-gradient(circle at 35% 35%,#fff,#ffd64a 42%,rgba(83,54,1,.3) 75%);box-shadow:0 0 16px rgba(255,214,74,.5)}
.price span{display:none!important}.price i{width:18px;height:18px;border-radius:50%;display:inline-block;box-shadow:inset 0 1px 2px rgba(255,255,255,.35),0 0 12px rgba(255,255,255,.12)}
.price-wood i{border-radius:7px;background:linear-gradient(135deg,#d58b3d,#6b3714)}
.price-stone i{background:linear-gradient(135deg,#e5e9ee,#767e86)}
.price-food i{border-radius:4px;background:linear-gradient(135deg,#ffe37a,#c77a05)}
.extra-cost{margin-top:10px;grid-template-columns:1fr!important}.extra-cost .price{max-width:120px}
body:before{content:"";position:fixed;inset:-3%;z-index:-2;background:inherit;filter:saturate(1.05);animation:forestDrift 28s ease-in-out infinite alternate;transform-origin:center;pointer-events:none} 
body:after{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(circle at 60% 10%,rgba(255,222,95,.16),transparent 24%),radial-gradient(circle at 50% 80%,rgba(16,255,122,.07),transparent 28%),linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.42));pointer-events:none;animation:mistMove 16s ease-in-out infinite alternate}
.hero-panel,.resource-card,.building-card,.info-strip{position:relative;isolation:isolate}.hero-panel:before,.building-card:before,.resource-card:after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.09) 35%,transparent 60%);transform:translateX(-130%);animation:shineSweep 7s ease-in-out infinite}.resource-card:after{animation-duration:5.8s}.building-card:before{animation-duration:8.5s;z-index:3;opacity:.55}.hero-art{animation:heroBreath 6s ease-in-out infinite}.resource-card{overflow:hidden}.resource-card .res-icon{animation:iconFloat 3.6s ease-in-out infinite}.building-card:nth-child(2){animation-delay:.08s}.building-card:nth-child(3){animation-delay:.16s}.upgrade-btn{transition:transform .18s ease,filter .18s ease,box-shadow .18s ease}.upgrade-btn:hover{transform:translateY(-2px);filter:brightness(1.12);box-shadow:0 0 18px rgba(103,255,105,.35)}
.forest-fx{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}.firefly{position:absolute;width:5px;height:5px;border-radius:50%;background:#cfff72;box-shadow:0 0 10px #9cff66,0 0 22px rgba(156,255,102,.7);opacity:.75;animation:fly var(--dur,9s) linear infinite}.leaf-bit{position:absolute;color:rgba(116,255,111,.48);font-size:18px;animation:leafFall var(--dur,12s) linear infinite;filter:drop-shadow(0 0 8px rgba(103,255,105,.35))}
@keyframes forestDrift{0%{transform:scale(1.02) translate3d(-8px,-4px,0)}100%{transform:scale(1.08) translate3d(10px,8px,0)}}
@keyframes mistMove{0%{opacity:.7;transform:translateX(-10px)}100%{opacity:1;transform:translateX(10px)}}
@keyframes shineSweep{0%,55%{transform:translateX(-130%);opacity:0}70%{opacity:.65}100%{transform:translateX(130%);opacity:0}}
@keyframes heroBreath{0%,100%{filter:brightness(1) saturate(1)}50%{filter:brightness(1.09) saturate(1.08)}}
@keyframes iconFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes fly{0%{transform:translate3d(var(--x0),110vh,0) scale(.7);opacity:0}12%{opacity:.85}50%{transform:translate3d(var(--x1),50vh,0) scale(1)}88%{opacity:.75}100%{transform:translate3d(var(--x2),-10vh,0) scale(.6);opacity:0}}
@keyframes leafFall{0%{transform:translate3d(var(--x0),-10vh,0) rotate(0deg);opacity:0}10%{opacity:.65}100%{transform:translate3d(var(--x1),110vh,0) rotate(420deg);opacity:0}}
@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}.forest-fx{display:none}}

.upgrade-row:not(.extra-cost) .price:nth-child(1) i{border-radius:7px;background:linear-gradient(135deg,#d58b3d,#6b3714)}
.upgrade-row:not(.extra-cost) .price:nth-child(2) i{background:linear-gradient(135deg,#e5e9ee,#767e86)}
.extra-cost .price i{border-radius:4px;background:linear-gradient(135deg,#ffe37a,#c77a05)}


/* === PIXEL PERFECT ICON FIX: real icons instead of P/K/T/€ and cleaner titles === */
.res-icon{font-size:0!important;overflow:visible;position:relative;background:radial-gradient(circle at 40% 35%, rgba(255,255,255,.10), rgba(0,0,0,.34) 58%, rgba(0,0,0,.58));}
.res-icon img{width:68px;height:68px;object-fit:contain;display:block;filter:drop-shadow(0 10px 14px rgba(0,0,0,.45));animation:iconFloat 3.6s ease-in-out infinite;}
.resource-card.coins .res-icon img{width:64px;height:64px}
.build-icon{font-size:0!important;position:relative;overflow:visible!important;background:rgba(0,0,0,.38);}
.build-icon:before{display:none!important;content:none!important;}
.build-icon img{width:32px;height:32px;object-fit:contain;display:block;filter:drop-shadow(0 0 10px rgba(255,255,255,.18));}
.building-title{gap:10px!important;line-height:1.05;}
.resource-card.wood .res-icon{box-shadow:inset 0 0 22px rgba(255,179,62,.18),0 0 28px rgba(255,179,62,.16),0 12px 32px rgba(0,0,0,.35)}
.resource-card.stone .res-icon{box-shadow:inset 0 0 22px rgba(88,214,255,.18),0 0 28px rgba(88,214,255,.16),0 12px 32px rgba(0,0,0,.35)}
.resource-card.food .res-icon{box-shadow:inset 0 0 22px rgba(255,214,74,.18),0 0 28px rgba(255,214,74,.16),0 12px 32px rgba(0,0,0,.35)}
.resource-card.coins .res-icon{box-shadow:inset 0 0 22px rgba(200,100,255,.18),0 0 28px rgba(200,100,255,.18),0 12px 32px rgba(0,0,0,.35)}
.resource-card strong{font-weight:1000;text-shadow:0 0 18px currentColor;}
.building-card:hover .build-icon img,.resource-card:hover .res-icon img{transform:scale(1.08) rotate(-3deg);transition:transform .22s ease;}
.hero-panel{border-color:rgba(103,255,105,.28)!important;box-shadow:0 0 0 1px rgba(103,255,105,.06),0 0 40px rgba(103,255,105,.11),var(--shadow)!important;}
.building-card.wood:hover{box-shadow:0 0 32px rgba(103,255,105,.25),var(--shadow)!important;}
.building-card.stone:hover{box-shadow:0 0 32px rgba(88,214,255,.24),var(--shadow)!important;}
.building-card.food:hover{box-shadow:0 0 32px rgba(255,181,28,.24),var(--shadow)!important;}

/* === FIX 1.4: icon scale + gain animations === */
.resource-card{align-items:center!important;min-height:128px!important;overflow:hidden!important;}
.resource-card > div:last-child{position:relative;z-index:3;min-width:0;}
.res-icon{width:70px!important;height:70px!important;flex:0 0 70px!important;overflow:hidden!important;position:relative!important;z-index:3!important;}
.res-icon img{width:50px!important;height:50px!important;max-width:50px!important;max-height:50px!important;object-fit:contain!important;position:static!important;transform:none!important;margin:0!important;}
.resource-card.coins .res-icon img{width:48px!important;height:48px!important;max-width:48px!important;max-height:48px!important;}
.resource-card strong{position:relative;z-index:3;}
.resource-card em{position:relative;z-index:3;}
.resource-card.gain-pop{animation:cardGain .62s ease both!important;}
@keyframes cardGain{0%{transform:scale(1)}35%{transform:scale(1.035);filter:brightness(1.22)}100%{transform:scale(1)}}
.float-gain{font-size:22px!important;background:rgba(4,25,11,.78);padding:7px 12px;border-radius:999px;border:1px solid rgba(103,255,105,.45);box-shadow:0 0 26px rgba(103,255,105,.34),0 12px 34px rgba(0,0,0,.45);}
.building-title{font-size:24px!important;white-space:nowrap;text-shadow:0 3px 16px rgba(0,0,0,.9)!important;}
.build-icon{width:34px!important;height:34px!important;flex:0 0 34px!important;overflow:hidden!important;}
.build-icon img{width:28px!important;height:28px!important;max-width:28px!important;max-height:28px!important;object-fit:contain!important;position:static!important;}
@media(max-width:900px){.res-icon{width:58px!important;height:58px!important;flex-basis:58px!important}.res-icon img{width:42px!important;height:42px!important;max-width:42px!important;max-height:42px!important}.resource-card{min-height:112px!important;padding:18px!important}.building-title{font-size:21px!important}}

/* === QUESTS + XP lightweight UI === */
.quest-panel{margin-top:28px;padding:20px;border-radius:22px;background:rgba(5,22,14,.62);border:1px solid rgba(103,255,105,.22);box-shadow:0 18px 60px rgba(0,0,0,.38);backdrop-filter:blur(12px)}
.section-head.compact{margin-bottom:14px}.section-head.compact a{color:var(--green);font-weight:900;text-decoration:none}
.quest-list{display:grid;gap:12px}.quest-list.big{margin-top:18px}
.quest-item{position:relative;overflow:hidden;display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;padding:15px 16px;border-radius:16px;background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(0,0,0,.36));border:1px solid rgba(255,255,255,.08)}
.quest-item b{display:block;font-size:16px}.quest-item span,.quest-item small{display:block;color:var(--muted);margin-top:4px}.quest-item strong{font-size:18px;color:var(--green)}
.quest-item>i{position:absolute;left:0;bottom:0;height:3px;width:var(--p);background:linear-gradient(90deg,var(--green),#ffd64a);box-shadow:0 0 18px rgba(103,255,105,.45)}
.quest-item.done{border-color:rgba(103,255,105,.42);box-shadow:0 0 22px rgba(103,255,105,.14)}
.quest-item.done:after{content:'TEHTUD';position:absolute;right:12px;top:10px;font-size:11px;font-weight:1000;color:#06110c;background:var(--green);border-radius:99px;padding:4px 8px}
.xpbar{height:12px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid rgba(255,255,255,.08);margin:10px 0 18px}.xpbar i{display:block;height:100%;width:var(--p);background:linear-gradient(90deg,var(--green),#ffd64a);box-shadow:0 0 18px rgba(103,255,105,.38)}
@media(max-width:700px){.quest-item{grid-template-columns:1fr}.quest-item.done:after{position:static;width:max-content;margin-top:8px}}
.building-title{display:flex!important;align-items:center!important}

/* Bank / police / danger pages */
.bank-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:18px 0}.bank-stat{padding:16px;border-radius:18px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.08);box-shadow:0 0 22px rgba(35,255,145,.12)}.bank-stat span{display:block;color:#aee7c7;font-size:13px}.bank-stat b{font-size:22px}.bank-form,.report-form{display:grid;gap:10px}.bank-form{grid-template-columns:1fr repeat(4,auto)}.bank-form input,.report-form input,.report-form textarea{width:100%;padding:13px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.35);color:#fff}.report-form textarea{min-height:120px;resize:vertical}.bank-form button,.report-form button{padding:12px 14px;border:0;border-radius:14px;background:linear-gradient(135deg,#24ffa1,#0bbf68);font-weight:800;color:#04120b;cursor:pointer}.report-list,.event-list{display:grid;gap:10px}.report-item,.event-item{padding:14px;border-radius:16px;background:rgba(0,0,0,.32);border:1px solid rgba(255,255,255,.08);display:grid;gap:4px}.report-item span,.event-item span{color:#c8e7d3}.report-item small,.event-item small{color:#88bd9c}.event-item.high{box-shadow:0 0 24px rgba(255,75,75,.18);border-color:rgba(255,75,75,.28)}.event-item.medium{box-shadow:0 0 24px rgba(255,199,60,.14);border-color:rgba(255,199,60,.22)}.clock-widget{display:flex;align-items:center;gap:14px;padding:16px;border-radius:20px;background:rgba(0,0,0,.36);border:1px solid rgba(255,255,255,.08);max-width:360px;margin:18px 0}.clock-widget span{display:block;color:#aee7c7}.clock-widget b{font-size:28px}.moon{width:54px;height:54px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#f6fff8,#8cd3ff 42%,#174364 70%);box-shadow:0 0 30px rgba(116,220,255,.35);animation:clockPulse 4s ease-in-out infinite}.moon.day{background:radial-gradient(circle at 35% 35%,#fff7ad,#ffb42c 55%,#a95400 80%);box-shadow:0 0 35px rgba(255,190,40,.42)}@keyframes clockPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@media(max-width:760px){.bank-grid{grid-template-columns:1fr 1fr}.bank-form{grid-template-columns:1fr}.bank-form button{width:100%}}
/* === Final security/profile/mobile/notices update === */
.mobile-menu-toggle{display:none;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.35);color:#eafff2;border-radius:14px;padding:10px 13px;font-size:20px;font-weight:900}.notice-list{display:grid;gap:12px;margin-top:18px}.notice-item{padding:15px 16px;border-radius:18px;background:rgba(0,0,0,.34);border:1px solid rgba(255,255,255,.09);box-shadow:0 0 26px rgba(35,255,145,.08)}.notice-item b,.notice-item span,.notice-item small{display:block}.notice-item span{color:#d5f4df;margin:5px 0}.notice-item small{color:#8abd9d}.notice-item.warning{border-color:rgba(255,199,60,.32);box-shadow:0 0 26px rgba(255,199,60,.13)}.notice-item.danger{border-color:rgba(255,75,75,.34);box-shadow:0 0 28px rgba(255,75,75,.16)}.notice-item.system{border-color:rgba(103,255,105,.32)}.profile-hero{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;padding:22px;border-radius:26px;background:rgba(4,18,11,.72);border:1px solid rgba(103,255,105,.23);box-shadow:0 18px 70px rgba(0,0,0,.38),0 0 42px rgba(103,255,105,.1);backdrop-filter:blur(14px)}.profile-avatar{width:94px;height:94px;border-radius:28px;display:grid;place-items:center;font-size:42px;font-weight:1000;color:#06130b;background:linear-gradient(135deg,#24ff9b,#ffcf3a);box-shadow:0 0 36px rgba(103,255,105,.28)}.profile-kicker{color:#8fffc0;font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:12px}.profile-main h1{font-size:34px;margin:4px 0}.profile-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:16px}.profile-box{padding:17px;border-radius:20px;background:rgba(0,0,0,.36);border:1px solid rgba(255,255,255,.08);box-shadow:0 0 26px rgba(103,255,105,.08)}.profile-box span{display:block;color:#aee7c7}.profile-box b{font-size:22px}.xpbar.big{height:15px;max-width:520px}.error-page,.blocked-card{margin:40px auto;max-width:760px;text-align:center;padding:34px;border-radius:30px;background:rgba(4,18,11,.78);border:1px solid rgba(255,255,255,.1);box-shadow:0 22px 80px rgba(0,0,0,.45),0 0 50px rgba(103,255,105,.1);backdrop-filter:blur(16px)}.error-code{font-size:86px;font-weight:1000;line-height:.9;color:#67ff69;text-shadow:0 0 30px rgba(103,255,105,.35)}.blocked-icon{font-size:64px;margin-bottom:10px}.muted{color:#9fc4ac}@media(max-width:850px){.top{position:relative;align-items:center}.mobile-menu-toggle{display:block}.nav{display:none!important;position:absolute;left:0;right:0;top:calc(100% + 10px);z-index:50;padding:12px;border-radius:22px;background:rgba(4,18,11,.94);border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 70px rgba(0,0,0,.45);backdrop-filter:blur(16px);grid-template-columns:1fr 1fr;gap:9px}.nav.open{display:grid!important}.nav .btn{justify-content:center;width:100%}.profile-hero{grid-template-columns:1fr;text-align:center}.profile-avatar{margin:auto}.profile-grid{grid-template-columns:1fr 1fr}}@media(max-width:520px){.nav{grid-template-columns:1fr}.profile-grid{grid-template-columns:1fr}.error-code{font-size:64px}}


/* === REAL public wooden profile + mobile/errors === */
@media(max-width:850px){
  .wrap{padding:12px!important}.top{position:sticky;top:8px;z-index:100;border-radius:18px;padding:10px;background:rgba(4,18,11,.82);backdrop-filter:blur(16px)}
  .brand-text strong{font-size:20px}.mobile-menu-toggle{display:block!important}.nav{display:none!important}.nav.open{display:grid!important;grid-template-columns:1fr!important;gap:8px}.nav.open a{min-height:44px;font-size:16px}
}
.wood-profile{max-width:1120px;margin:10px auto 28px;color:#2c1b0e;font-family:Georgia,serif;position:relative}.wood-sign{background:linear-gradient(#d8a861,#8b5528);border:5px solid #4a2914;border-radius:26px;padding:18px;text-align:center;color:#2c3b16;box-shadow:0 18px 50px rgba(0,0,0,.45),inset 0 0 0 3px rgba(255,230,160,.35);text-transform:uppercase}.wood-sign span{display:block;font-size:42px;font-weight:1000;letter-spacing:2px}.wood-sign b{display:inline-block;margin-top:8px;padding:6px 30px;border-radius:12px;background:#6b3d1d;color:#f7e1b0;font-size:25px;box-shadow:inset 0 0 16px rgba(0,0,0,.25)}.wood-grid{display:grid;grid-template-columns:330px 1fr;gap:18px;margin-top:16px}.wood-left,.parchment,.online-panel{background:#f3dcae;border:4px solid #5b341b;border-radius:22px;box-shadow:0 18px 50px rgba(0,0,0,.35),inset 0 0 24px rgba(95,55,22,.18)}.wood-left{padding:16px;text-align:center}.wood-avatar{height:410px;border-radius:20px;background:radial-gradient(circle at 50% 25%,#d4ffc8,#345332 48%,#102314 100%);border:4px solid #6a421f;display:grid;place-items:center;position:relative;overflow:hidden}.avatar-letter{font-family:system-ui;font-size:155px;font-weight:1000;color:#244619;text-shadow:0 6px 0 rgba(255,255,255,.35),0 0 40px #e6ffd7}.avatar-forest{position:absolute;bottom:18px;font-size:40px;filter:drop-shadow(0 4px 7px rgba(0,0,0,.4))}.wood-name{margin:12px auto 8px;background:#7a481f;color:#ffe9bd;border-radius:14px;padding:10px;font-size:25px;font-weight:900;box-shadow:inset 0 0 14px rgba(0,0,0,.25)}.online-badge{display:inline-block;padding:7px 18px;border-radius:999px;background:#3a2b1a;color:#e5d1a6;font-weight:900}.online-badge.on{color:#1dff6c}.wood-info{margin-top:14px;text-align:left;font-size:19px;padding:12px;background:rgba(255,248,220,.45);border-radius:16px}.wood-info p{margin:10px 0}.wood-main{display:grid;grid-template-columns:1fr 1fr;gap:14px}.parchment{padding:18px}.parchment h2{font-size:34px;margin:0;color:#31401c}.parchment h3{margin:0 0 12px;text-align:center;background:#4d662d;color:#ffe5b5;border-radius:10px;padding:8px;text-transform:uppercase;letter-spacing:1px}.top-card{grid-column:1/3;background:rgba(20,35,18,.92);color:#f6ead0;border-color:#5b341b}.ability-list{list-style:none;padding:0;margin:0}.ability-list li{font-size:19px;padding:12px 0;border-bottom:2px dashed rgba(95,55,22,.28)}.inv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.inv-slot{background:#5b341b;border:3px solid #321a0c;border-radius:10px;min-height:78px;display:grid;place-items:center;color:#ffe5b5;position:relative}.inv-slot img{width:34px;height:34px;object-fit:contain}.inv-slot b{font-size:16px}.inv-slot span{font-size:11px;color:#efd39e}.stat-line{display:flex;justify-content:space-between;border-bottom:2px dashed rgba(95,55,22,.22);padding:9px 0;font-size:18px}.wood-xp,.wood-row i{display:block;height:12px;background:#33210f;border-radius:999px;overflow:hidden;margin:10px 0}.wood-xp i,.wood-row i:before{content:'';display:block;width:var(--p);height:100%;background:linear-gradient(90deg,#5d802d,#c9e36a);border-radius:inherit}.wood-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;margin:10px 0}.wood-row i{grid-column:1/3}.motto{text-align:center;font-size:24px;color:#31401c;font-weight:900}.online-panel{margin-top:16px;padding:16px}.online-panel h3{text-align:center;margin:0 0 14px;color:#31401c;text-transform:uppercase}.online-list{display:flex;gap:12px;overflow:auto;padding-bottom:8px}.online-chip{min-width:105px;text-align:center;color:#ffe7b4;text-decoration:none;background:#4a2914;border:2px solid #8b5528;border-radius:18px;padding:10px;position:relative}.online-chip span{width:58px;height:58px;display:grid;place-items:center;margin:auto;border-radius:50%;background:linear-gradient(135deg,#86ff9d,#d9a74b);color:#163210;font-family:system-ui;font-weight:1000;font-size:25px}.online-chip b,.online-chip em{display:block}.online-chip em{font-size:12px;color:#d7bd87}.online-chip i{position:absolute;right:12px;top:55px;width:12px;height:12px;border-radius:50%;background:#22e85e}.online-total{text-align:right;color:#f5e4bd;font-size:18px}.game-error:before{content:'🌲';display:block;font-size:42px;margin-bottom:8px}.error-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.btn.ghost{background:rgba(255,255,255,.08)!important;color:#eafff2!important}
@media(max-width:850px){.wood-sign span{font-size:30px}.wood-grid,.wood-main{grid-template-columns:1fr}.top-card{grid-column:auto}.wood-avatar{height:320px}.inv-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.wood-sign span{font-size:24px}.wood-sign b{font-size:18px}.wood-avatar{height:260px}.avatar-letter{font-size:110px}.wood-main{gap:10px}.parchment{padding:13px}.inv-grid{grid-template-columns:repeat(2,1fr)}}
/* === Extra polish: playful errors + reliable mobile menu === */
body.menu-open{overflow:hidden}.error-mascot{font-size:72px;line-height:1;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35));animation:errorBounce 2.8s ease-in-out infinite}.error-mini{display:flex;justify-content:center;gap:13px;margin:18px 0 22px}.error-mini span{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);animation:floatMini 3.2s ease-in-out infinite}.error-mini span:nth-child(2){animation-delay:.25s}.error-mini span:nth-child(3){animation-delay:.5s}.error-mini span:nth-child(4){animation-delay:.75s}@keyframes errorBounce{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-8px) rotate(2deg)}}@keyframes floatMini{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@media(max-width:850px){.top{left:auto;right:auto}.mobile-menu-toggle{min-width:48px;min-height:44px;touch-action:manipulation}.nav.open{max-height:calc(100vh - 100px);overflow:auto}.nav.open .btn{padding:13px 12px;border-radius:14px}.mode-table{min-width:720px}.mode-card{overflow-x:auto}}
@media(max-width:520px){.error-page,.blocked-card{margin:18px auto;padding:24px 15px;border-radius:24px}.error-mascot{font-size:54px}.error-actions .btn{width:100%;justify-content:center}.error-mini span{width:40px;height:40px}}

/* Metsaelu mängulised error-lehed */
.error-body{min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at 50% 12%,rgba(103,255,105,.16),transparent 28%),linear-gradient(180deg,#06130b 0%,#020805 65%,#010402 100%)}
.error-wrap{display:grid;place-items:center;min-height:100vh;padding-top:24px;padding-bottom:24px}.game-error{position:relative;overflow:hidden;isolation:isolate;border-color:rgba(103,255,105,.28);background:linear-gradient(180deg,rgba(6,26,14,.9),rgba(1,8,5,.88));min-height:520px;display:grid;place-items:center;padding:46px 26px}.game-error:before{content:"";position:absolute;inset:-25%;z-index:-3;background:radial-gradient(circle at 20% 20%,rgba(103,255,105,.22),transparent 22%),radial-gradient(circle at 80% 30%,rgba(255,207,58,.11),transparent 18%),radial-gradient(circle at 50% 90%,rgba(11,191,104,.22),transparent 24%);animation:mistDrift 9s ease-in-out infinite alternate}.game-error:after{content:"";position:absolute;left:0;right:0;bottom:0;height:45%;z-index:-1;background:linear-gradient(0deg,rgba(0,0,0,.72),transparent),repeating-linear-gradient(90deg,transparent 0 34px,rgba(103,255,105,.05) 35px 37px);clip-path:polygon(0 40%,8% 18%,14% 42%,23% 10%,32% 45%,42% 16%,51% 44%,62% 12%,72% 46%,82% 18%,91% 42%,100% 20%,100% 100%,0 100%)}.moon-orb{position:absolute;right:11%;top:11%;width:86px;height:86px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fff9c7,#9effc0 55%,#1f7d4c 78%);box-shadow:0 0 55px rgba(103,255,105,.38);animation:orbFloat 4.8s ease-in-out infinite}.error-woods{position:absolute;inset:auto 0 0;display:flex;justify-content:space-around;align-items:end;opacity:.75;z-index:-1}.error-woods i{display:block;width:0;height:0;border-left:38px solid transparent;border-right:38px solid transparent;border-bottom:150px solid rgba(9,54,26,.92);filter:drop-shadow(0 0 16px rgba(103,255,105,.14));animation:treeSway 4s ease-in-out infinite alternate}.error-woods i:nth-child(2n){border-left-width:48px;border-right-width:48px;border-bottom-height:180px;animation-duration:5.5s}.error-mascot{font-size:76px;filter:drop-shadow(0 0 22px rgba(103,255,105,.38));animation:mascotBounce 2.8s ease-in-out infinite}.game-error h1{font-size:clamp(30px,6vw,52px);margin:6px 0 8px;text-shadow:0 0 24px rgba(103,255,105,.22)}.game-error p{max-width:560px;color:#d8f5df;font-size:clamp(16px,2.5vw,19px);line-height:1.55}.error-story{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:18px 0}.error-story span{padding:9px 12px;border-radius:999px;background:rgba(0,0,0,.32);border:1px solid rgba(255,255,255,.1);color:#c9f5d4;font-weight:800;font-size:13px}.scene-forbidden{box-shadow:0 22px 80px rgba(0,0,0,.52),0 0 70px rgba(103,255,105,.14),inset 0 0 80px rgba(103,255,105,.08)}.scene-forbidden .error-code{text-shadow:0 0 34px rgba(103,255,105,.58)}.scene-lost:before{filter:blur(1px);opacity:.92}.scene-glitch{border-color:rgba(255,75,75,.28);box-shadow:0 22px 80px rgba(0,0,0,.52),0 0 70px rgba(255,75,75,.14)}.scene-glitch .error-code{color:#ff6b6b;text-shadow:2px 0 #24ffa1,-2px 0 #8cd3ff,0 0 34px rgba(255,75,75,.42);animation:glitchText 1.8s infinite}.scene-guard .moon-orb{background:radial-gradient(circle at 35% 35%,#fff7ad,#ffcf3a 55%,#92620b 78%)}@keyframes mistDrift{from{transform:translate3d(-2%,0,0) scale(1)}to{transform:translate3d(2%,-2%,0) scale(1.04)}}@keyframes orbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}@keyframes mascotBounce{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(2deg)}}@keyframes treeSway{from{transform:rotate(-1deg)}to{transform:rotate(1.5deg)}}@keyframes glitchText{0%,92%,100%{transform:translate(0)}94%{transform:translate(2px,-1px)}96%{transform:translate(-2px,1px)}}@media(max-width:620px){.game-error{min-height:calc(100vh - 36px);padding:34px 16px}.moon-orb{width:58px;height:58px;right:8%;top:7%}.error-mascot{font-size:58px}.error-story{display:grid}.error-actions{width:100%;display:grid}.error-actions .btn{width:100%;justify-content:center}.error-woods i{border-left-width:28px;border-right-width:28px;border-bottom-width:112px}}

/* === Metsaelu RPG error screens v2 === */
.error-body{min-height:100vh;margin:0;overflow-x:hidden;color:#efffec;background:#020603;position:relative}.error-body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 50% 12%,rgba(104,255,125,.20),transparent 26%),radial-gradient(circle at 18% 80%,rgba(255,203,87,.10),transparent 24%),linear-gradient(180deg,#07160c 0%,#020703 72%,#000 100%);z-index:-5}.error-body:after{content:"";position:fixed;inset:0;opacity:.28;background:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:44px 44px;mask-image:linear-gradient(to bottom,transparent,black 20%,black 80%,transparent);z-index:-4}.error-stage{min-height:100vh;display:grid;place-items:center;padding:24px}.rpg-error-card{width:min(920px,100%);min-height:min(680px,calc(100vh - 48px));position:relative;overflow:hidden;isolation:isolate;display:grid;place-items:center;text-align:center;padding:48px 26px;border-radius:38px;background:linear-gradient(180deg,rgba(7,28,14,.84),rgba(1,8,4,.92));border:1px solid rgba(129,255,151,.28);box-shadow:0 30px 100px rgba(0,0,0,.68),inset 0 0 0 1px rgba(255,255,255,.06),0 0 80px rgba(65,255,122,.13)}.rpg-error-card:before{content:"";position:absolute;inset:-25%;z-index:-4;background:radial-gradient(circle at 24% 25%,rgba(102,255,126,.22),transparent 18%),radial-gradient(circle at 78% 22%,rgba(255,210,100,.13),transparent 16%),radial-gradient(circle at 50% 92%,rgba(21,136,70,.35),transparent 24%);filter:blur(5px);animation:rpgMist 11s ease-in-out infinite alternate}.rpg-error-card:after{content:"";position:absolute;left:-10%;right:-10%;bottom:-8%;height:42%;z-index:-2;background:linear-gradient(0deg,rgba(0,0,0,.82),transparent 68%)}.rpg-moon{position:absolute;right:10%;top:9%;width:88px;height:88px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fffbd2,#9bffc2 55%,#1a7543 80%);box-shadow:0 0 65px rgba(104,255,130,.46);animation:rpgFloat 5s ease-in-out infinite}.rpg-trees{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-around;align-items:flex-end;gap:12px;opacity:.9;z-index:-1}.rpg-trees i{width:0;height:0;border-left:42px solid transparent;border-right:42px solid transparent;border-bottom:170px solid rgba(6,53,25,.96);filter:drop-shadow(0 0 18px rgba(104,255,130,.14));animation:rpgSway 4.5s ease-in-out infinite alternate}.rpg-trees i:nth-child(2n){border-left-width:56px;border-right-width:56px;border-bottom-width:215px;opacity:.86;animation-duration:6s}.rpg-trees i:nth-child(3n){border-left-width:32px;border-right-width:32px;border-bottom-width:135px;opacity:.7}.rpg-badge{display:inline-flex;align-items:center;justify-content:center;padding:9px 16px;border-radius:999px;background:rgba(0,0,0,.38);border:1px solid rgba(157,255,174,.22);color:#aaffbe;text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:1000;box-shadow:0 0 24px rgba(104,255,130,.10)}.rpg-icon{font-size:82px;line-height:1;filter:drop-shadow(0 0 24px rgba(104,255,130,.40));animation:rpgBounce 3s ease-in-out infinite}.rpg-code{font-size:clamp(72px,16vw,145px);font-weight:1000;line-height:.82;color:#78ff86;text-shadow:0 0 18px rgba(120,255,134,.55),0 0 62px rgba(120,255,134,.28);letter-spacing:-.06em}.rpg-error-card h1{font-size:clamp(30px,6vw,56px);line-height:1;margin:0;text-shadow:0 0 28px rgba(104,255,130,.22)}.rpg-error-card p{max-width:620px;margin:0 auto;color:#ddf8e0;font-size:clamp(16px,2.5vw,20px);line-height:1.55}.rpg-hints{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.rpg-hints span{padding:10px 13px;border-radius:999px;background:rgba(0,0,0,.36);border:1px solid rgba(255,255,255,.10);color:#d7f8dc;font-weight:900;font-size:13px}.scene-forbidden .rpg-error-card,.scene-blocked .rpg-error-card{border-color:rgba(255,203,87,.34);box-shadow:0 30px 100px rgba(0,0,0,.70),0 0 90px rgba(255,190,70,.14)}.scene-forbidden .rpg-code,.scene-blocked .rpg-code{color:#ffd66d;text-shadow:0 0 24px rgba(255,214,109,.48)}.scene-blocked .rpg-moon,.scene-forbidden .rpg-moon{background:radial-gradient(circle at 35% 35%,#fff4b8,#ffd46a 58%,#7d480a 82%)}.scene-glitch .rpg-error-card{border-color:rgba(255,76,76,.34);box-shadow:0 30px 100px rgba(0,0,0,.70),0 0 90px rgba(255,76,76,.15)}.scene-glitch .rpg-code{color:#ff6969;text-shadow:3px 0 #55ffaf,-3px 0 #79c7ff,0 0 34px rgba(255,76,76,.50);animation:rpgGlitch 1.8s steps(2,end) infinite}.scene-lost .rpg-error-card:before{filter:blur(9px);opacity:.9}.blocked-card-pro p b{color:#ffd66d}.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn.ghost{background:rgba(255,255,255,.08)!important;color:#eafff2!important;border-color:rgba(255,255,255,.18)!important}@keyframes rpgMist{from{transform:translate3d(-2%,0,0) scale(1)}to{transform:translate3d(2%,-2%,0) scale(1.05)}}@keyframes rpgFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}@keyframes rpgBounce{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-11px) rotate(2deg)}}@keyframes rpgSway{from{transform:rotate(-1.1deg)}to{transform:rotate(1.6deg)}}@keyframes rpgGlitch{0%,90%,100%{transform:translate(0)}93%{transform:translate(3px,-1px)}96%{transform:translate(-3px,1px)}}@media(max-width:620px){.error-stage{padding:12px}.rpg-error-card{border-radius:26px;min-height:calc(100vh - 24px);padding:34px 16px}.rpg-moon{width:58px;height:58px;right:7%;top:6%}.rpg-icon{font-size:60px}.rpg-hints{display:grid}.error-actions{display:grid;width:100%}.error-actions .btn{width:100%;justify-content:center}.rpg-trees i{border-left-width:28px;border-right-width:28px;border-bottom-width:118px}.rpg-trees i:nth-child(2n){border-left-width:36px;border-right-width:36px;border-bottom-width:145px}}

/* === Juurde ehitatud süsteemid: päevapreemia, edetabel, metsapood === */
.daily-card{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,rgba(39,91,48,.88),rgba(14,35,20,.92));border:1px solid rgba(140,255,164,.22);box-shadow:0 18px 60px rgba(0,0,0,.28),inset 0 0 40px rgba(109,255,128,.08)}
.daily-card h1{margin:0 0 8px}.daily-card p{margin:0;color:#d9f6df}.daily-streak{display:inline-flex;align-items:center;gap:10px;margin-top:14px;padding:9px 13px;border-radius:999px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.12)}
.daily-streak b{font-size:26px;color:#b6ff99}.daily-streak span{font-weight:900;color:#efffee}.daily-card button[disabled]{opacity:.55;cursor:not-allowed;filter:grayscale(.4)}
.leaderboard-page,.shop-page{overflow:hidden}.leader-list{display:grid;gap:10px;margin-top:18px}.leader-row{display:grid;grid-template-columns:64px 1fr auto;gap:14px;align-items:center;text-decoration:none;color:inherit;padding:14px;border-radius:18px;background:rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.10);transition:.18s transform,.18s border-color,.18s background}.leader-row:hover{transform:translateY(-2px);background:rgba(76,255,112,.08);border-color:rgba(132,255,151,.28)}.leader-row>b{font-size:20px;color:#ffe082}.leader-row span{font-weight:1000}.leader-row small{display:block;color:#bfe8c7;font-weight:800;margin-top:3px}.leader-row strong{text-align:right;color:#b6ff99}.leader-row em{display:block;font-style:normal;color:#d4f5d9;font-size:12px;margin-top:3px}
.shop-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:18px}.shop-item{display:flex;flex-direction:column;gap:10px;padding:18px;border-radius:22px;background:linear-gradient(180deg,rgba(0,0,0,.26),rgba(0,0,0,.14));border:1px solid rgba(255,255,255,.10);min-height:260px}.shop-icon{width:58px;height:58px;display:grid;place-items:center;border-radius:18px;background:rgba(124,255,145,.12);font-size:30px;box-shadow:inset 0 0 24px rgba(111,255,139,.10)}.shop-item h3{margin:0}.shop-item p{color:#d9f6df;flex:1}.shop-item b{font-size:22px;color:#ffe082}.shop-item button{width:100%;justify-content:center}
@media(max-width:900px){.shop-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.leader-row{grid-template-columns:48px 1fr}.leader-row strong{text-align:left;grid-column:2}.daily-card{align-items:flex-start;flex-direction:column}.daily-card form,.daily-card button{width:100%}}
@media(max-width:560px){.shop-grid{grid-template-columns:1fr}.leader-row{grid-template-columns:40px 1fr;padding:12px}.leader-row>b{font-size:17px}}

/* Daily missions + XP UI - lightweight, no external assets */
.xp-widget{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;margin:16px 0;padding:18px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,rgba(103,255,105,.12),rgba(0,0,0,.28));box-shadow:var(--shadow)}
.xp-widget span{display:block;color:var(--muted);font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.08em}.xp-widget b{display:block;color:var(--green);font-size:34px;line-height:1}.xp-widget small{color:#dfffe3;font-weight:900}.xp-track,.mission-item>i{position:relative;display:block;height:12px;border-radius:999px;background:rgba(0,0,0,.35);border:1px solid var(--line);overflow:hidden}.xp-track i,.mission-item>i:before{content:"";position:absolute;inset:0 auto 0 0;width:var(--p);border-radius:999px;background:linear-gradient(90deg,#4cff62,#ffd64a);box-shadow:0 0 18px rgba(103,255,105,.45)}
.mission-panel{background:linear-gradient(180deg,rgba(8,38,20,.72),rgba(4,16,12,.88));border:1px solid var(--line);border-radius:24px;padding:22px;margin:18px 0;box-shadow:var(--shadow)}
.mission-list{display:grid;gap:12px}.mission-item{position:relative;display:grid;grid-template-columns:1fr auto auto;gap:14px;align-items:center;padding:16px;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.24);overflow:hidden}.mission-item b{display:block;font-size:17px}.mission-item span,.mission-item small{display:block;color:var(--muted);margin-top:4px}.mission-item strong{font-size:18px;color:var(--green);white-space:nowrap}.mission-item form{margin:0}.mission-item button{padding:10px 15px;background:linear-gradient(135deg,#69ff6b,#179b39);color:#06110c;border:0}.mission-item em{font-style:normal;color:var(--green);font-weight:950}.mission-item>i{grid-column:1/-1;height:10px}.mission-item.done{border-color:rgba(103,255,105,.42);box-shadow:0 0 20px rgba(103,255,105,.10)}.mission-item.claimed{opacity:.72;filter:saturate(.75)}
@media(max-width:720px){.xp-widget{grid-template-columns:1fr}.mission-item{grid-template-columns:1fr;align-items:start}.mission-item strong{justify-self:start}.mission-item button{width:100%}}

/* Compact daily missions widget */
.mission-panel-mini{padding:12px 14px;margin:10px 0;border-radius:16px;box-shadow:0 10px 28px rgba(0,0,0,.18)}
.mission-panel-mini .section-head{margin-bottom:8px;gap:10px}
.mission-panel-mini .section-head h2{font-size:16px;margin:0}
.mission-panel-mini .section-head a{font-size:12px;padding:5px 8px;border-radius:999px;background:rgba(103,255,105,.08);border:1px solid rgba(103,255,105,.18)}
.mission-panel-mini .mission-list{gap:6px}
.mission-item.mini{grid-template-columns:minmax(0,1fr) auto auto;gap:8px;padding:8px 10px;border-radius:12px;background:rgba(0,0,0,.18)}
.mission-item.mini b{font-size:13px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mission-item.mini strong{font-size:12px}
.mission-item.mini button{padding:5px 8px;font-size:12px;border-radius:10px}
.mission-item.mini em{font-size:12px}
.mission-item.mini>i{height:5px;margin-top:-2px}
@media(max-width:720px){.mission-panel-mini{padding:10px;margin:8px 0}.mission-item.mini{grid-template-columns:1fr auto;gap:7px}.mission-item.mini form,.mission-item.mini em{grid-column:1/-1}.mission-item.mini button{width:100%;padding:7px 8px}.mission-item.mini>i{grid-column:1/-1}}

/* === PvE metsajaht + parem mobiilimenüü === */
.hunt-page{overflow:hidden;background:linear-gradient(135deg,rgba(9,42,22,.86),rgba(3,15,10,.94));border-color:rgba(118,255,145,.25)}
.hunt-hero{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;position:relative}.hunt-hero:before{content:"";position:absolute;right:4%;top:-30px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(103,255,105,.16),transparent 68%);pointer-events:none}.hunt-hero h1{font-size:clamp(30px,5vw,54px);margin:6px 0 12px}.hunt-hero p{max-width:680px;color:#daf5df;line-height:1.55}.hunt-stats{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:14px}.hunt-stats b{padding:9px 13px;border-radius:999px;background:rgba(103,255,105,.12);border:1px solid rgba(103,255,105,.24);color:#aaffb7}.hunt-stats span{color:#b9d8c0;font-weight:800}.hunt-btn{font-size:18px;min-width:190px;min-height:58px;display:flex;align-items:center;justify-content:center}.hunt-log-list{display:grid;gap:10px;margin-top:14px}.hunt-log{display:grid;grid-template-columns:80px 1fr auto;gap:12px;align-items:center;padding:13px 14px;border-radius:16px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.09)}.hunt-log span{font-weight:1000;color:#ffe082}.hunt-log.win{border-color:rgba(103,255,105,.28);box-shadow:0 0 24px rgba(103,255,105,.07)}.hunt-log.lose{border-color:rgba(255,104,104,.24)}.hunt-log small{color:#cfe8d4;font-weight:800;text-align:right}
@media(max-width:850px){
  .top{position:sticky;top:8px;z-index:60;border:1px solid rgba(255,255,255,.08);background:rgba(4,18,11,.76);backdrop-filter:blur(16px);border-radius:22px;padding:10px 12px;box-shadow:0 16px 50px rgba(0,0,0,.28)}
  .mobile-menu-toggle{margin-left:auto;border-radius:16px;background:linear-gradient(135deg,rgba(103,255,105,.20),rgba(0,0,0,.35));border-color:rgba(103,255,105,.26)}
  .mobile-menu-toggle[aria-expanded="true"]{background:linear-gradient(135deg,#67ff69,#179b39);color:#06110c}
  .nav.open{position:fixed!important;left:12px!important;right:12px!important;top:76px!important;max-height:calc(100vh - 92px)!important;overflow:auto!important;display:grid!important;grid-template-columns:1fr 1fr!important;gap:10px!important;padding:14px!important;border-radius:24px!important;background:rgba(3,14,9,.96)!important;box-shadow:0 24px 90px rgba(0,0,0,.62),0 0 40px rgba(103,255,105,.10)!important;z-index:999!important}
  .nav.open .btn{min-height:48px;display:flex;align-items:center;justify-content:center;font-size:15px;padding:12px 10px}.menu-open:before{content:"";position:fixed;inset:0;background:rgba(0,0,0,.46);z-index:50;backdrop-filter:blur(2px)}
  .hunt-hero{grid-template-columns:1fr}.hunt-hero form,.hunt-btn{width:100%}.hunt-log{grid-template-columns:1fr}.hunt-log small{text-align:left}
}
@media(max-width:520px){.nav.open{grid-template-columns:1fr!important;left:10px!important;right:10px!important;top:72px!important}.hunt-stats{display:grid}.hunt-log{padding:12px}}

/* Patch: mobile menu has its own visible scrollbar and fits small screens */
@media(max-width:850px){
  .nav.open{
    overflow-y:auto!important;
    overflow-x:hidden!important;
    overscroll-behavior:contain!important;
    -webkit-overflow-scrolling:touch!important;
    scrollbar-width:thin;
    scrollbar-color:rgba(103,255,105,.85) rgba(255,255,255,.08);
  }
  .nav.open::-webkit-scrollbar{width:8px}
  .nav.open::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:999px}
  .nav.open::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#67ff69,#179b39);border-radius:999px}
  body.menu-open{overflow:hidden}
}
.quest-empty{padding:12px 14px;border:1px dashed rgba(103,255,105,.28);border-radius:14px;background:rgba(0,0,0,.18);color:#dfffe3;font-weight:900}

/* === Building living view + mobile menu logout fix === */
.building-card{position:relative}
.building-card .building-image{cursor:pointer}
.building-open-link{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;padding:10px 12px;border-radius:14px;background:rgba(103,255,105,.12);border:1px solid rgba(103,255,105,.22);color:#dffff0;text-decoration:none;font-weight:900;box-shadow:0 0 20px rgba(103,255,105,.08)}
.building-open-link:hover{background:rgba(103,255,105,.22);transform:translateY(-1px)}
.building-life-hero{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:stretch;margin-top:18px}
.building-life-art{min-height:360px;border-radius:30px;background-size:cover;background-position:center;position:relative;overflow:hidden;border:1px solid rgba(103,255,105,.20);box-shadow:0 25px 90px rgba(0,0,0,.45)}
.building-life-art:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,13,8,.88))}
.building-life-art:after{content:"";position:absolute;inset:auto -20% 0 -20%;height:45%;background:radial-gradient(circle at 50% 100%,rgba(103,255,105,.22),transparent 62%);filter:blur(18px)}
.building-life-title{position:absolute;left:24px;right:24px;bottom:22px;z-index:1}.building-life-title h1{font-size:42px;margin:0 0 8px}.building-life-title p{color:#d7f6df;margin:0;max-width:640px}
.life-panel{padding:22px;border-radius:30px;background:rgba(3,18,11,.74);border:1px solid rgba(255,255,255,.10);box-shadow:0 20px 70px rgba(0,0,0,.34);backdrop-filter:blur(12px)}
.life-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0}.life-stat{padding:14px;border-radius:18px;background:rgba(0,0,0,.30);border:1px solid rgba(255,255,255,.08)}.life-stat span{display:block;color:#aee7c7;font-size:13px}.life-stat b{font-size:22px}
.root-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}.root-card{padding:18px;border-radius:24px;background:rgba(0,0,0,.32);border:1px solid rgba(255,255,255,.08)}.root-card.good{border-color:rgba(103,255,105,.26);box-shadow:0 0 28px rgba(103,255,105,.08)}.root-card.dark{border-color:rgba(255,70,110,.28);box-shadow:0 0 28px rgba(255,70,110,.08)}.root-card h3{margin:0 0 8px}.root-card ul{margin:10px 0 0;padding-left:18px;color:#d8f3df}.root-card li{margin:5px 0}
.life-action-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.life-action-row .btn{min-height:46px}.creature-list{display:grid;gap:10px;margin-top:12px}.creature{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:17px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}.creature em{font-style:normal;color:#9fffc1;font-weight:900}.creature.bad em{color:#ff91a8}
@media(max-width:850px){.building-life-hero,.root-grid{grid-template-columns:1fr}.building-life-art{min-height:300px}.building-life-title h1{font-size:32px}.life-panel{padding:16px}.life-stat-grid{grid-template-columns:1fr 1fr}.mobile-menu-toggle{position:relative;z-index:200}.nav.open{position:fixed!important;left:12px!important;right:12px!important;top:74px!important;bottom:12px!important;max-height:none!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch;padding:12px 12px 90px!important;align-content:start}.nav.open .logout-btn{position:sticky;bottom:0;margin-top:8px;background:linear-gradient(135deg,#ff6464,#9b1d1d)!important;color:white!important;box-shadow:0 -14px 30px rgba(0,0,0,.35),0 0 22px rgba(255,80,80,.25)}}
@media(max-width:520px){.building-life-art{min-height:250px}.life-stat-grid{grid-template-columns:1fr}.root-card{padding:14px}.building-open-link{width:100%}}


/* === Living buildings + survival HUD === */
.survival-hud{display:grid;grid-template-columns:1.1fr 1.4fr 1.4fr auto auto;gap:10px;align-items:center;margin:14px 0;padding:12px;border-radius:22px;background:rgba(3,16,10,.78);border:1px solid rgba(103,255,105,.20);box-shadow:0 16px 55px rgba(0,0,0,.35);backdrop-filter:blur(14px)}
.survival-hud>div,.survival-hud form{min-width:0}.survival-hud span{display:block;color:#aacdb3;font-size:12px;font-weight:800}.survival-hud b{font-size:17px}.survival-hud button,.life-explore button{width:100%;background:linear-gradient(135deg,#69ff6b,#179b39);color:#05140a;border:0}
.surv-meter{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center}.surv-meter i{display:block;height:12px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;position:relative}.surv-meter i:before{content:"";position:absolute;inset:0 auto 0 0;width:var(--p);border-radius:99px;background:linear-gradient(90deg,#67ff69,#ffd64a);box-shadow:0 0 18px rgba(103,255,105,.35)}.surv-meter.thirst i:before{background:linear-gradient(90deg,#58d6ff,#67ff69)}
.life-explore{display:grid;gap:8px;margin:14px 0;padding:12px;border-radius:18px;background:rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.08)}.life-explore small{color:#b8d8c0}
.life-log-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}.life-log,.missing-person{display:grid;gap:4px;margin:8px 0;padding:12px;border-radius:16px;background:rgba(0,0,0,.26);border:1px solid rgba(255,255,255,.08)}.life-log b,.missing-person b{color:#eaffee}.life-log span,.missing-person span{color:#cfead5}.life-log small,.missing-person small{color:#91b99e}.life-log.bad{border-color:rgba(255,90,90,.25)}.life-log.good{border-color:rgba(103,255,105,.25)}.life-log.dark{border-color:rgba(200,100,255,.30)}
.creature{position:relative;overflow:hidden}.creature:after{content:"";position:absolute;inset:auto 10px 7px auto;width:7px;height:7px;border-radius:50%;background:#67ff69;box-shadow:0 0 16px #67ff69;animation:pulse 1.8s ease-in-out infinite}.creature.bad:after{background:#ff6868;box-shadow:0 0 16px #ff6868}

/* Mobile menu hard fix: visible close/logout area and smooth internal scroll */
@media(max-width:850px){
  body.menu-open{overflow:hidden}
  .nav.open{display:flex!important;flex-direction:column!important;position:fixed!important;left:10px!important;right:10px!important;top:74px!important;bottom:10px!important;z-index:9999!important;max-height:none!important;overflow-y:auto!important;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:12px 12px 96px!important;background:rgba(4,18,11,.97)!important}
  .nav.open .btn{flex:0 0 auto;min-height:46px;width:100%;display:flex;align-items:center;justify-content:center}
  .nav.open:after{content:"";display:block;height:76px;flex:0 0 76px}
  .nav.open .logout-btn{position:sticky!important;bottom:8px!important;z-index:2;margin-top:auto!important;background:linear-gradient(135deg,#ff6868,#8b1515)!important;color:#fff!important;border-color:rgba(255,120,120,.45)!important}
}
@media(max-width:760px){
  .survival-hud{grid-template-columns:1fr;gap:9px}.surv-meter{grid-template-columns:56px 1fr 44px}.life-log-grid{grid-template-columns:1fr}.building-life-title h1{font-size:28px}.building-life-title p{font-size:14px}
}

/* === FINAL mobile menu rebuild: game-like drawer, always visible logout === */
@media (max-width: 850px){
  body.menu-open{overflow:hidden!important;touch-action:none}
  body.menu-open::before{
    content:"";position:fixed;inset:0;background:rgba(0,0,0,.62)!important;
    z-index:9000!important;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)
  }
  .top{position:relative;z-index:10001}
  .mobile-menu-toggle{
    display:inline-flex!important;align-items:center;justify-content:center;gap:8px;
    min-width:54px;min-height:48px;padding:12px 15px!important;border-radius:18px!important;
    font-size:22px!important;line-height:1;background:linear-gradient(135deg,rgba(103,255,105,.26),rgba(0,0,0,.45))!important;
    border:1px solid rgba(103,255,105,.38)!important;box-shadow:0 10px 30px rgba(0,0,0,.35),0 0 18px rgba(103,255,105,.13)!important
  }
  .mobile-menu-toggle[aria-expanded="true"]{background:linear-gradient(135deg,#67ff69,#159538)!important;color:#06110c!important}
  .nav{display:none!important}
  .nav.open{
    display:grid!important;grid-template-columns:1fr 1fr!important;align-content:start!important;gap:10px!important;
    position:fixed!important;left:10px!important;right:10px!important;top:72px!important;
    bottom:calc(86px + env(safe-area-inset-bottom))!important;
    width:auto!important;max-height:none!important;overflow-y:auto!important;overflow-x:hidden!important;
    overscroll-behavior:contain!important;-webkit-overflow-scrolling:touch!important;
    padding:14px 14px 18px!important;border-radius:24px!important;
    background:linear-gradient(180deg,rgba(6,26,15,.98),rgba(2,10,7,.98))!important;
    border:1px solid rgba(103,255,105,.28)!important;
    box-shadow:0 24px 90px rgba(0,0,0,.72),0 0 42px rgba(103,255,105,.13)!important;
    z-index:10000!important
  }
  .nav.open::before{
    content:"🌲 Menüü";grid-column:1/-1;position:sticky;top:-14px;z-index:1;
    margin:-14px -14px 4px;padding:15px 16px 12px;border-radius:24px 24px 14px 14px;
    background:rgba(5,20,12,.96);border-bottom:1px solid rgba(103,255,105,.18);
    color:#dfffe4;font-weight:950;font-size:18px;text-align:left
  }
  .nav.open .btn{
    width:100%!important;min-height:50px!important;display:flex!important;align-items:center!important;justify-content:center!important;
    padding:12px 10px!important;border-radius:16px!important;font-size:15px!important;text-align:center!important;
    background:rgba(255,255,255,.075)!important;border:1px solid rgba(255,255,255,.13)!important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 8px 20px rgba(0,0,0,.22)!important
  }
  .nav.open .btn.active{background:linear-gradient(135deg,rgba(103,255,105,.32),rgba(16,92,31,.65))!important;border-color:rgba(103,255,105,.48)!important}
  .nav.open .logout-btn{
    position:fixed!important;left:18px!important;right:18px!important;bottom:calc(14px + env(safe-area-inset-bottom))!important;
    width:auto!important;min-height:56px!important;z-index:10002!important;margin:0!important;
    border-radius:20px!important;background:linear-gradient(135deg,#ff6969,#8d1515)!important;color:#fff!important;
    border:1px solid rgba(255,130,130,.58)!important;box-shadow:0 -14px 36px rgba(0,0,0,.52),0 0 24px rgba(255,90,90,.28)!important;
    font-size:17px!important;font-weight:950!important
  }
  .nav.open::-webkit-scrollbar{width:7px!important}
  .nav.open::-webkit-scrollbar-track{background:rgba(255,255,255,.07)!important;border-radius:999px!important}
  .nav.open::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#67ff69,#148c32)!important;border-radius:999px!important}
}
@media (max-width: 420px){
  .nav.open{grid-template-columns:1fr!important;top:68px!important;bottom:calc(84px + env(safe-area-inset-bottom))!important;padding:12px!important}
  .nav.open .btn{min-height:48px!important;font-size:14px!important}
  .nav.open .logout-btn{left:12px!important;right:12px!important;bottom:calc(10px + env(safe-area-inset-bottom))!important;min-height:54px!important}
}

/* === TRUE FINAL mobile menu: clean full-screen drawer, no overlap === */
@media (max-width: 850px){
  body.menu-open{overflow:hidden!important;touch-action:none!important}
  body.menu-open::before{content:"";position:fixed;inset:0;background:rgba(0,0,0,.72)!important;z-index:29000!important;backdrop-filter:blur(6px)!important;-webkit-backdrop-filter:blur(6px)!important}
  body.menu-open .top{z-index:1!important}
  body.menu-open .brand{pointer-events:none!important;filter:blur(2px)!important;opacity:.22!important}

  .mobile-menu-toggle{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-width:48px!important;min-height:46px!important;line-height:1!important}
  .mobile-menu-toggle[aria-expanded="true"]{
    position:fixed!important;top:calc(18px + env(safe-area-inset-top))!important;right:18px!important;z-index:30020!important;
    width:46px!important;height:46px!important;min-width:46px!important;min-height:46px!important;padding:0!important;border-radius:50%!important;
    font-size:30px!important;font-weight:1000!important;background:linear-gradient(135deg,#65ff66,#149536)!important;color:#031108!important;
    border:1px solid rgba(180,255,190,.65)!important;box-shadow:0 12px 32px rgba(0,0,0,.5),0 0 24px rgba(103,255,105,.25)!important
  }

  .nav.open{
    display:grid!important;grid-template-columns:1fr 1fr!important;gap:10px!important;align-content:start!important;
    position:fixed!important;left:14px!important;right:14px!important;top:calc(14px + env(safe-area-inset-top))!important;bottom:calc(14px + env(safe-area-inset-bottom))!important;
    z-index:30000!important;width:auto!important;max-height:none!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;
    padding:76px 14px 14px!important;border-radius:28px!important;background:linear-gradient(180deg,rgba(5,23,13,.985),rgba(1,8,5,.985))!important;
    border:1px solid rgba(103,255,105,.30)!important;box-shadow:0 28px 95px rgba(0,0,0,.78),0 0 45px rgba(103,255,105,.16)!important
  }
  .nav.open::before{
    content:"🌲 Metsaelu menüü"!important;position:fixed!important;left:30px!important;right:82px!important;top:calc(26px + env(safe-area-inset-top))!important;z-index:30005!important;
    margin:0!important;padding:0!important;background:transparent!important;border:0!important;border-radius:0!important;color:#67ff69!important;text-shadow:0 0 18px rgba(103,255,105,.35)!important;
    font-size:20px!important;font-weight:1000!important;line-height:46px!important;text-align:left!important;grid-column:auto!important
  }
  .nav.open .btn{width:100%!important;min-height:50px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:12px 10px!important;border-radius:17px!important;font-size:15px!important;background:rgba(255,255,255,.075)!important;border:1px solid rgba(255,255,255,.12)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 8px 20px rgba(0,0,0,.24)!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
  .nav.open .btn.active{background:linear-gradient(135deg,rgba(103,255,105,.34),rgba(12,82,28,.76))!important;border-color:rgba(103,255,105,.52)!important;color:#effff1!important}
  .nav.open .logout-btn{position:sticky!important;bottom:0!important;grid-column:1/-1!important;margin-top:8px!important;width:100%!important;min-height:54px!important;background:linear-gradient(135deg,#ff6868,#8a1515)!important;color:#fff!important;border-color:rgba(255,130,130,.60)!important;box-shadow:0 -12px 28px rgba(0,0,0,.45),0 0 22px rgba(255,80,80,.25)!important;font-size:16px!important}
}
@media (max-width: 430px){
  .nav.open{grid-template-columns:1fr!important;left:12px!important;right:12px!important;padding-top:72px!important;border-radius:24px!important}
  .nav.open::before{left:28px!important;right:76px!important;font-size:18px!important}
  .nav.open .btn{min-height:48px!important;font-size:14px!important}
}

/* === PRO MOBILE MENU: fixed app drawer that actually opens === */
@media (max-width: 900px){
  body.menu-open{overflow:hidden!important;touch-action:none!important;position:fixed!important;width:100%!important;}
  .top{position:relative!important;z-index:1000!important;}
  .mobile-menu-toggle{
    position:fixed!important;
    top:calc(14px + env(safe-area-inset-top))!important;
    right:14px!important;
    width:58px!important;height:58px!important;
    border-radius:21px!important;
    z-index:100002!important;
    display:flex!important;align-items:center!important;justify-content:center!important;
    font-size:28px!important;font-weight:950!important;line-height:1!important;
    background:linear-gradient(135deg,#63ff68,#118831)!important;
    color:#041209!important;
    border:1px solid rgba(145,255,150,.55)!important;
    box-shadow:0 12px 36px rgba(0,0,0,.55),0 0 26px rgba(94,255,103,.45)!important;
    -webkit-tap-highlight-color:transparent!important;
  }
  body.menu-open::before{
    content:""!important;position:fixed!important;inset:0!important;
    z-index:99990!important;background:rgba(0,0,0,.72)!important;
    backdrop-filter:blur(7px)!important;-webkit-backdrop-filter:blur(7px)!important;
  }
  .nav{display:none!important;}
  .nav.open{
    display:flex!important;flex-direction:column!important;gap:10px!important;
    position:fixed!important;
    top:calc(82px + env(safe-area-inset-top))!important;
    left:14px!important;right:14px!important;
    bottom:calc(14px + env(safe-area-inset-bottom))!important;
    z-index:100000!important;
    overflow-y:auto!important;overscroll-behavior:contain!important;-webkit-overflow-scrolling:touch!important;
    padding:18px 14px 14px!important;
    border-radius:26px!important;
    background:linear-gradient(180deg,rgba(4,22,12,.985),rgba(1,10,7,.985))!important;
    border:1px solid rgba(103,255,105,.24)!important;
    box-shadow:0 30px 90px rgba(0,0,0,.75), inset 0 1px 0 rgba(255,255,255,.08),0 0 55px rgba(62,255,75,.12)!important;
  }
  .nav.open::before{
    content:"🌲 Menüü";display:block!important;position:sticky!important;top:0!important;z-index:3!important;
    padding:12px 12px 14px!important;margin:-4px 0 4px!important;
    color:#67ff69!important;font-size:23px!important;font-weight:950!important;letter-spacing:-.4px!important;
    background:linear-gradient(180deg,rgba(4,22,12,1),rgba(4,22,12,.82))!important;
    border-bottom:1px solid rgba(103,255,105,.16)!important;
  }
  .nav.open .btn{
    flex:0 0 auto!important;width:100%!important;min-height:54px!important;
    display:flex!important;align-items:center!important;justify-content:flex-start!important;
    text-align:left!important;padding:13px 16px!important;border-radius:18px!important;
    font-size:16px!important;font-weight:950!important;white-space:nowrap!important;
    background:rgba(255,255,255,.07)!important;border:1px solid rgba(255,255,255,.13)!important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 10px 22px rgba(0,0,0,.20)!important;
  }
  .nav.open .btn.active{background:linear-gradient(135deg,rgba(103,255,105,.33),rgba(13,96,34,.72))!important;border-color:rgba(103,255,105,.5)!important;}
  .nav.open .shadow-link{background:linear-gradient(135deg,rgba(154,87,255,.36),rgba(30,8,57,.80))!important;border-color:rgba(190,130,255,.5)!important;}
  .nav.open .logout-btn{
    position:sticky!important;bottom:0!important;margin-top:auto!important;z-index:4!important;justify-content:center!important;
    background:linear-gradient(135deg,#ff6868,#8b1515)!important;color:#fff!important;border-color:rgba(255,130,130,.55)!important;
    box-shadow:0 -18px 34px rgba(0,0,0,.55),0 0 24px rgba(255,70,70,.25)!important;
  }
  .nav.open::-webkit-scrollbar{width:7px!important}.nav.open::-webkit-scrollbar-track{background:rgba(255,255,255,.06)!important;border-radius:999px!important}.nav.open::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#67ff69,#148c32)!important;border-radius:999px!important}
}
.surv-meter.life i{background:linear-gradient(90deg,#ff5757,#ffd35a,#67ff69)!important}.shadow-call{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}.shadow-realm-page{background:radial-gradient(circle at top,#1c0933,rgba(2,5,8,.92)),linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.75))!important;border-color:rgba(189,119,255,.35)!important;box-shadow:0 0 50px rgba(150,78,255,.18),var(--shadow)!important}.shadow-realm-page h1{font-size:clamp(36px,7vw,64px);margin-top:0;text-shadow:0 0 26px rgba(188,113,255,.65)}.shadow-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0}.shadow-stats div{padding:18px;border-radius:18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13)}.shadow-stats span{display:block;color:var(--muted);font-weight:800}.shadow-stats b{display:block;font-size:28px;color:#d9b8ff}.shadow-fight{background:linear-gradient(135deg,#b75cff,#4b138e)!important;color:#fff!important;border-color:rgba(220,170,255,.55)!important}.muted{color:var(--muted)}
@media(max-width:520px){.shadow-stats{grid-template-columns:1fr}.shadow-call{display:block}.shadow-call .btn{margin-top:12px;width:100%;justify-content:center}}

/* === ABSOLUTE PRO MOBILE MENU PATCH: own drawer + real visible items === */
@media (max-width: 900px){
  #mainNav.open{display:none!important;visibility:hidden!important;pointer-events:none!important;}
  body.pro-drawer-open{overflow:hidden!important;position:fixed!important;width:100%!important;}
  .pro-menu-backdrop{display:none;position:fixed!important;inset:0!important;z-index:2147483000!important;background:rgba(0,0,0,.72)!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;}
  body.pro-drawer-open .pro-menu-backdrop{display:block!important;}
  .mobile-menu-toggle{position:relative!important;z-index:2147483200!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;width:58px!important;height:58px!important;min-width:58px!important;min-height:58px!important;border-radius:21px!important;background:linear-gradient(135deg,#63ff68,#139c39)!important;color:#041209!important;border:1px solid rgba(145,255,150,.62)!important;box-shadow:0 10px 30px rgba(0,0,0,.55),0 0 26px rgba(94,255,103,.46)!important;font-size:28px!important;font-weight:1000!important;line-height:1!important;}
  body.pro-drawer-open .mobile-menu-toggle{position:fixed!important;top:calc(16px + env(safe-area-inset-top))!important;right:16px!important;border-radius:50%!important;}
  .pro-mobile-menu{display:flex!important;flex-direction:column!important;position:fixed!important;z-index:2147483100!important;left:14px!important;right:14px!important;top:calc(82px + env(safe-area-inset-top))!important;bottom:calc(14px + env(safe-area-inset-bottom))!important;transform:translateY(16px) scale(.985)!important;opacity:0!important;pointer-events:none!important;border-radius:28px!important;background:linear-gradient(180deg,rgba(5,24,14,.99),rgba(1,9,6,.99))!important;border:1px solid rgba(103,255,105,.30)!important;box-shadow:0 28px 95px rgba(0,0,0,.80), inset 0 1px 0 rgba(255,255,255,.08),0 0 50px rgba(70,255,82,.15)!important;overflow:hidden!important;transition:opacity .18s ease,transform .18s ease!important;}
  body.pro-drawer-open .pro-mobile-menu{opacity:1!important;transform:none!important;pointer-events:auto!important;}
  .pro-menu-head{flex:0 0 auto!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:14px!important;padding:18px 76px 14px 18px!important;border-bottom:1px solid rgba(103,255,105,.16)!important;background:linear-gradient(180deg,rgba(7,33,17,.98),rgba(4,20,12,.88))!important;}
  .pro-menu-head b{display:block!important;color:#67ff69!important;font-size:23px!important;font-weight:1000!important;line-height:1.05!important;text-shadow:0 0 18px rgba(103,255,105,.35)!important;}
  .pro-menu-head span{display:block!important;color:#bcecca!important;font-size:13px!important;font-weight:850!important;margin-top:5px!important;}
  .pro-menu-close{position:absolute!important;right:16px!important;top:16px!important;width:46px!important;height:46px!important;border-radius:50%!important;padding:0!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:30px!important;line-height:1!important;background:linear-gradient(135deg,#63ff68,#129038)!important;color:#041209!important;border:1px solid rgba(145,255,150,.65)!important;box-shadow:0 8px 22px rgba(0,0,0,.45),0 0 22px rgba(94,255,103,.30)!important;}
  .pro-menu-links{flex:1 1 auto!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;display:grid!important;grid-template-columns:1fr!important;gap:10px!important;padding:14px 14px 96px!important;}
  .pro-menu-links a{min-height:54px!important;display:flex!important;align-items:center!important;justify-content:flex-start!important;gap:10px!important;text-align:left!important;padding:13px 16px!important;border-radius:18px!important;font-size:16px!important;font-weight:950!important;color:#f1fff4!important;text-decoration:none!important;background:rgba(255,255,255,.075)!important;border:1px solid rgba(255,255,255,.13)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 10px 22px rgba(0,0,0,.20)!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;}
  .pro-menu-links a.active{background:linear-gradient(135deg,rgba(103,255,105,.34),rgba(14,95,34,.75))!important;border-color:rgba(103,255,105,.52)!important;}
  .pro-menu-links a[href*="logout"],.pro-menu-links a.logout-btn{position:sticky!important;bottom:0!important;z-index:3!important;margin-top:10px!important;justify-content:center!important;background:linear-gradient(135deg,#ff6868,#8b1515)!important;color:#fff!important;border-color:rgba(255,130,130,.58)!important;box-shadow:0 -18px 34px rgba(0,0,0,.55),0 0 24px rgba(255,70,70,.25)!important;}
  .pro-menu-links::-webkit-scrollbar{width:7px!important}.pro-menu-links::-webkit-scrollbar-track{background:rgba(255,255,255,.06)!important;border-radius:999px!important}.pro-menu-links::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#67ff69,#148c32)!important;border-radius:999px!important}
}
@media (min-width: 901px){.pro-menu-backdrop,.pro-mobile-menu{display:none!important}}

/* Event popup system */
.event-popup-stack{position:fixed;right:18px;bottom:18px;z-index:2147483200;display:flex;flex-direction:column;gap:10px;width:min(360px,calc(100vw - 28px));pointer-events:none}.event-popup{pointer-events:auto;display:grid;grid-template-columns:42px 1fr auto;gap:12px;align-items:start;padding:13px 14px;border-radius:18px;background:linear-gradient(180deg,rgba(7,29,17,.98),rgba(1,10,6,.98));border:1px solid rgba(103,255,105,.32);box-shadow:0 18px 55px rgba(0,0,0,.55),0 0 26px rgba(76,255,96,.18),inset 0 1px 0 rgba(255,255,255,.10);transform:translateX(18px) scale(.98);opacity:0;animation:eventIn .26s ease forwards;color:#f4fff4}.event-popup.out{animation:eventOut .22s ease forwards}.event-popup-icon{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(50,255,71,.92),rgba(12,120,41,.92));box-shadow:0 0 24px rgba(76,255,96,.28);font-size:20px}.event-popup b{display:block;font-size:14px;line-height:1.1;margin:1px 0 4px;font-weight:950}.event-popup span{display:block;color:#d5ead8;font-size:12.5px;line-height:1.35;font-weight:750}.event-popup small{color:#9fc9a8;font-weight:900;font-size:11px}.event-popup-close{appearance:none;border:0!important;background:rgba(255,255,255,.08)!important;box-shadow:none!important;border-radius:12px!important;padding:5px 8px!important;min-width:0!important;color:#dfffe4!important;line-height:1!important}.event-popup.danger,.event-popup.warning{border-color:rgba(255,194,80,.45);box-shadow:0 18px 55px rgba(0,0,0,.55),0 0 28px rgba(255,170,34,.13)}.event-popup.danger .event-popup-icon,.event-popup.warning .event-popup-icon{background:linear-gradient(135deg,rgba(255,202,70,.95),rgba(162,76,10,.95))}.event-popup.hunt .event-popup-icon{background:linear-gradient(135deg,rgba(115,221,255,.95),rgba(36,111,158,.95))}.event-popup.reward .event-popup-icon,.event-popup.shop .event-popup-icon{background:linear-gradient(135deg,rgba(255,216,75,.95),rgba(183,105,8,.95))}.event-popup.mission .event-popup-icon{background:linear-gradient(135deg,rgba(174,118,255,.95),rgba(83,37,154,.95))}@keyframes eventIn{to{transform:none;opacity:1}}@keyframes eventOut{to{transform:translateX(20px) scale(.96);opacity:0}}@media(max-width:700px){.event-popup-stack{left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));width:auto}.event-popup{grid-template-columns:38px 1fr auto;border-radius:16px;padding:11px 12px}.event-popup-icon{width:38px;height:38px;border-radius:13px}.event-popup b{font-size:13.5px}.event-popup span{font-size:12px}}

/* === PRO MENU BOTTOM LOGOUT FIX: logout is separate and never covers items === */
@media (max-width: 900px){
  .pro-mobile-menu{padding-bottom:0!important;}
  .pro-menu-links{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;padding:14px 14px 18px!important;height:auto!important;}
  .pro-menu-links a.logout-btn,.pro-menu-links a[href*="logout"]{display:none!important;}
  .pro-menu-logout{flex:0 0 auto!important;position:relative!important;z-index:5!important;width:100%!important;padding:12px 14px calc(12px + env(safe-area-inset-bottom))!important;background:linear-gradient(180deg,rgba(2,10,7,.72),rgba(3,18,10,.99))!important;border-top:1px solid rgba(103,255,105,.20)!important;box-shadow:0 -16px 34px rgba(0,0,0,.55)!important;}
  .pro-menu-logout a,.pro-menu-logout .pro-logout-btn{width:100%!important;min-height:54px!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:10px!important;border-radius:18px!important;text-decoration:none!important;color:#fff!important;font-weight:1000!important;font-size:17px!important;background:linear-gradient(135deg,#ff3b3b,#ff6b6b)!important;border:1px solid rgba(255,150,150,.65)!important;box-shadow:0 0 15px rgba(255,0,0,.50), inset 0 1px 0 rgba(255,255,255,.18)!important;}
  .pro-menu-logout a:active{transform:scale(.985)!important;filter:brightness(1.08)!important;}
}

/* MAX SPEED PATCH: keep the look, reduce mobile paint cost */
@media (max-width: 700px){
  body{background-attachment:scroll!important;background-size:cover!important;}
  .card,.hero-panel,.resource-card,.building-card,.info-strip,.top,.life-panel,.survival-hud{
    -webkit-backdrop-filter:none!important;backdrop-filter:none!important;
  }
  .resource-card,.building-card,.hero-panel,.card,.top,.pro-mobile-menu{
    box-shadow:0 10px 28px rgba(0,0,0,.38)!important;
  }
  .forest-fx,.firefly,.leaf-bit{display:none!important;}
  .resource-card:hover,.building-card:hover,.building-tile:hover,.btn:hover,button:hover{transform:none!important;}
  .resource-card,.building-card,.hero-panel,.top{animation:none!important;}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important;}
}
.building-card,.resource-card,.card,.info-strip{content-visibility:auto;contain-intrinsic-size:320px;}
img{max-width:100%;height:auto;}
/* Production boost + combat update */
.boost-box{display:flex;justify-content:space-between;gap:14px;align-items:center;margin:14px 0 18px;padding:14px 16px;border:1px solid rgba(89,255,119,.28);border-radius:20px;background:linear-gradient(135deg,rgba(7,35,20,.82),rgba(6,15,10,.78));box-shadow:0 14px 32px rgba(0,0,0,.22), inset 0 0 22px rgba(71,255,96,.06)}
.boost-box b{display:block;color:#7cff85;font-size:18px}.boost-box span,.boost-box em{color:rgba(255,255,255,.78);font-style:normal}.boost-box button{border:0;border-radius:14px;padding:12px 16px;font-weight:900;color:#07140b;background:linear-gradient(135deg,#fff071,#f0a900);box-shadow:0 0 18px rgba(255,214,49,.25);cursor:pointer}.boost-box button:disabled{opacity:.45;filter:grayscale(.5);cursor:not-allowed}.combat-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0}.combat-stats div,.boss-card{border:1px solid rgba(89,255,119,.22);border-radius:20px;background:rgba(5,22,13,.72);padding:16px}.combat-stats span{display:block;color:rgba(255,255,255,.68);font-size:13px}.combat-stats b{font-size:26px;color:#66ff78}.boss-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin:16px 0}.boss-card h2{margin:0 0 8px;color:#fff}.boss-card p{color:#9dffab}.boss-card small{display:block;color:rgba(255,255,255,.72);margin:8px 0 14px}.boss-card button{width:100%;border:0;border-radius:14px;padding:13px;font-weight:900;color:#06150b;background:linear-gradient(135deg,#58ff6d,#19b843);cursor:pointer}
@media(max-width:760px){.boost-box{display:block}.boost-box form{margin-top:12px}.boost-box button{width:100%}.combat-stats,.boss-grid{grid-template-columns:1fr}}
/* Danger scaling notice */
.danger-scale{border-color:rgba(255,186,73,.35)!important;background:linear-gradient(135deg,rgba(255,180,40,.12),rgba(30,8,0,.42))!important;display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap}.danger-scale b{color:#ffd36b}.danger-scale span{color:rgba(255,255,255,.82);font-size:.92rem}
@media(max-width:640px){.danger-scale{align-items:flex-start}.danger-scale span{font-size:.84rem}}

/* 018 + 021: world seasons/weather/game-clock HUD */
.world-hud{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:12px 0 18px;
}
.world-hud>div,.danger-grid>div{
  background:rgba(3,24,14,.72);border:1px solid rgba(122,255,171,.18);border-radius:18px;padding:12px 14px;
  box-shadow:0 10px 28px rgba(0,0,0,.18);backdrop-filter:blur(8px)
}
.world-hud span,.danger-grid span{display:block;color:#a7f5c6;font-size:12px;letter-spacing:.02em;text-transform:uppercase}
.world-hud b,.danger-grid b{display:block;color:#fff;font-size:20px;margin-top:2px}
.world-hud small{display:block;color:rgba(255,255,255,.68);font-size:12px;margin-top:3px}
.world-hud.night>div{border-color:rgba(156,120,255,.25);background:rgba(10,8,28,.78)}
body.night-mode .hero-panel, body.night-mode .card{box-shadow:0 16px 42px rgba(20,8,58,.22)}
body.night-mode .forest-fx{opacity:.9;filter:hue-rotate(45deg) brightness(.75)}
.danger-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:14px 0 18px}
@media(max-width:720px){.world-hud,.danger-grid{grid-template-columns:1fr}.world-hud>div,.danger-grid>div{padding:10px 12px;border-radius:14px}.world-hud b,.danger-grid b{font-size:18px}}

/* 011 + 012: ambient sound toggle */
.sound-toggle{
  appearance:none;border:1px solid rgba(103,255,105,.22);border-radius:999px;padding:10px 13px;
  color:#eaffee;background:rgba(4,24,12,.72);font-weight:900;cursor:pointer;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 8px 22px rgba(0,0,0,.20);
}
.sound-toggle[aria-pressed="true"]{background:linear-gradient(135deg,rgba(103,255,105,.30),rgba(12,89,31,.82));border-color:rgba(103,255,105,.48)}
.sound-toggle:active{transform:scale(.98)}
@media(max-width:900px){.sound-toggle{position:fixed;top:calc(16px + env(safe-area-inset-top));right:68px;z-index:30020;padding:10px 11px;font-size:13px}.pro-drawer-open .sound-toggle{display:none}}
@media(min-width:901px){.sound-toggle{margin-left:auto}.top .mobile-menu-toggle+.sound-toggle{order:2}.top .nav{order:3}}

/* 023: sound button beside mobile drawer X + one-shot FX polish */
@media(max-width:900px){
  .sound-toggle{
    position:fixed!important;
    top:calc(16px + env(safe-area-inset-top))!important;
    right:82px!important;
    z-index:2147483210!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:54px!important;
    height:46px!important;
    min-width:54px!important;
    padding:0!important;
    border-radius:18px!important;
    font-size:22px!important;
    line-height:1!important;
    background:rgba(5,26,14,.92)!important;
    border:1px solid rgba(103,255,105,.36)!important;
    box-shadow:0 10px 28px rgba(0,0,0,.45),0 0 20px rgba(103,255,105,.12)!important;
  }
  body.pro-drawer-open .sound-toggle{
    display:inline-flex!important;
    opacity:1!important;
    pointer-events:auto!important;
    right:82px!important;
  }
  .sound-toggle[aria-pressed="true"]{
    background:linear-gradient(135deg,rgba(103,255,105,.38),rgba(11,86,33,.94))!important;
    border-color:rgba(103,255,105,.62)!important;
  }
}

/* 024: FX-only sound toggle inside mobile drawer header */
@media(max-width:900px){
  .pro-menu-head{gap:10px!important;}
  .pro-menu-head .sound-toggle,
  .sound-toggle.sound-toggle-in-menu{
    position:static!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:48px!important;
    height:44px!important;
    min-width:48px!important;
    padding:0!important;
    margin-left:auto!important;
    margin-right:8px!important;
    border-radius:16px!important;
    font-size:21px!important;
    line-height:1!important;
    background:rgba(5,26,14,.92)!important;
    border:1px solid rgba(103,255,105,.40)!important;
    box-shadow:0 8px 22px rgba(0,0,0,.38),0 0 18px rgba(103,255,105,.13)!important;
    z-index:auto!important;
  }
  .pro-menu-head .sound-toggle[aria-pressed="true"],
  .sound-toggle.sound-toggle-in-menu[aria-pressed="true"]{
    background:linear-gradient(135deg,rgba(103,255,105,.40),rgba(11,86,33,.95))!important;
    border-color:rgba(103,255,105,.65)!important;
  }
}

/* 025 Skill system – compact and fast */
.skills-box{margin:14px 0;padding:14px;border:1px solid rgba(137,255,193,.16);background:rgba(4,18,12,.62);border-radius:18px;box-shadow:0 10px 28px rgba(0,0,0,.16)}
.skills-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}
.skills-head h2{margin:0 0 4px;font-size:18px}.skills-head p{margin:0;color:rgba(235,255,244,.72);font-size:13px}.skills-head strong{white-space:nowrap;color:#8affc1;background:rgba(138,255,193,.1);border:1px solid rgba(138,255,193,.18);padding:7px 10px;border-radius:999px}
.skills-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.skill-card{display:flex;align-items:center;gap:10px;justify-content:space-between;margin:0;padding:10px;border-radius:14px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08)}
.skill-card div{min-width:0}.skill-card b{display:block;font-size:13px}.skill-card span{display:block;font-size:11px;color:rgba(235,255,244,.62);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.skill-card strong{font-size:18px;color:#8affc1}.skill-card button{border:0;border-radius:10px;padding:8px 10px;background:#8affc1;color:#062011;font-weight:800}.skill-card button:disabled{opacity:.35;filter:grayscale(1)}
@media(max-width:760px){.skills-head{align-items:stretch;flex-direction:column}.skills-grid{grid-template-columns:1fr 1fr}.skill-card{padding:9px}.skill-card span{white-space:normal}}

/* 026 Moral system light */
.moral-box{margin:14px 0;padding:14px;border:1px solid rgba(137,255,193,.16);background:linear-gradient(135deg,rgba(4,18,12,.72),rgba(18,10,22,.54));border-radius:18px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}
.moral-box span{display:block;color:#a7ffd0;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}.moral-box b{display:block;color:#fff;margin:3px 0}.moral-box small{display:block;color:rgba(255,255,255,.68);font-size:12px}.moral-box i{display:block;height:8px;margin:8px 0;border-radius:99px;background:rgba(255,255,255,.10);overflow:hidden}.moral-box i:before{content:"";display:block;width:var(--p);height:100%;background:linear-gradient(90deg,#ff5d73,#ffd66b,#70ffad);border-radius:inherit}.moral-box form{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.moral-box button{border:0;border-radius:14px;padding:11px 13px;font-weight:1000;color:#082014;background:linear-gradient(135deg,#70ffad,#2acb72);cursor:pointer}.moral-box button.dark{color:#fff;background:linear-gradient(135deg,#6d314f,#161017);border:1px solid rgba(255,112,170,.25)}@media(max-width:700px){.moral-box{grid-template-columns:1fr}.moral-box form{justify-content:stretch}.moral-box button{flex:1;min-height:44px}}

/* 028 weather gameplay effects - compact/light */
.weather-effects{margin:.45rem 0 .8rem;padding:.55rem .75rem;border:1px solid rgba(120,255,190,.18);background:rgba(4,24,14,.55);border-radius:14px;font-size:.9rem;display:flex;gap:.5rem;align-items:center;justify-content:space-between;backdrop-filter:blur(4px)}
.weather-effects b{color:#9fffc9;white-space:nowrap}.weather-effects span{opacity:.9;text-align:right}
@media(max-width:640px){.weather-effects{font-size:.82rem;align-items:flex-start;flex-direction:column;gap:.2rem}.weather-effects span{text-align:left}}

/* 028.1 UI polish – beautiful compact skill panel */
.skills-box-v2{max-width:980px;margin:18px auto 22px!important;padding:18px!important;border-radius:22px!important;background:radial-gradient(circle at 12% 18%,rgba(112,255,173,.16),transparent 32%),linear-gradient(135deg,rgba(5,30,16,.86),rgba(4,18,13,.72))!important;border:1px solid rgba(112,255,173,.24)!important;box-shadow:0 16px 42px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.05)!important}.skills-box-v2 .skills-head{align-items:center;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:14px;margin-bottom:14px}.skills-kicker{display:inline-block;margin-bottom:5px;color:#88ffc2;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;opacity:.85}.skills-box-v2 .skills-head h2{font-size:24px;line-height:1.1;margin:0 0 7px;text-shadow:0 0 18px rgba(112,255,173,.18)}.skills-box-v2 .skills-head p{max-width:620px;font-size:14px;line-height:1.45;color:rgba(235,255,244,.74)}.skills-box-v2 .skills-head strong{display:grid;place-items:center;min-width:92px;height:68px;border-radius:18px;background:linear-gradient(135deg,rgba(112,255,173,.20),rgba(18,122,58,.20));border:1px solid rgba(112,255,173,.28);font-size:26px;color:#9dffc9;box-shadow:0 0 20px rgba(112,255,173,.08)}.skills-box-v2 .skills-head strong em{display:block;font-style:normal;font-size:11px;color:rgba(235,255,244,.65);text-transform:uppercase;letter-spacing:.06em;margin-bottom:-2px}.skills-box-v2 .skills-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.skills-box-v2 .skill-card{display:grid;grid-template-columns:46px 1fr auto 52px;align-items:center;gap:12px;padding:13px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.10);box-shadow:inset 0 1px 0 rgba(255,255,255,.04);min-height:72px}.skills-box-v2 .skill-card:hover{border-color:rgba(112,255,173,.28);background:rgba(112,255,173,.075)}.skills-box-v2 .skill-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:15px;background:rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.10);font-size:24px;filter:drop-shadow(0 0 8px rgba(112,255,173,.18))}.skills-box-v2 .skill-info{min-width:0}.skills-box-v2 .skill-info b{display:block;font-size:15px;margin-bottom:3px}.skills-box-v2 .skill-info span{display:block;font-size:12px;color:rgba(235,255,244,.67);white-space:normal;overflow:visible;text-overflow:clip}.skills-box-v2 .skill-info i{display:block;height:5px;margin-top:8px;border-radius:999px;background:rgba(255,255,255,.09);overflow:hidden}.skills-box-v2 .skill-info i:before{content:"";display:block;height:100%;width:var(--w);border-radius:inherit;background:linear-gradient(90deg,#70ffad,#ffd66b);box-shadow:0 0 12px rgba(112,255,173,.45)}.skills-box-v2 .skill-card strong{font-size:22px;color:#9dffc9;min-width:24px;text-align:center}.skills-box-v2 .skill-card button{width:48px;height:42px;padding:0;border-radius:14px;background:linear-gradient(135deg,#70ffad,#24c96e);color:#062011;border:0;font-weight:1000;box-shadow:0 8px 18px rgba(36,201,110,.18)}.skills-box-v2 .skill-card button:disabled{opacity:.34;box-shadow:none;filter:grayscale(.6)}@media(max-width:760px){.skills-box-v2{margin:14px auto 18px!important;padding:14px!important;border-radius:20px!important}.skills-box-v2 .skills-head{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding-bottom:12px}.skills-box-v2 .skills-head h2{font-size:20px}.skills-box-v2 .skills-head p{font-size:12px}.skills-box-v2 .skills-head strong{min-width:70px;height:58px;font-size:22px;border-radius:15px}.skills-box-v2 .skills-grid{grid-template-columns:1fr;gap:9px}.skills-box-v2 .skill-card{grid-template-columns:40px 1fr auto 46px;gap:9px;min-height:64px;padding:10px;border-radius:16px}.skills-box-v2 .skill-icon{width:40px;height:40px;border-radius:13px;font-size:21px}.skills-box-v2 .skill-info b{font-size:14px}.skills-box-v2 .skill-info span{font-size:11px}.skills-box-v2 .skill-card button{width:44px;height:38px}}

/* Legal pages – rules/privacy/terms via index.php?iD=19/20/21 */
.legal-hero{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;margin:18px 0 16px;padding:22px!important;background:radial-gradient(circle at 10% 10%,rgba(112,255,173,.16),transparent 34%),linear-gradient(135deg,rgba(5,30,16,.88),rgba(4,18,13,.72))!important;border:1px solid rgba(112,255,173,.22)!important;border-radius:24px!important;box-shadow:0 16px 44px rgba(0,0,0,.26)!important}.legal-icon{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:16px;background:rgba(112,255,173,.12);border:1px solid rgba(112,255,173,.24);font-size:25px;margin-bottom:8px}.legal-hero h1{margin:0 0 8px;font-size:clamp(28px,4vw,44px);line-height:1.05}.legal-hero p{margin:0;max-width:760px;color:rgba(235,255,244,.78);font-size:15px;line-height:1.55}.legal-hero aside{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.legal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:14px 0}.legal-card{padding:18px;border-radius:20px;background:rgba(4,18,12,.66);border:1px solid rgba(255,255,255,.09);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}.legal-card h2{font-size:18px;margin:0 0 12px;color:#b4ffd3}.legal-card ul{margin:0;padding-left:19px}.legal-card li{margin:8px 0;color:rgba(245,255,249,.84);line-height:1.45}.legal-note{font-size:13px;color:rgba(245,255,249,.72)}.footer a{color:#9dffc9;text-decoration:none}.footer a:hover{text-decoration:underline}@media(max-width:760px){.legal-hero{grid-template-columns:1fr;padding:17px!important;border-radius:20px!important}.legal-hero aside{justify-content:flex-start}.legal-grid{grid-template-columns:1fr}.legal-card{padding:15px;border-radius:18px}.legal-card h2{font-size:16px}.legal-card li{font-size:13px}}

/* 029.2 Legal pages final polish – clean, readable, mobile-friendly */
.legal-page{
  max-width:1180px;
  margin:18px auto 36px;
  padding:0 14px 36px;
}
.legal-page, .legal-page *{
  box-sizing:border-box;
}
.legal-hero-pro{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1fr) 260px;
  gap:22px;
  align-items:stretch;
  margin:18px 0 18px!important;
  padding:26px!important;
  border-radius:28px!important;
  background:
    radial-gradient(circle at 12% 15%, rgba(112,255,173,.22), transparent 34%),
    radial-gradient(circle at 88% 22%, rgba(255,214,107,.12), transparent 30%),
    linear-gradient(135deg, rgba(4,24,14,.92), rgba(5,18,14,.78))!important;
  border:1px solid rgba(112,255,173,.28)!important;
  box-shadow:0 20px 55px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.07)!important;
}
.legal-hero-pro:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.045) 45%, transparent 70%);
  opacity:.7;
}
.legal-hero-main{position:relative;z-index:1;min-width:0;}
.legal-kicker{
  display:inline-flex;
  align-items:center;
  gap:7px;
  width:auto;
  margin:0 0 12px;
  padding:7px 11px;
  border-radius:999px;
  color:#8affc1;
  background:rgba(112,255,173,.10);
  border:1px solid rgba(112,255,173,.20);
  font-size:12px;
  font-weight:950;
  letter-spacing:.07em;
  text-transform:uppercase;
}
.legal-title-row{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:12px;
}
.legal-icon-pro{
  flex:0 0 auto;
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(112,255,173,.22), rgba(23,102,50,.24));
  border:1px solid rgba(112,255,173,.30);
  box-shadow:0 0 24px rgba(112,255,173,.12), inset 0 1px 0 rgba(255,255,255,.08);
  font-size:30px;
}
.legal-title-row h1{
  margin:0;
  font-size:clamp(30px,4.2vw,54px);
  line-height:1.02;
  letter-spacing:-.045em;
  text-shadow:0 0 25px rgba(112,255,173,.12);
}
.legal-hero-main p{
  margin:0;
  max-width:850px;
  color:rgba(242,255,248,.82);
  font-size:16px;
  line-height:1.62;
}
.legal-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  margin-top:18px;
}
.legal-chip-row span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:8px 12px;
  border-radius:999px;
  color:#eafff2;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.10);
  font-size:13px;
  line-height:1.1;
  white-space:nowrap;
}
.legal-nav-card{
  position:relative;
  z-index:1;
  align-self:stretch;
  min-width:0;
  padding:16px;
  border-radius:22px;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045);
}
.legal-nav-card b{
  display:block;
  margin-bottom:10px;
  color:#ffffff;
  font-size:14px;
}
.legal-nav-link{
  display:flex;
  align-items:center;
  gap:9px;
  width:100%;
  margin:7px 0;
  padding:11px 12px;
  border-radius:15px;
  color:rgba(242,255,248,.84)!important;
  text-decoration:none!important;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.08);
  font-size:14px;
  font-weight:800;
}
.legal-nav-link:hover,
.legal-nav-link.active{
  color:#062012!important;
  background:linear-gradient(135deg,#8affc1,#38d77d);
  border-color:rgba(138,255,193,.55);
  box-shadow:0 10px 22px rgba(56,215,125,.16);
}
.legal-nav-card small{
  display:block;
  margin-top:12px;
  color:rgba(242,255,248,.58);
  font-size:12px;
  line-height:1.35;
}
.legal-summary-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:16px 0;
}
.legal-summary-grid article{
  padding:16px;
  border-radius:20px;
  background:rgba(4,18,12,.68);
  border:1px solid rgba(112,255,173,.15);
  box-shadow:0 12px 30px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.04);
}
.legal-summary-grid b{
  display:block;
  margin-bottom:7px;
  color:#baffd5;
  font-size:15px;
}
.legal-summary-grid p{
  margin:0;
  color:rgba(242,255,248,.75);
  line-height:1.5;
  font-size:13px;
}
.legal-toc{
  margin:16px 0 20px!important;
  padding:18px!important;
  border-radius:22px!important;
  background:rgba(4,18,12,.72)!important;
  border:1px solid rgba(112,255,173,.18)!important;
}
.legal-toc>b{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:12px;
  color:#ffffff;
  font-size:15px;
}
.legal-toc>b:before{content:"🧭";}
.legal-toc div{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.legal-toc a{
  display:inline-flex;
  align-items:center;
  padding:8px 11px;
  border-radius:999px;
  color:rgba(242,255,248,.78)!important;
  text-decoration:none!important;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  font-size:13px;
  line-height:1.15;
}
.legal-toc a:hover{
  color:#062012!important;
  background:#8affc1;
}
.legal-grid-pro{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.legal-card-pro{
  display:grid;
  grid-template-columns:58px minmax(0,1fr);
  gap:16px;
  padding:20px;
  border-radius:24px;
  background:
    linear-gradient(135deg, rgba(5,26,15,.78), rgba(6,18,16,.64));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 14px 34px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.045);
  scroll-margin-top:22px;
}
.legal-card-pro:hover{
  border-color:rgba(112,255,173,.24);
  background:linear-gradient(135deg, rgba(7,34,19,.82), rgba(6,18,16,.66));
}
.legal-sec-number{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  color:#9dffc9;
  background:rgba(112,255,173,.10);
  border:1px solid rgba(112,255,173,.20);
  font-weight:1000;
  font-size:15px;
}
.legal-card-pro h2{
  margin:0 0 12px;
  color:#fff;
  font-size:22px;
  line-height:1.2;
  letter-spacing:-.02em;
}
.legal-card-pro ul{
  margin:0;
  padding:0;
  list-style:none;
}
.legal-card-pro li{
  position:relative;
  margin:10px 0;
  padding-left:22px;
  color:rgba(242,255,248,.80);
  font-size:15px;
  line-height:1.58;
}
.legal-card-pro li:before{
  content:"";
  position:absolute;
  left:0;
  top:.72em;
  width:7px;
  height:7px;
  border-radius:50%;
  background:#8affc1;
  box-shadow:0 0 10px rgba(138,255,193,.48);
}
.legal-final-note{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin:18px 0 0!important;
  padding:18px!important;
  border-radius:22px!important;
  background:linear-gradient(135deg,rgba(112,255,173,.10),rgba(255,214,107,.06))!important;
  border:1px solid rgba(112,255,173,.18)!important;
}
.legal-final-note b{
  display:block;
  margin-bottom:5px;
  color:#baffd5;
  font-size:15px;
}
.legal-final-note p{
  margin:0;
  color:rgba(242,255,248,.72);
  font-size:13px;
  line-height:1.45;
}
.legal-final-note .btn{
  flex:0 0 auto;
  text-decoration:none!important;
}
@media(max-width:900px){
  .legal-hero-pro{grid-template-columns:1fr;gap:14px;padding:20px!important;border-radius:24px!important;}
  .legal-nav-card{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:center;padding:12px;}
  .legal-nav-card b,.legal-nav-card small{grid-column:1/-1;margin:0;}
  .legal-nav-link{margin:0;justify-content:center;text-align:center;padding:10px 8px;font-size:13px;}
  .legal-summary-grid{grid-template-columns:1fr;gap:10px;}
}
@media(max-width:640px){
  .legal-page{padding:0 10px 24px;margin-top:10px;}
  .legal-hero-pro{padding:16px!important;border-radius:22px!important;}
  .legal-title-row{gap:10px;align-items:flex-start;}
  .legal-icon-pro{width:46px;height:46px;border-radius:15px;font-size:24px;}
  .legal-title-row h1{font-size:29px;line-height:1.08;}
  .legal-hero-main p{font-size:14px;line-height:1.55;}
  .legal-chip-row{gap:7px;margin-top:14px;}
  .legal-chip-row span{font-size:12px;min-height:30px;padding:7px 10px;white-space:normal;}
  .legal-nav-card{grid-template-columns:1fr;}
  .legal-nav-link{justify-content:flex-start;}
  .legal-toc{padding:14px!important;border-radius:18px!important;}
  .legal-toc div{max-height:190px;overflow:auto;padding-right:3px;}
  .legal-toc a{width:100%;border-radius:13px;}
  .legal-card-pro{grid-template-columns:1fr;gap:9px;padding:16px;border-radius:20px;}
  .legal-sec-number{width:40px;height:40px;border-radius:13px;font-size:13px;}
  .legal-card-pro h2{font-size:19px;margin-bottom:9px;}
  .legal-card-pro li{font-size:14px;line-height:1.52;margin:9px 0;}
  .legal-final-note{flex-direction:column;align-items:stretch;border-radius:20px!important;}
  .legal-final-note .btn{text-align:center;}
}

/* === 032 mobile speed/accessibility polish === */
.pro-mobile-menu[hidden]{display:none!important;}
@media(max-width:760px){
  body{background-attachment:scroll!important;}
  .card,.hero-panel,.resource-card,.building-card,.info-strip,.top,.profile-hero,.error-page,.blocked-card{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  .forest-fx,.firefly,.leaf-bit{display:none!important;}
  .building-grid,.resource-grid,.info-strip,.wood-profile,.legal-shell,.online-panel{content-visibility:auto;contain-intrinsic-size:600px;}
  .hero-panel,.resource-card,.building-card,.top{animation:none!important;}
  .btn:hover,button:hover,.resource-card:hover,.building-card:hover,.building-tile:hover{transform:none!important;}
  .resource-card,.building-card,.card{box-shadow:0 12px 34px rgba(0,0,0,.36)!important;}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}


/* 059 account settings forest UI + dynamic motto */
.account-page-pro{max-width:1180px;margin:22px auto 40px;padding:0 10px;}
.account-hero-pro{display:grid;grid-template-columns:86px 1fr;gap:18px;align-items:center;padding:24px;border-radius:28px;background:linear-gradient(135deg,rgba(5,34,20,.90),rgba(43,25,7,.78));border:1px solid rgba(158,255,112,.20);box-shadow:0 24px 70px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.08);position:relative;overflow:hidden;}
.account-hero-pro:before{content:"";position:absolute;inset:-40px;background:radial-gradient(circle at 18% 20%,rgba(130,255,92,.18),transparent 34%),radial-gradient(circle at 82% 12%,rgba(255,198,91,.12),transparent 28%);pointer-events:none;}
.account-hero-pro>*{position:relative;z-index:1;}
.account-hero-icon{width:72px;height:72px;border-radius:24px;display:grid;place-items:center;font-size:40px;background:linear-gradient(135deg,#114b23,#6fdc45);box-shadow:0 0 28px rgba(112,255,90,.28);border:1px solid rgba(255,255,255,.14);}
.account-hero-pro h1{margin:0;color:#f8ffe9;font-size:clamp(32px,5vw,58px);letter-spacing:.5px;text-shadow:0 3px 0 rgba(0,0,0,.35);}
.account-hero-pro p{margin:8px 0 0;color:rgba(242,255,237,.82);font-size:16px;line-height:1.55;max-width:850px;}
.account-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;}
.account-badges span{padding:8px 12px;border-radius:999px;background:rgba(0,0,0,.28);border:1px solid rgba(172,255,118,.16);color:#dfffd4;font-weight:800;font-size:13px;}
.account-layout-pro{display:grid;grid-template-columns:330px 1fr;gap:18px;margin-top:18px;align-items:start;}
.account-preview-pro,.account-panel-pro{background:linear-gradient(180deg,rgba(5,22,14,.88),rgba(9,16,9,.82));border:1px solid rgba(171,255,95,.20);border-radius:26px;box-shadow:0 20px 58px rgba(0,0,0,.38),inset 0 1px 0 rgba(255,255,255,.06);}
.account-preview-pro{padding:22px;text-align:center;position:sticky;top:14px;}
.account-avatar-pro{width:86px;height:86px;margin:0 auto 12px;border-radius:28px;display:grid;place-items:center;background:linear-gradient(135deg,#073c22,#32ce78);border:1px solid rgba(137,255,157,.34);box-shadow:0 0 30px rgba(70,255,137,.22);font-size:38px;font-weight:1000;color:#fff;}
.account-preview-pro h2{margin:0;color:#a8ff67;font-size:30px;}
.account-preview-pro small{display:block;color:rgba(239,255,236,.62);margin-top:3px;}
.motto-preview-pro{margin:18px 0;padding:18px;border-radius:22px;background:linear-gradient(180deg,#f5e0a9,#e8c989);border:3px solid rgba(99,57,24,.75);box-shadow:inset 0 1px 0 rgba(255,255,255,.45);color:#2e431e;}
.motto-preview-pro b{display:block;background:#496b2e;color:#fff2cf;border-radius:10px;padding:8px;margin-bottom:12px;letter-spacing:1px;}
.motto-preview-pro p{font-family:Georgia,serif;font-size:22px;font-weight:800;line-height:1.25;margin:0;word-break:break-word;}
.account-wide-btn{display:block;text-decoration:none;margin-top:12px;}
.account-form-grid-pro{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;}
.account-panel-pro{padding:20px;}
.account-panel-pro.motto-panel{grid-column:1/-1;}
.account-panel-head{display:flex;gap:13px;align-items:flex-start;margin-bottom:14px;}
.account-panel-head>span{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:rgba(117,255,100,.13);border:1px solid rgba(155,255,110,.22);font-size:25px;flex:0 0 auto;}
.account-panel-head h2{margin:0;color:#b7ff72;font-size:23px;}
.account-panel-head p{margin:4px 0 0;color:rgba(240,255,236,.68);font-size:14px;line-height:1.45;}
.account-panel-pro input,.account-panel-pro textarea{width:100%;box-sizing:border-box;margin:7px 0;padding:13px 14px;border-radius:15px;border:1px solid rgba(179,255,106,.20);background:rgba(0,0,0,.28);color:#fff;font:inherit;outline:none;}
.account-panel-pro input:focus,.account-panel-pro textarea:focus{border-color:rgba(144,255,92,.55);box-shadow:0 0 0 3px rgba(112,255,97,.10);}
.account-panel-pro textarea{min-height:124px;resize:vertical;}
.account-panel-pro button{border:0;border-radius:15px;padding:13px 18px;font-weight:1000;cursor:pointer;background:linear-gradient(135deg,#8cff5b,#28d278);color:#062114;box-shadow:0 12px 28px rgba(34,220,112,.22);}
.account-help-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:6px;}
.account-help-row small{color:rgba(235,255,226,.62);}
.account-panel-pro.danger{border-color:rgba(255,92,70,.34);background:linear-gradient(180deg,rgba(35,12,8,.85),rgba(15,18,9,.80));}
.account-panel-pro.danger .account-panel-head>span{background:rgba(255,83,60,.14);border-color:rgba(255,83,60,.28);}
.account-panel-pro.danger h2{color:#ff9d7e;}
.account-panel-pro.danger button{background:linear-gradient(135deg,#ffb36d,#ff674f);color:#230904;}
.checkline{display:block;margin:12px 0;color:#e8f6df;line-height:1.45;}
.checkline input{width:auto!important;margin-right:8px;}
.checkline a{color:#9cff68;font-weight:800;}
@media(max-width:900px){.account-layout-pro{grid-template-columns:1fr}.account-preview-pro{position:relative;top:auto}.account-form-grid-pro{grid-template-columns:1fr}.account-panel-pro.motto-panel{grid-column:auto}.account-hero-pro{grid-template-columns:1fr;text-align:center}.account-hero-icon{margin:auto}.account-badges{justify-content:center}}
@media(max-width:620px){.account-page-pro{margin:10px auto 26px;padding:0 6px}.account-hero-pro{padding:18px;border-radius:22px}.account-hero-pro p{font-size:14px}.account-preview-pro,.account-panel-pro{border-radius:20px;padding:16px}.motto-preview-pro p{font-size:19px}.account-panel-head{gap:10px}.account-panel-head>span{width:42px;height:42px}.account-help-row{flex-direction:column;align-items:stretch}.account-panel-pro button{width:100%;}.account-badges span{width:100%;text-align:center}}
/* 061 profile image moderation */
.profile-approved-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block;box-shadow:inset 0 0 35px rgba(0,0,0,.35)}
.profile-img-status-pro{margin:12px 0;padding:10px 12px;border-radius:14px;background:rgba(143,224,49,.13);border:1px solid rgba(143,224,49,.35);color:#dfffad;font-weight:800;line-height:1.35}
.profile-img-status-pro.bad{background:rgba(255,80,60,.12);border-color:rgba(255,80,60,.35);color:#ffb3a8}.profile-img-status-pro.ok{background:rgba(55,210,120,.12);border-color:rgba(55,210,120,.35);color:#baffcf}.account-mini-note{color:#d8c99b;font-size:13px;line-height:1.4;margin:4px 0 12px}.image-panel input[type=file]{border:1px dashed rgba(210,170,78,.45);padding:14px;background:rgba(0,0,0,.22);border-radius:12px;color:#f7efd2}.wood-avatar{overflow:hidden}
/* 062: profiilipildi raam korda — kinnitatud foto täidab kogu kasti ilma heleda vaheta */
.wood-avatar.has-image{padding:0;background:#07150d;border-color:#6a421f;display:block;line-height:0;}
.wood-avatar.has-image .profile-approved-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:15px;display:block;box-shadow:none;}
.account-avatar-pro.has-image{overflow:hidden;padding:0;}
.account-avatar-pro.has-image img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit;}
@media(max-width:520px){.wood-left{padding:12px}.wood-avatar.has-image .profile-approved-img{border-radius:14px}}

/* 080 Mobile push notifications */
.push-card{margin:14px 0 18px;padding:16px;border:1px solid rgba(123,255,145,.22);border-radius:16px;background:rgba(0,35,18,.52)}
.push-card p{margin:6px 0 12px}.push-card small{display:block;margin-top:8px;color:#bfffc1}


/* === 082 fixed mobile/desktop PageSpeed stability patch === */
img,svg,video,canvas{max-width:100%;height:auto}
.brand img{width:50px;height:50px;min-width:50px;min-height:50px;aspect-ratio:1/1;display:block;flex:0 0 50px}
.top{min-height:70px;contain:layout paint}
.hero-panel{contain:layout paint;min-height:315px;animation:none!important}
.hero-copy{min-height:315px}
.hero-art{min-height:315px;aspect-ratio:16/9;background-position:center center;transform:translateZ(0)}
.hero-meta{min-height:64px}.meta-box{min-height:66px}
.info-strip{min-height:102px;contain:layout paint}
.resource-card,.building-card,.hero-panel,.top{animation:none!important}
.forest-fx,.firefly,.leaf-bit{display:none!important}
@media(max-width:850px){body{background-attachment:scroll!important}.wrap{width:min(94vw,560px);padding-top:12px}.top{min-height:70px;padding:10px 12px;margin-bottom:14px;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.brand img{width:48px;height:48px;min-width:48px;min-height:48px;flex-basis:48px}.brand-text{min-width:120px}.mobile-menu-toggle{display:grid!important;width:48px;height:48px;min-width:48px;place-items:center;line-height:1;padding:0}.hero-panel{grid-template-columns:1fr;grid-template-rows:220px auto;gap:0;min-height:512px;border-radius:22px;overflow:hidden;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.hero-art{order:-1;height:220px;min-height:220px;aspect-ratio:auto;background-position:center top}.hero-copy{min-height:292px;padding:24px 20px}.hero-panel h1{font-size:30px;line-height:1.05;margin-bottom:14px}.hero-panel p{font-size:16px;line-height:1.55}.hero-meta{min-height:70px;margin-top:22px;gap:10px}.meta-box{width:100%;min-height:62px;padding:12px}.info-strip{grid-template-columns:1fr;min-height:210px;padding:16px;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.card,.resource-card,.building-card{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.btn:hover,button:hover,.resource-card:hover,.building-card:hover,.building-tile:hover{transform:none!important}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}

/* === 083 hero overflow / clipping clean UI fix === */
.hero-panel{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:0!important;align-items:stretch!important;min-height:420px!important;height:auto!important;overflow:hidden!important;border-radius:22px!important;contain:paint!important}
.hero-copy{min-width:0!important;min-height:0!important;height:auto!important;padding:58px 56px 44px!important;overflow:hidden!important;display:flex!important;flex-direction:column!important;justify-content:center!important}
.hero-panel h1,.hero-panel p,.hero-meta{min-width:0!important;max-width:100%!important}.hero-panel p{overflow-wrap:break-word!important;word-break:normal!important}.hero-art{min-width:0!important;width:100%!important;height:100%!important;min-height:420px!important;aspect-ratio:auto!important;background-size:cover!important;background-position:center center!important;display:block!important}.hero-meta{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:18px!important;min-height:0!important}.meta-box{min-width:0!important;width:100%!important}.info-strip{position:relative!important;z-index:2!important;clear:both!important}
@media(max-width:850px){.hero-panel{grid-template-columns:1fr!important;grid-template-rows:220px auto!important;min-height:0!important;height:auto!important;contain:paint!important}.hero-art{order:-1!important;height:220px!important;min-height:220px!important;background-position:center top!important}.hero-copy{padding:24px 20px!important;min-height:0!important;justify-content:flex-start!important}.hero-meta{grid-template-columns:1fr!important;gap:10px!important;margin-top:22px!important}}
@media(max-width:520px){.hero-art{height:210px!important;min-height:210px!important}.hero-panel h1{font-size:30px!important}}

/* === 084 safe 100 performance guard === */
html{overflow-x:hidden;text-size-adjust:100%;-webkit-text-size-adjust:100%}
body{overflow-x:hidden}
img{max-width:100%;height:auto}
.hero-panel,.top,.info-strip{transform:translateZ(0)}
.hero-panel{isolation:isolate;contain:layout paint!important}
.hero-copy,.hero-art,.info-strip,.card{min-width:0!important}
.hero-panel h1,.hero-panel p{overflow-wrap:break-word}
.hero-art{will-change:auto!important}
@media(max-width:850px){.hero-panel{content-visibility:visible!important;contain-intrinsic-size:auto!important}.forest-fx{display:none!important}.resource-card,.building-card,.hero-panel,.top,.card,.info-strip{animation:none!important;transition:box-shadow .15s ease,border-color .15s ease!important}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}


/* === 090 DESKTOP CLS + SPEED STABILITY FIX ===
   Safe CSS-only patch: ei muuda mängu loogikat, SQL-i, PWA-d ega push teavitusi.
   Eesmärk: desktop CLS 0.17 -> alla 0.1, säilitades mobiili 100 tulemuse. */
html{overflow-y:scroll;}
body{font-synthesis-weight:none;text-rendering:optimizeLegibility;}
.page-main{min-height:520px;}
.top{min-height:70px;contain:layout paint;}
.brand,.nav,.btn{min-height:44px;}
.hero-panel{min-height:315px;contain:layout paint;transform:none!important;animation:none!important;}
.hero-copy{min-height:315px;min-width:0;overflow:hidden;}
.hero-art{min-height:315px;aspect-ratio:16/9;transform:none!important;animation:none!important;filter:none!important;}
.hero-meta{min-height:82px;}
.meta-box{min-height:66px;}
.resource-grid{min-height:168px;contain:layout;}
.resource-card{min-height:140px;transform:none!important;animation:none!important;}
.info-strip{min-height:102px;contain:layout;transform:none!important;animation:none!important;}
.building-grid,.village{contain:layout;}
.building-card,.building-tile{transform:none!important;}
.hero-panel:before,.building-card:before,.resource-card:after{animation:none!important;transform:none!important;opacity:.18!important;}
.forest-fx{display:none!important;}
.firefly,.leaf-bit{display:none!important;}
@media (min-width:901px){
  .wrap{width:min(1180px,94vw);}
  .hero-panel{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);}
  .hero-copy{padding:42px 44px;}
  .hero-art{height:315px;}
  .resource-grid{grid-template-columns:repeat(4,minmax(0,1fr));}
  .resource-card{height:140px;}
  .top,.hero-panel,.resource-grid,.info-strip{content-visibility:visible;}
}
@media (max-width:900px){
  .hero-panel{grid-template-columns:1fr;min-height:0;}
  .hero-copy{min-height:0;}
  .hero-art{min-height:230px;height:230px;}
  .resource-grid{min-height:0;}
}
@media (max-width:560px){
  .hero-art{min-height:210px;height:210px;}
}


/* === 091 ULTRA FAST RENDER SAFE PATCH ===
   Safe render-only layer: ei muuda SQL-i, mängu loogikat, push/PWA-d ega trackingut.
   Eesmärk: vähendada desktop Speed Index 1.4s -> ~1.0-1.2s ilma CLS-i tõstmata. */
html{background:#06110c;overflow-y:scroll;}
body{background-color:#06110c;}
.top,.hero-panel,.hero-art,.hero-copy,.resource-grid,.info-strip{content-visibility:visible;}
.top,.hero-panel{contain:layout paint;}
.hero-panel,.hero-panel *,.resource-card,.info-strip{animation:none!important;}
.hero-panel,.hero-art{transition:none!important;}
.hero-art{background-image:linear-gradient(90deg,rgba(5,24,15,.22),transparent),url('img/hero-house.webp')!important;background-size:cover!important;background-position:center center!important;}
.forest-fx,.firefly,.leaf-bit{display:none!important;}
@media (min-width:901px){
  .hero-panel{min-height:315px!important;}
  .hero-art{height:315px!important;min-height:315px!important;}
  .hero-copy{min-height:315px!important;}
  .resource-grid{min-height:168px!important;}
}
@media (max-width:900px){
  .hero-art{min-height:220px!important;height:220px!important;}
}

/* === 093 HERO DESKTOP OVERLAP / CLIP FIX ===
   Safe CSS-only UI fix: ei muuda SQL-i, mängu loogikat, push/PWA-d ega trackingut.
   Eesmärk: vasaku teksti fragment ei tohi minna hero pildi peale; desktop hero lahtrid lukus. */
*,*::before,*::after{box-sizing:border-box;}
@media (min-width:901px){
  .hero-panel{
    display:grid!important;
    grid-template-columns:minmax(0,46%) minmax(0,54%)!important;
    grid-template-rows:auto!important;
    gap:0!important;
    align-items:stretch!important;
    overflow:hidden!important;
    contain:layout paint!important;
    isolation:isolate!important;
  }
  .hero-copy{
    grid-column:1!important;
    grid-row:1!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    overflow:hidden!important;
    overflow:clip!important;
    clip-path:inset(0)!important;
    padding:42px 44px!important;
    z-index:2!important;
  }
  .hero-copy > *{
    max-width:100%!important;
    min-width:0!important;
  }
  .hero-panel p{
    width:100%!important;
    max-width:520px!important;
    overflow:hidden!important;
    overflow-wrap:break-word!important;
    word-break:normal!important;
  }
  .hero-meta{
    max-width:100%!important;
    min-width:0!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .meta-box{
    min-width:0!important;
    max-width:100%!important;
  }
  .hero-art{
    grid-column:2!important;
    grid-row:1!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    height:100%!important;
    min-height:315px!important;
    z-index:1!important;
    overflow:hidden!important;
    background-position:center center!important;
    background-size:cover!important;
  }
}
@media (max-width:900px){
  .hero-panel{display:grid!important;grid-template-columns:1fr!important;grid-template-rows:auto auto!important;overflow:hidden!important;}
  .hero-art{grid-column:1!important;grid-row:1!important;order:0!important;width:100%!important;}
  .hero-copy{grid-column:1!important;grid-row:2!important;order:1!important;width:100%!important;overflow:hidden!important;clip-path:none!important;}
}


/* === 094 ULTRA STABLE + HOUSE IMAGE FIX ===
   Safe patch: hoiab 091 index speed parandused, vähendab API koormust ja fikseerib desktop hero/hoonete pildid.
   Ei muuda SQL-i, ressursse, push/PWA loogikat ega mängu funktsioone. */
@media (min-width:901px){
  .hero-panel{
    display:grid!important;
    grid-template-columns:minmax(0,48%) minmax(0,52%)!important;
    gap:0!important;
    overflow:hidden!important;
    contain:layout paint!important;
    isolation:isolate!important;
  }
  .hero-copy{
    grid-column:1!important;
    width:100%!important;
    min-width:0!important;
    max-width:100%!important;
    contain:paint!important;
    overflow:hidden!important;
    clip-path:inset(0)!important;
    padding:42px 38px 42px 44px!important;
  }
  .hero-panel h1{max-width:100%!important;overflow-wrap:break-word!important;}
  .hero-panel p{
    max-width:430px!important;
    width:auto!important;
    overflow:hidden!important;
    overflow-wrap:break-word!important;
    word-break:normal!important;
    line-height:1.62!important;
  }
  .hero-meta{max-width:100%!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .hero-art{
    grid-column:2!important;
    width:100%!important;
    min-width:0!important;
    max-width:100%!important;
    height:100%!important;
    min-height:315px!important;
    overflow:hidden!important;
    background-image:linear-gradient(90deg,rgba(5,24,15,.18),transparent 36%),url('img/hero-house.webp')!important;
    background-size:cover!important;
    background-position:center center!important;
    contain:paint!important;
  }
  .hero-art::before,.hero-art::after{content:none!important;display:none!important;}
}
.building-image{
  background-size:cover!important;
  background-position:center center!important;
  background-repeat:no-repeat!important;
  min-height:230px!important;
  overflow:hidden!important;
  contain:paint!important;
}
.building-life-art{
  background-size:cover!important;
  background-position:center center!important;
  background-repeat:no-repeat!important;
  overflow:hidden!important;
  contain:layout paint!important;
  min-height:360px!important;
}
.building-card,.building-tile,.building-life-hero,.building-life-art{min-width:0!important;}
@media (max-width:900px){
  .hero-panel{grid-template-columns:1fr!important;grid-template-rows:220px auto!important;overflow:hidden!important;}
  .hero-art{grid-column:1!important;grid-row:1!important;height:220px!important;min-height:220px!important;background-position:center top!important;}
  .hero-copy{grid-column:1!important;grid-row:2!important;min-width:0!important;overflow:hidden!important;clip-path:none!important;}
  .building-image{min-height:210px!important;}
  .building-life-art{min-height:280px!important;background-position:center center!important;}
}


/* 097 custom 403 moderator-only blocked page */
.forbidden-card{max-width:760px;margin:28px auto;text-align:center;border:1px solid rgba(255,196,86,.28);background:linear-gradient(135deg,rgba(24,12,6,.92),rgba(5,18,11,.9));box-shadow:0 18px 55px rgba(0,0,0,.42)}
.forbidden-card .forbidden-icon{width:76px;height:76px;margin:0 auto 12px;display:grid;place-items:center;border-radius:24px;background:rgba(255,196,86,.12);border:1px solid rgba(255,196,86,.24);font-size:42px}
.forbidden-card h1{margin:.15em 0 .35em;font-size:clamp(30px,4vw,48px)}
.forbidden-card p{font-size:17px;line-height:1.55}.forbidden-card .btn{margin:6px}

/* === 098 CLEAN HERO IMAGE + FAST SAFE PAGES ===
   Safe visual/speed patch: puhastab hero pildi servateksti, hoiab CLS madalal ja ei muuda mängu loogikat/API/SQL-i. */
.hero-panel{overflow:hidden!important;contain:layout paint!important;transform:none!important;animation:none!important;backface-visibility:hidden!important;}
.hero-copy{position:relative!important;z-index:2!important;min-width:0!important;overflow:hidden!important;contain:layout paint!important;}
.hero-art{position:relative!important;z-index:1!important;background-image:linear-gradient(90deg,rgba(5,24,15,.18),transparent),url('img/hero-house.webp')!important;background-size:cover!important;background-position:center center!important;background-repeat:no-repeat!important;transform:none!important;animation:none!important;filter:none!important;contain:layout paint!important;}
.hero-panel h1,.hero-panel p,.hero-meta{max-width:100%!important;min-width:0!important;}
.hero-panel p{overflow-wrap:break-word!important;}
@media(min-width:901px){
  .hero-panel{grid-template-columns:minmax(0,48%) minmax(0,52%)!important;min-height:315px!important;}
  .hero-copy{padding:42px 44px!important;min-height:315px!important;}
  .hero-art{min-height:315px!important;height:auto!important;}
}
@media(max-width:900px){
  .hero-panel{grid-template-columns:1fr!important;grid-template-rows:220px auto!important;min-height:0!important;}
  .hero-art{order:-1!important;height:220px!important;min-height:220px!important;background-position:center center!important;}
  .hero-copy{padding:24px 20px!important;min-height:0!important;}
}


/* === 099 MOBILE HERO IMAGE VISIBLE + FAST SAFE ===
   Mobiilis kasutab hero nüüd päris <img> elementi, mitte ainult background-image'i.
   See väldib Safari/PWA/cache olukorda, kus pilt ei ilmu, kuid hoiab Speed/CLS parandused alles. */
.hero-art{
  position:relative!important;
  overflow:hidden!important;
  background-color:#06110c!important;
  background-image:linear-gradient(90deg,rgba(5,24,15,.12),transparent),url('/assets/img/hero-house.webp?v=099')!important;
  background-size:cover!important;
  background-position:center center!important;
  background-repeat:no-repeat!important;
}
.hero-art > img{
  display:block!important;
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
  opacity:1!important;
  visibility:visible!important;
  z-index:0!important;
  pointer-events:none!important;
}
.hero-art::before,.hero-art::after{content:none!important;display:none!important;}
.hero-copy{z-index:2!important;}
@media(max-width:900px){
  .hero-panel{grid-template-columns:1fr!important;grid-template-rows:220px auto!important;overflow:hidden!important;}
  .hero-art{display:block!important;order:-1!important;height:220px!important;min-height:220px!important;background-position:center center!important;}
  .hero-art > img{object-position:center center!important;}
}
@media(max-width:520px){
  .hero-art{height:210px!important;min-height:210px!important;}
}

/* 0100: kerge juhusliku sündmuse kaart - CSS only, no extra JS */
.forest-event-card{border:1px solid rgba(84,255,123,.24);background:linear-gradient(135deg,rgba(7,38,22,.92),rgba(6,19,13,.86));box-shadow:0 18px 50px rgba(0,0,0,.24);margin:18px 0;contain:layout paint}
.forest-event-card h2{margin:.25rem 0 .55rem;font-size:clamp(1.3rem,2vw,2rem)}
.forest-event-card p{max-width:760px;color:rgba(255,255,255,.86);line-height:1.55}
.forest-event-kicker{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .7rem;border-radius:999px;background:rgba(85,255,125,.12);border:1px solid rgba(85,255,125,.24);color:#7cff8b;font-weight:900;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em}
.forest-event-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.forest-event-actions .btn{min-width:180px;justify-content:center}
.forest-event-card small{display:block;margin-top:10px;color:rgba(255,255,255,.55)}
@media(max-width:650px){.forest-event-actions .btn{width:100%;min-width:0}.forest-event-card{margin:14px 0}}


/* 0105: hoone eriefektid - kerge CSS, ei lisa JS koormust */
.building-card.defense .building-title,.building-card.defense [data-production]{color:#9bd7ff}
.building-card.coins .building-title,.building-card.coins [data-production]{color:#ffe08a}
.effect-row b{letter-spacing:.01em}
.shop-item small{display:block;margin:.25rem 0;color:#9dff85;font-weight:800}


/* 0106 Mini kaart / piirkonnad - kerge CSS, ei lisa JS koormust */
.region-map{margin:16px 0;padding:18px}.region-map .section-head{margin-bottom:12px}.region-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.region-card{margin:0}.region-card button{width:100%;height:100%;text-align:left;border:1px solid rgba(100,255,126,.22);background:linear-gradient(180deg,rgba(8,35,21,.82),rgba(4,15,10,.9));color:#fff;border-radius:18px;padding:16px;display:grid;gap:5px;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,.035)}.region-card.active button{border-color:rgba(96,255,109,.72);box-shadow:0 0 22px rgba(50,255,83,.18),inset 0 0 0 1px rgba(96,255,109,.28);cursor:default}.region-icon{font-size:30px;line-height:1}.region-card b{font-size:20px}.region-card small{color:#80ff72;font-weight:900}.region-card em{font-style:normal;color:rgba(255,255,255,.72);font-size:13px;line-height:1.35}@media(max-width:760px){.region-grid{grid-template-columns:1fr}.region-map{padding:14px}.region-card button{padding:14px}}

/* 0107: mini kaart nähtav, kerge ja hoonete aretus */
.region-map{padding:14px!important;margin:14px 0!important}
.region-map .section-head h2{font-size:22px;margin:0}
.region-grid{gap:10px!important}
.region-card button{min-height:96px!important;will-change:auto!important;transform:none!important}
.breed-action{margin-top:10px!important}
.breed-action button{background:linear-gradient(135deg,rgba(110,255,120,.92),rgba(20,150,55,.92))!important;color:#041008!important}
.building-card.defense .building-image,.building-card.coins .building-image{background-position:center center!important}
@media(max-width:760px){.region-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}.region-card button{padding:10px!important;min-height:88px!important;text-align:center!important}.region-card em{display:none!important}.region-card b{font-size:15px!important}.region-icon{font-size:24px!important}}

/* 0109: light image overlay fix */
.building-card.defense .building-image,
.building-card.coins .building-image{
  position:relative!important;
  overflow:hidden!important;
  background-position:center center!important;
}
.building-card.defense .building-image::before,
.building-card.coins .building-image::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
  pointer-events:none!important;
  background:
    linear-gradient(90deg,rgba(0,16,9,.78) 0%,rgba(0,16,9,.42) 28%,rgba(0,16,9,.10) 58%,rgba(0,16,9,.34) 100%),
    linear-gradient(180deg,rgba(0,16,9,.48) 0%,rgba(0,16,9,.08) 38%,rgba(0,16,9,.80) 100%)!important;
}
.building-card.defense .building-image::after,
.building-card.coins .building-image::after{
  z-index:2!important;
  background:linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.18) 44%,rgba(2,15,9,.94))!important;
}
.building-card.defense .building-title,
.building-card.coins .building-title,
.building-card.defense .level-pill,
.building-card.coins .level-pill{
  z-index:4!important;
}
.building-card.defense .build-icon,
.building-card.coins .build-icon{
  background:rgba(0,10,8,.68)!important;
  border:1px solid rgba(255,255,255,.18)!important;
  box-shadow:0 0 18px rgba(0,0,0,.42)!important;
}


/* 0110: clean building badges + light PWA install/update */
/* Remove the ugly duplicate icon boxes over Valvetorn/Turg cards. The title stays clean and readable. */
.building-card.defense .build-icon,
.building-card.coins .build-icon{
  display:none!important;
}
.building-card.defense .building-title,
.building-card.coins .building-title{
  left:28px!important;
  gap:0!important;
  max-width:calc(100% - 56px)!important;
}
/* Keep the image area light: no extra files, no heavy effects. */
.building-card.defense .building-image,
.building-card.coins .building-image{
  background-size:cover!important;
  background-position:center!important;
}
/* Small install/update prompt, hidden until browser supports install prompt or update notice. */
.pwa-install-lite{
  position:fixed;
  left:50%;
  bottom:14px;
  transform:translateX(-50%);
  z-index:9999;
  display:none;
  align-items:center;
  gap:10px;
  max-width:min(92vw,420px);
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(103,255,105,.28);
  background:rgba(5,24,14,.92);
  box-shadow:0 14px 38px rgba(0,0,0,.35);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:#f2fff3;
  font-weight:900;
}
.pwa-install-lite.show{display:flex;}
.pwa-install-lite span{font-size:14px;line-height:1.25;}
.pwa-install-lite button{
  padding:8px 11px;
  border-radius:12px;
  white-space:nowrap;
  box-shadow:none;
}
.pwa-install-lite .pwa-close{background:rgba(255,255,255,.08);color:#fff;padding:7px 10px;}
@media(max-width:560px){
  .building-card.defense .building-title,
  .building-card.coins .building-title{left:22px!important;}
  .pwa-install-lite{bottom:76px;}
}


/* 0111: safer PWA prompt visual fix */
.pwa-install-lite-safe{left:50%!important;right:auto!important;bottom:14px!important;top:auto!important;transform:translateX(-50%)!important;display:none!important;align-items:center!important;gap:10px!important;max-width:min(92vw,430px)!important;padding:10px 12px!important;border-radius:16px!important;border:1px solid rgba(103,255,105,.30)!important;background:rgba(5,24,14,.94)!important;color:#f2fff3!important;font-weight:900!important;line-height:1.2!important;box-shadow:0 12px 34px rgba(0,0,0,.34)!important;z-index:9999!important;}
.pwa-install-lite-safe.show{display:flex!important;}
.pwa-install-lite-safe .pwa-lite-msg{font-size:14px!important;line-height:1.25!important;}
.pwa-install-lite-safe .pwa-action{border:0!important;background:linear-gradient(135deg,#65ff6f,#22b940)!important;color:#06130a!important;padding:8px 12px!important;border-radius:12px!important;font-weight:1000!important;white-space:nowrap!important;}
.pwa-install-lite-safe .pwa-close{border:0!important;background:rgba(255,255,255,.10)!important;color:#fff!important;padding:7px 10px!important;border-radius:12px!important;}
@media(max-width:560px){.pwa-install-lite-safe{bottom:82px!important;max-width:calc(100vw - 24px)!important}.pwa-install-lite-safe .pwa-lite-msg{font-size:13px!important}}


/* 0112: friendly PWA update toast */
.pwa-install-lite,.pwa-install-lite-safe{display:none!important;}
.pwa-friendly-toast{position:fixed!important;right:16px!important;bottom:16px!important;left:auto!important;top:auto!important;display:none!important;align-items:center!important;gap:10px!important;max-width:min(92vw,420px)!important;padding:10px 12px!important;border-radius:16px!important;border:1px solid rgba(103,255,105,.28)!important;background:rgba(5,24,14,.92)!important;color:#f2fff3!important;font-weight:900!important;line-height:1.2!important;box-shadow:0 12px 34px rgba(0,0,0,.30)!important;z-index:9999!important;backdrop-filter:blur(10px)!important;}
.pwa-friendly-toast.show{display:flex!important;}
.pwa-friendly-msg{font-size:14px!important;line-height:1.25!important;}
.pwa-friendly-action{border:0!important;background:linear-gradient(135deg,#65ff6f,#22b940)!important;color:#06130a!important;padding:8px 12px!important;border-radius:12px!important;font-weight:1000!important;white-space:nowrap!important;cursor:pointer!important;}
.pwa-friendly-close{border:0!important;background:rgba(255,255,255,.10)!important;color:#fff!important;padding:7px 10px!important;border-radius:12px!important;cursor:pointer!important;}
@media(max-width:560px){.pwa-friendly-toast{left:12px!important;right:12px!important;bottom:82px!important;max-width:none!important}.pwa-friendly-msg{font-size:13px!important}}

/* 0115 mobile background clarity fix - keeps pages light */
@media (max-width: 850px){
  body{
    background-color:#06110c !important;
    background-image:url('bg.webp') !important;
    background-position:center top !important;
    background-size:cover !important;
    background-repeat:no-repeat !important;
    background-attachment:scroll !important;
  }
  body:before{
    background:
      radial-gradient(circle at 50% 8%,rgba(103,255,105,.10),transparent 22%),
      linear-gradient(180deg,rgba(0,8,5,.72),rgba(0,12,8,.88) 46%,rgba(0,0,0,.94)) !important;
  }
  body:after{
    background:linear-gradient(90deg,rgba(0,0,0,.50),transparent 20%,transparent 80%,rgba(0,0,0,.50)) !important;
  }
  .resource-card,.building-card,.building-tile,.card,.info-strip,.life-panel{
    background-color:rgba(4,18,11,.78) !important;
  }
  .resource-card{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
}
@media (max-width: 520px){
  body{
    background-position:center top !important;
    background-size:auto 100vh !important;
  }
  body:before{
    background:linear-gradient(180deg,rgba(0,8,5,.78),rgba(0,10,7,.91) 45%,rgba(0,0,0,.96)) !important;
  }
}


/* 0117 mobile smooth bg css only light */
@media (max-width: 850px) {
  html {
    background:#06110c;
    min-height:100%;
    overscroll-behavior-y:none;
  }
  body {
    background:#06110c !important;
    min-height:100svh;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
  }
  body::before {
    content:"" !important;
    position:fixed !important;
    inset:-2px !important;
    z-index:-3 !important;
    pointer-events:none !important;
    background:
      radial-gradient(circle at 50% 16%, rgba(120,255,116,.12), transparent 24%),
      linear-gradient(180deg, rgba(0,0,0,.50), rgba(0,12,8,.78) 54%, rgba(0,0,0,.94)),
      url('bg.webp') center center / cover no-repeat !important;
    transform:translate3d(0,0,0) scale(1.01);
    backface-visibility:hidden;
    will-change:transform;
  }
  body::after {
    content:"" !important;
    position:fixed !important;
    inset:0 !important;
    z-index:-2 !important;
    pointer-events:none !important;
    background:linear-gradient(90deg,rgba(0,0,0,.55),transparent 20%,transparent 80%,rgba(0,0,0,.55)) !important;
  }
  .wrap,
  .card,
  .hero-panel,
  .resource-card,
  .building-card,
  .info-strip {
    transform:translateZ(0);
    backface-visibility:hidden;
  }
}
/* === 0118 MOBILE MENU COMPACT SPEED FIX ===
   CSS-only: fixes stretched drawer rows on mobile without extra JS/API/assets. */
@media (max-width: 900px){
  .pro-mobile-menu{
    top:calc(88px + env(safe-area-inset-top))!important;
    bottom:calc(10px + env(safe-area-inset-bottom))!important;
    max-height:calc(100dvh - 98px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  }
  .pro-menu-links{
    align-content:start!important;
    justify-content:stretch!important;
    grid-auto-rows:minmax(54px,auto)!important;
    gap:9px!important;
    padding:12px 12px 18px!important;
  }
  .pro-menu-links a,
  .pro-menu-links a.btn{
    height:auto!important;
    min-height:54px!important;
    max-height:none!important;
    flex:0 0 auto!important;
    align-self:start!important;
    padding:12px 14px!important;
    border-radius:17px!important;
    line-height:1.15!important;
    white-space:normal!important;
    overflow:hidden!important;
  }
  .pro-menu-links a:empty{display:none!important;}
  .pro-menu-head{padding:16px 74px 12px 16px!important;min-height:70px!important;}
  .pro-menu-head b{font-size:22px!important;}
  .pro-menu-close{width:48px!important;height:48px!important;}
}
@media (max-width: 420px){
  .pro-mobile-menu{left:10px!important;right:10px!important;border-radius:24px!important;}
  .pro-menu-links{gap:8px!important;padding:10px 10px 16px!important;}
  .pro-menu-links a,.pro-menu-links a.btn{min-height:50px!important;font-size:15.5px!important;padding:11px 13px!important;}
}


/* 0120 passive strategy: kerge CSS-only UI */
.strategy-map{margin-top:14px}
.strategy-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.strategy-card{margin:0}.strategy-card button{width:100%;height:100%;min-height:112px;text-align:left;border:1px solid rgba(88,255,113,.24);border-radius:20px;background:rgba(4,28,16,.62);color:#fff;padding:14px 16px;display:flex;flex-direction:column;gap:5px;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03)}
.strategy-card.active button{border-color:rgba(83,255,105,.72);background:linear-gradient(135deg,rgba(30,122,43,.72),rgba(3,31,17,.74));box-shadow:0 0 22px rgba(83,255,105,.12),inset 0 0 0 1px rgba(255,255,255,.05)}
.strategy-card button:disabled{cursor:default}.strategy-icon{font-size:1.35rem}.strategy-card b{font-size:1.05rem}.strategy-card small{color:#68ff78;font-weight:800}.strategy-card em{font-style:normal;color:rgba(255,255,255,.72);font-size:.86rem;line-height:1.25}
@media(max-width:720px){.strategy-grid{grid-template-columns:1fr}.strategy-card button{min-height:86px;padding:12px 14px}.strategy-card em{font-size:.82rem}}


/* 0121 daily streak light */
.daily-streak-card{display:flex;align-items:center;justify-content:space-between;gap:18px;overflow:hidden}
.daily-track{display:flex;gap:7px;margin:12px 0 10px;flex-wrap:wrap}
.daily-track span{width:30px;height:30px;border-radius:999px;display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(112,255,123,.24);font-weight:900;color:#dfffe3}
.daily-track span.done{background:rgba(70,220,95,.24);border-color:rgba(112,255,123,.5)}
.daily-track span.now{background:linear-gradient(135deg,#43ff66,#f7d45a);color:#08240f;box-shadow:0 0 18px rgba(83,255,112,.35)}
.daily-streak-card small{display:block;color:rgba(255,255,255,.75);font-weight:800;margin-top:4px}
@media(max-width:720px){.daily-streak-card{display:block}.daily-streak-card form{margin-top:14px}.daily-track span{width:28px;height:28px}}

/* 0122 rare minimap regions: CSS-only, no extra requests */
.region-card.rare button{
  border-color: rgba(255, 214, 102, .55);
  box-shadow: inset 0 0 0 1px rgba(255,214,102,.12);
}
.region-card.rare .region-icon{filter: drop-shadow(0 0 8px rgba(255,214,102,.28));}
.rare-region-note{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  margin-top:.25rem;
  padding:.35rem .55rem;
  border-radius:999px;
  background:rgba(255,214,102,.12);
  color:#ffe6a3;
  font-size:.82rem;
}
@media(max-width:700px){.rare-region-note{font-size:.78rem;line-height:1.25}}

/* 0123 visual feedback: CSS-only, no JS/API/images */
@keyframes meSoftPulse0123{
  0%,100%{transform:translateZ(0) scale(1);filter:brightness(1)}
  50%{transform:translateZ(0) scale(1.018);filter:brightness(1.08)}
}
@keyframes meTinyFloat0123{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-2px)}
}
.resource-card b,
.resource-card strong,
.res-card b,
.res-card strong,
.stat-card b,
.stat-card strong,
[data-resource-value]{
  display:inline-block;
  animation:meSoftPulse0123 2.8s ease-in-out infinite;
  will-change:transform;
}
.btn,
button,
.menu a,
.pro-menu-links a,
.strategy-card button,
.region-card button,
.daily-streak-card button{
  transition:transform .16s ease, box-shadow .16s ease, filter .16s ease, border-color .16s ease;
}
.btn:hover,
button:hover,
.menu a:hover,
.pro-menu-links a:hover,
.strategy-card button:hover,
.region-card button:hover,
.daily-streak-card button:hover{
  transform:translateY(-1px);
  filter:brightness(1.06);
  box-shadow:0 0 18px rgba(82,255,107,.14), inset 0 0 0 1px rgba(255,255,255,.04);
}
.btn:active,
button:active,
.menu a:active,
.pro-menu-links a:active,
.strategy-card button:active,
.region-card button:active,
.daily-streak-card button:active{
  transform:translateY(0) scale(.99);
}
.card .emoji,
.region-icon,
.strategy-icon,
.daily-track span.now{
  animation:meTinyFloat0123 3.6s ease-in-out infinite;
  will-change:transform;
}
@media (prefers-reduced-motion: reduce){
  .resource-card b,.resource-card strong,.res-card b,.res-card strong,.stat-card b,.stat-card strong,[data-resource-value],.card .emoji,.region-icon,.strategy-icon,.daily-track span.now{
    animation:none!important;
  }
  .btn,button,.menu a,.pro-menu-links a,.strategy-card button,.region-card button,.daily-streak-card button{
    transition:none!important;
  }
}
@media(max-width:720px){
  .btn:hover,button:hover,.menu a:hover,.pro-menu-links a:hover,.strategy-card button:hover,.region-card button:hover,.daily-streak-card button:hover{
    transform:none;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.035);
  }
}


/* 0125: kerge crafting UI */
.crafting-page{overflow:hidden}.craft-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.craft-card{display:grid;gap:8px;padding:16px;border-radius:18px;background:rgba(5,20,11,.72);border:1px solid rgba(154,255,111,.18);box-shadow:0 10px 28px rgba(0,0,0,.22)}.craft-card h3{margin:0;font-size:20px}.craft-card p{margin:0;color:#dcefc7}.craft-card small{color:#aeea82;font-weight:800}.craft-card.disabled{opacity:.58}.craft-card.disabled button{cursor:not-allowed}.craft-icon{font-size:34px;line-height:1}@media(max-width:720px){.craft-grid{grid-template-columns:1fr}.craft-card{padding:14px}}


/* 0126 homepage mobile layout polish - CSS only, no extra requests */
.home-hero .hero-copy{display:flex;flex-direction:column;justify-content:center;gap:12px}
.home-kicker{display:inline-flex;align-items:center;width:max-content;max-width:100%;padding:6px 10px;border-radius:999px;background:rgba(143,224,49,.12);border:1px solid rgba(143,224,49,.22);color:#dfffb0;font-weight:900;font-size:13px;letter-spacing:.02em}
.home-actions{display:flex;flex-wrap:wrap;gap:9px;align-items:center}.home-actions .btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.home-tick{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 12px;border-radius:14px;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.08);width:max-content;max-width:100%}.home-tick small{color:#cfe4b8;font-weight:800}.home-tick b{color:#fff;font-size:18px}.home-tick em{font-style:normal;color:#9fdc75;font-size:13px}.guest-points{display:flex;gap:8px;flex-wrap:wrap}.guest-points span{padding:8px 10px;border-radius:12px;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.08);font-weight:850;color:#f0ffd7}.guest-start-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:14px 0 18px}.guest-start-card{min-height:86px;padding:14px}.guest-start-card b{display:block;color:#fff;font-size:16px}.guest-start-card span{display:block;margin-top:5px;color:#cfe4b8;font-size:14px}
@media(max-width:760px){.home-hero.hero-panel{grid-template-columns:1fr!important;border-radius:18px}.home-hero .hero-copy{grid-column:1;order:2;min-height:auto!important;padding:18px 16px!important;text-align:left}.home-hero .hero-art{grid-column:1;order:1;height:185px!important;min-height:185px!important}.home-hero .hero-art img{width:100%;height:100%;object-fit:cover;display:block}.home-hero h1{font-size:clamp(28px,9vw,42px);line-height:1.02;margin:2px 0}.home-hero p{font-size:15px;line-height:1.45;margin:0}.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.logged-home .home-actions{grid-template-columns:1fr}.home-actions .btn{width:100%;padding:11px 12px}.home-tick{width:100%;justify-content:space-between;gap:6px}.guest-points{display:grid;grid-template-columns:1fr;gap:7px}.guest-start-grid{grid-template-columns:1fr;gap:9px;margin-top:10px}.guest-start-card{min-height:auto;padding:12px 14px}.resource-grid{margin-top:12px}.section-head{gap:6px}}
@media(min-width:761px){.home-hero .hero-copy{padding-top:28px;padding-bottom:28px}.guest-home .hero-copy{padding-right:22px}}

/* 0127 Android mobile background visibility fix - CSS only, no JS/API/images */
@media (max-width: 900px){
  html{
    min-height:100%;
    background:#06110c url('bg.webp') center top/cover no-repeat!important;
  }
  body{
    min-height:100%;
    background:#06110c url('bg.webp') center top/cover no-repeat!important;
    background-attachment:scroll!important;
    background-size:cover!important;
    background-position:center top!important;
  }
  body:before{
    background:
      radial-gradient(circle at 48% 18%,rgba(120,255,116,.12),transparent 24%),
      linear-gradient(180deg,rgba(0,0,0,.50),rgba(0,12,8,.78) 56%,rgba(0,0,0,.92))!important;
  }
}
/* 0128 uniform mobile background light */
@media (max-width: 820px){
  html{
    background:#06110c url('bg.webp') center top / cover no-repeat !important;
    min-height:100%;
  }
  body{
    background:#06110c !important;
    background-image:none !important;
    min-height:100vh;
    overflow-x:hidden;
  }
  body::before{
    content:"" !important;
    position:fixed !important;
    inset:0 !important;
    z-index:-2 !important;
    pointer-events:none !important;
    background:
      linear-gradient(180deg,rgba(0,0,0,.52),rgba(0,12,8,.72) 50%,rgba(0,0,0,.88)),
      url('bg.webp') center top / cover no-repeat !important;
    transform:translateZ(0);
    will-change:auto;
  }
  body::after{
    content:"" !important;
    position:fixed !important;
    inset:0 !important;
    z-index:-1 !important;
    pointer-events:none !important;
    background:linear-gradient(90deg,rgba(0,0,0,.28),transparent 28%,transparent 72%,rgba(0,0,0,.28)) !important;
  }
}


/* 0129 final android pwa background layer */
@media (max-width: 900px){
  html{
    min-height:100%;
    background:#06110c !important;
  }
  body{
    min-height:100vh;
    background:#06110c !important;
    background-image:none !important;
    overflow-x:hidden;
    isolation:isolate;
  }
  body::before{
    content:"" !important;
    position:fixed !important;
    inset:-1px !important;
    z-index:0 !important;
    pointer-events:none !important;
    background:
      linear-gradient(180deg,rgba(0,0,0,.50),rgba(0,15,8,.68) 52%,rgba(0,0,0,.90)),
      url('bg.webp') center top / cover no-repeat !important;
    transform:translate3d(0,0,0);
    opacity:1 !important;
  }
  body::after{
    content:"" !important;
    position:fixed !important;
    inset:0 !important;
    z-index:0 !important;
    pointer-events:none !important;
    background:radial-gradient(circle at 50% 12%,rgba(120,255,116,.10),transparent 28%) !important;
  }
  .wrap,.app,.page,.card,.topbar,.mobile-menu,.hero-panel,main,header,nav,footer{
    position:relative;
    z-index:1;
  }
}



/* 0130: 6 minuti hoone uuenduse töötekst — CSS-only, kerge */
.upgrade-status{min-height:1.35em;margin:.45rem 0 0;color:#7dff8f;font-weight:900;font-size:.92rem;text-shadow:0 0 12px rgba(80,255,110,.25)}
.upgrade-btn:disabled{opacity:.55;filter:saturate(.75);cursor:not-allowed}
.building-card:has([data-upgrade-until]) .building-image{box-shadow:inset 0 0 0 1px rgba(96,255,120,.35),0 0 24px rgba(80,255,120,.12)}
@media(max-width:760px){.upgrade-status{font-size:.88rem}.upgrade-row{gap:.5rem}}

/* 0131 bank loan status */
.bank-stat.danger{border-color:rgba(255,86,86,.55)!important;box-shadow:0 0 0 1px rgba(255,86,86,.18),0 0 22px rgba(255,40,40,.14)}
.bank-stat small{display:block;margin-top:4px;color:rgba(255,255,255,.7);font-weight:800}

/* 0135 dynamic bank breakdown UI - light */
.bank-breakdown{display:grid;gap:8px;margin:14px 0 18px;padding:14px;border-radius:18px;background:rgba(0,0,0,.26);border:1px solid rgba(255,255,255,.08)}
.bank-breakdown>b{color:#d8ffe7;margin-bottom:2px}.bank-breakdown div{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:7px 0;border-top:1px solid rgba(255,255,255,.06)}
.bank-breakdown span{color:#b8d8c4}.bank-breakdown strong{color:#fff}.bank-form button[disabled]{opacity:.55;filter:grayscale(1);cursor:not-allowed}
@media(max-width:760px){.bank-breakdown div{font-size:14px}.bank-breakdown{padding:12px}}

/* 0141 social village visit - light */
.village-visit-page{overflow:hidden}.visit-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:12px;margin:16px 0}.visit-stat-grid>div,.visit-building-card{background:rgba(2,20,12,.55);border:1px solid rgba(90,255,120,.18);border-radius:18px;padding:16px}.visit-stat-grid span{display:block;color:rgba(232,255,237,.72);font-size:.9rem}.visit-stat-grid b{display:block;font-size:1.35rem;color:#70ff7a;margin-top:4px}.visit-actions{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 22px}.visit-actions button[disabled]{opacity:.65;cursor:not-allowed}.visit-buildings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.visit-building-card b{display:block;font-size:1.08rem}.visit-building-card span{color:#70ff7a}.profile-social-links{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}@media(max-width:700px){.visit-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.visit-actions .btn{width:100%}.visit-buildings-grid{grid-template-columns:1fr}.village-visit-page .section-head{gap:10px}.village-visit-page .section-head .btn{width:100%;justify-content:center}}

/* 0142 social village polish + automatic visit trace + livelier shadow realm (light CSS-only) */
.visit-polished{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(6,30,17,.92),rgba(3,14,10,.86));}
.visit-polished:before{content:"";position:absolute;inset:-90px -120px auto auto;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(94,255,103,.14),transparent 68%);pointer-events:none;filter:blur(4px)}
.visit-hero{position:relative;z-index:1;display:flex;justify-content:space-between;gap:22px;align-items:flex-start;margin-bottom:18px;padding:18px;border-radius:24px;background:linear-gradient(135deg,rgba(103,255,105,.10),rgba(0,0,0,.10));border:1px solid rgba(103,255,105,.18)}
.visit-kicker{display:inline-flex;margin-bottom:8px;color:#70ff7a;font-weight:950;text-transform:uppercase;font-size:.78rem;letter-spacing:.08em}
.visit-hero h1{margin:.1rem 0 .5rem;font-size:clamp(30px,4vw,52px);line-height:1.02}.visit-hero p{max-width:720px;color:rgba(232,255,237,.78);margin:0;line-height:1.55}.visit-hero .btn{white-space:nowrap}
.visit-mini-note{position:relative;z-index:1;margin:0 0 14px;padding:10px 13px;border-radius:15px;background:rgba(103,255,105,.10);border:1px solid rgba(103,255,105,.22);color:#caffcf;font-weight:850}
.visit-polished .visit-stat-grid{position:relative;z-index:1;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.visit-polished .visit-stat-grid>div{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(0,0,0,.20));box-shadow:inset 0 0 0 1px rgba(255,255,255,.025)}
.visit-auto-trace{display:inline-flex;align-items:center;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.10);color:rgba(232,255,237,.80);font-weight:850}.visit-section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:20px 0 12px}.visit-section-title h2{margin:0}.visit-section-title span{color:rgba(232,255,237,.60)}
.visit-polished .visit-buildings-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px}.visit-polished .visit-building-card{display:flex;align-items:center;gap:12px;min-height:78px;background:linear-gradient(135deg,rgba(7,35,20,.78),rgba(0,0,0,.28));border-color:rgba(103,255,105,.20)}.visit-building-emoji{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:rgba(103,255,105,.10);border:1px solid rgba(103,255,105,.20);font-size:24px;flex:0 0 44px}.visit-building-card small{display:block;color:#70ff7a;font-weight:950;margin-top:2px}
.shadow-realm-0142{position:relative;overflow:hidden;background:radial-gradient(circle at 50% 0%,rgba(120,83,255,.20),transparent 35%),linear-gradient(135deg,rgba(10,8,18,.96),rgba(3,8,8,.92));border-color:rgba(155,124,255,.35);box-shadow:0 0 42px rgba(100,76,255,.16),var(--shadow)}.shadow-realm-0142:before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent,rgba(255,255,255,.04),transparent);pointer-events:none}.shadow-hero{position:relative;z-index:1;padding:24px;border-radius:24px;background:linear-gradient(135deg,rgba(120,83,255,.13),rgba(0,0,0,.16));border:1px solid rgba(155,124,255,.22);margin-bottom:16px}.shadow-hero span{display:inline-block;color:#c9b8ff;font-weight:950;text-transform:uppercase;font-size:.78rem;letter-spacing:.12em;margin-bottom:8px}.shadow-hero h1{font-size:clamp(36px,5vw,64px);margin:0 0 8px;text-shadow:0 0 24px rgba(160,130,255,.35)}.shadow-hero p{max-width:760px;color:rgba(242,237,255,.78);line-height:1.55}.shadow-realm-0142 .shadow-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin:16px 0}.shadow-realm-0142 .shadow-stats>div{padding:16px;border-radius:18px;background:rgba(0,0,0,.22);border:1px solid rgba(155,124,255,.18)}.shadow-realm-0142 .shadow-stats span{display:block;color:rgba(242,237,255,.66);font-size:.9rem}.shadow-realm-0142 .shadow-stats b{display:block;color:#d8ccff;font-size:1.45rem;margin-top:4px}.shadow-threats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:14px 0}.shadow-threats>div{padding:13px 14px;border-radius:16px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);font-weight:850}.shadow-actions{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}.shadow-fight{background:linear-gradient(135deg,#d7c2ff,#7e55ff)!important;color:#10071e!important}
@media(max-width:700px){.visit-hero{display:block;padding:16px}.visit-hero .btn{margin-top:12px;width:100%;justify-content:center}.visit-polished .visit-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.visit-section-title{display:block}.visit-auto-trace{width:100%;box-sizing:border-box;justify-content:center}.shadow-actions .btn{width:100%;justify-content:center}}


/* 0143 Surnuriik: rohkem tegevusi, aga CSS-only ja kerge */
.shadow-realm-0143 .shadow-actions-0143{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:18px 0}
.shadow-realm-0143 .shadow-actions-0143 .btn{width:100%;justify-content:center;text-align:center;min-height:48px}
.shadow-realm-0143 .shadow-actions-0143 .danger{background:linear-gradient(135deg,rgba(255,89,89,.86),rgba(92,12,28,.86));border-color:rgba(255,140,140,.45);color:#fff}
.shadow-choice-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:14px 0}
.shadow-choice-grid div{padding:14px;border-radius:18px;background:rgba(0,0,0,.22);border:1px solid rgba(181,116,255,.18)}
.shadow-choice-grid b{display:block;color:#d8b6ff;margin-bottom:4px}.shadow-choice-grid span{display:block;color:rgba(255,255,255,.72);font-size:13px;line-height:1.35}
@media(max-width:760px){.shadow-realm-0143 .shadow-actions-0143{grid-template-columns:1fr}.shadow-choice-grid{grid-template-columns:1fr}.shadow-choice-grid div{padding:12px}}

/* 0144 uniform icon fix: avoids Windows/Android emoji rendering differences */
.me-icon,.me-inline{display:inline-grid;place-items:center;vertical-align:middle;flex:0 0 auto;font-weight:900;line-height:1;color:#dfffe7;text-shadow:0 0 10px rgba(92,255,111,.45);font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif;}
.me-icon{width:46px;height:46px;border-radius:16px;background:linear-gradient(145deg,rgba(30,255,89,.18),rgba(0,0,0,.34));border:1px solid rgba(104,255,125,.38);box-shadow:inset 0 0 20px rgba(255,255,255,.04),0 0 18px rgba(67,255,89,.14);font-size:20px;}
.me-inline{width:1.35em;height:1.35em;border-radius:.45em;background:rgba(39,255,83,.14);border:1px solid rgba(107,255,130,.32);font-size:.8em;margin-right:.35em;}
.me-icon-shop::before{content:'Pood';font-size:12px;letter-spacing:.02em}.me-icon-wood::before,.me-inline-wood::before{content:'P'}.me-icon-stone::before{content:'K'}.me-icon-food::before{content:'T'}.me-icon-coin::before,.me-inline-coin::before{content:'€'}.me-icon-axe::before{content:'K'}.me-icon-torch::before{content:'L'}.me-icon-seed::before{content:'S'}.me-icon-brick::before{content:'E'}.me-icon-spark::before{content:'★'}
.me-inline-shadow::before{content:'S'}.me-inline-wolf::before{content:'H'}.me-inline-web::before{content:'V'}.me-inline-fog::before{content:'U'}.me-inline-moon::before{content:'R'}.me-inline-sword::before{content:'X'}
.icon-title{display:flex;align-items:center;gap:12px}.shop-icon .me-icon,.craft-icon .me-icon{width:54px;height:54px;border-radius:18px}.shadow-actions .btn .me-inline{margin-right:8px}
@media(max-width:720px){.me-icon{width:40px;height:40px;border-radius:14px}.shop-icon .me-icon,.craft-icon .me-icon{width:46px;height:46px}.icon-title{gap:9px}}


/* 0145 real CSS icons: no letters, no emoji-font dependency */
.me-icon::before,.me-icon::after,.me-inline::before,.me-inline::after{content:"";display:block;position:absolute;box-sizing:border-box}
.me-icon,.me-inline{position:relative;overflow:hidden;color:transparent;text-shadow:none}
.me-icon-shop::before{width:26px;height:18px;left:11px;top:17px;border:3px solid #d7ffd8;border-top:none;border-radius:0 0 7px 7px;box-shadow:0 0 12px rgba(111,255,139,.35)}
.me-icon-shop::after{width:24px;height:10px;left:12px;top:10px;border-radius:7px;background:linear-gradient(90deg,#6dff7c 0 30%,#ffe077 30% 55%,#6dff7c 55% 100%)}
.me-icon-wood::before,.me-inline-wood::before{width:28px;height:10px;border-radius:9px;background:linear-gradient(90deg,#8a4d1e,#d48835);left:9px;top:18px;box-shadow:0 9px 0 #9b5a24,0 -9px 0 #b86b2c,0 0 14px rgba(255,164,75,.25)}
.me-icon-wood::after,.me-inline-wood::after{width:6px;height:6px;border:2px solid rgba(255,230,180,.85);border-radius:50%;left:13px;top:20px;box-shadow:0 9px 0 -1px rgba(255,230,180,.75),0 -9px 0 -1px rgba(255,230,180,.75)}
.me-icon-stone::before{width:28px;height:24px;left:9px;top:11px;background:linear-gradient(145deg,#eef4fb,#8f9fac);clip-path:polygon(18% 30%,45% 8%,76% 18%,92% 52%,66% 88%,26% 80%,5% 52%);box-shadow:0 0 14px rgba(210,240,255,.25)}
.me-icon-stone::after{width:12px;height:5px;left:17px;top:19px;background:rgba(255,255,255,.45);border-radius:6px;transform:rotate(-18deg)}
.me-icon-food::before{width:13px;height:28px;left:17px;top:9px;border-radius:9px;background:linear-gradient(#ffe76c,#daa52b);box-shadow:inset 0 0 0 2px rgba(255,255,255,.18),0 0 14px rgba(255,220,70,.30)}
.me-icon-food::after{width:5px;height:5px;left:21px;top:12px;background:#fff09a;border-radius:50%;box-shadow:0 6px 0 #fff09a,0 12px 0 #fff09a,0 18px 0 #fff09a,7px 3px 0 #d89621,7px 9px 0 #d89621,7px 15px 0 #d89621,-7px 3px 0 #d89621,-7px 9px 0 #d89621,-7px 15px 0 #d89621}
.me-icon-coin::before,.me-inline-coin::before{width:27px;height:27px;left:9px;top:9px;border-radius:50%;background:radial-gradient(circle at 50% 45%,#ffd44a 0 42%,#b56b15 44% 62%,#6b255b 64% 100%);box-shadow:0 0 16px rgba(255,195,54,.35)}
.me-icon-coin::after,.me-inline-coin::after{width:13px;height:13px;left:16px;top:16px;border-radius:50%;border:3px solid rgba(255,255,255,.5)}
.me-icon-axe::before{width:7px;height:30px;left:23px;top:10px;border-radius:4px;background:linear-gradient(#a76128,#5a2f12);transform:rotate(38deg);transform-origin:center}
.me-icon-axe::after{width:19px;height:17px;left:12px;top:12px;background:linear-gradient(145deg,#eff7ff,#9da8b2);clip-path:polygon(0 20%,65% 0,100% 45%,65% 100%,0 80%,32% 50%);box-shadow:0 0 12px rgba(230,245,255,.25)}
.me-icon-torch::before{width:8px;height:24px;left:20px;top:17px;border-radius:5px;background:#7b4a1e}.me-icon-torch::after{width:20px;height:22px;left:14px;top:6px;background:radial-gradient(circle,#fff28a 0 20%,#ffb12e 45%,#ff5a22 70%,transparent 72%);clip-path:polygon(50% 0,74% 35%,64% 75%,50% 100%,36% 75%,26% 35%)}
.me-icon-seed::before{width:24px;height:30px;left:12px;top:8px;border-radius:50% 50% 45% 45%;background:linear-gradient(145deg,#b8ff78,#2fa13f);clip-path:ellipse(42% 50% at 50% 50%)}.me-icon-seed::after{width:3px;height:22px;left:23px;top:14px;background:rgba(255,255,255,.45);border-radius:3px;transform:rotate(18deg)}
.me-icon-brick::before{width:30px;height:22px;left:8px;top:13px;border-radius:5px;background:linear-gradient(#d18a3b,#8b4b1f);box-shadow:inset 0 -3px 0 rgba(0,0,0,.2)}.me-icon-brick::after{width:28px;height:2px;left:9px;top:23px;background:rgba(0,0,0,.25);box-shadow:9px -6px 0 rgba(0,0,0,.18),-8px 6px 0 rgba(0,0,0,.18)}
.me-icon-spark::before{width:28px;height:28px;left:9px;top:9px;background:#d6ff6d;clip-path:polygon(50% 0,61% 36%,100% 50%,61% 64%,50% 100%,39% 64%,0 50%,39% 36%);box-shadow:0 0 16px rgba(214,255,109,.38)}
.me-inline{color:transparent;width:1.45em;height:1.45em}.me-inline::before{inset:.28em;border-radius:50%;background:rgba(117,255,143,.55);box-shadow:0 0 8px rgba(117,255,143,.25)}
.me-inline-wolf::before{border-radius:35% 35% 50% 50%;clip-path:polygon(8% 22%,30% 10%,50% 24%,70% 10%,92% 22%,78% 82%,22% 82%);background:#d7dbe0}.me-inline-web::before{background:repeating-conic-gradient(from 0deg,rgba(220,255,235,.8) 0 3deg,transparent 3deg 30deg);border:1px solid rgba(220,255,235,.7)}.me-inline-fog::before{inset:.45em .15em;border-radius:999px;background:#dff;box-shadow:0 .36em 0 #dff,0 -.36em 0 #dff}.me-inline-moon::before{background:#d9d1ff;box-shadow:.28em 0 0 #07180e}.me-inline-sword::before{width:.18em;height:1.05em;left:.62em;top:.15em;border-radius:.2em;background:#eef;transform:rotate(45deg);box-shadow:0 0 0 .05em rgba(255,255,255,.2)}
.shop-icon{background:rgba(124,255,145,.08)}


/* 0149 Kes on kus PRO mobile design - CSS only */
.online-mode-card{background:linear-gradient(180deg,rgba(5,24,13,.88),rgba(2,12,7,.78))!important;border-color:rgba(35,255,154,.16)!important;box-shadow:0 18px 55px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.05)!important}
.online-list{gap:14px!important}
.online-card.online-card-0148{position:relative;overflow:hidden;border-radius:26px!important;padding:16px!important;background:radial-gradient(circle at 8% 0%,rgba(35,255,154,.16),transparent 30%),linear-gradient(135deg,rgba(8,39,20,.92),rgba(1,12,7,.78))!important;border:1px solid rgba(35,255,154,.18)!important;box-shadow:0 16px 42px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.06)!important}
.online-card.online-card-0148:before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(#31ff84,#166c42);opacity:.9}
.online-card.online-card-0148.is-flagged:before{background:linear-gradient(#ff566b,#ffb44d)}
.online-card.online-card-0148:hover{transform:translateY(-1px);border-color:rgba(35,255,154,.32)!important}
.online-avatar{width:56px!important;height:56px!important;border-radius:20px!important;background:linear-gradient(145deg,rgba(31,255,139,.25),rgba(7,75,39,.55))!important;border:1px solid rgba(78,255,157,.28)!important;box-shadow:0 0 26px rgba(35,255,154,.16), inset 0 1px 0 rgba(255,255,255,.12)!important}
.online-user-name b{font-size:20px!important;line-height:1.1}.online-user-name span{padding:3px 7px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07)}
.online-user-meta span{background:rgba(0,0,0,.22)!important;border-color:rgba(255,255,255,.08)!important}.online-motto{font-size:13px!important;border-radius:16px!important;background:linear-gradient(135deg,rgba(35,255,154,.14),rgba(255,255,255,.04))!important;border-color:rgba(35,255,154,.18)!important}.online-motto b{font-size:11px!important;color:#65ff9e!important}
.online-info-box,.online-recent{border-radius:18px!important;background:rgba(0,0,0,.22)!important}.inspect-btn{display:inline-flex;margin-top:10px;text-decoration:none;border-radius:14px;padding:9px 12px;background:linear-gradient(135deg,#70ff9d,#1fad62);color:#04170d!important;font-weight:950;box-shadow:0 8px 20px rgba(35,255,154,.14)}
@media(max-width:760px){
 .online-mode-card{padding:10px!important;border-radius:22px!important}
 .online-list{display:grid!important;grid-template-columns:1fr!important;gap:12px!important}
 .online-card.online-card-0148{display:grid!important;grid-template-columns:1fr!important;gap:12px!important;padding:13px!important;border-radius:22px!important}
 .online-user-main{align-items:flex-start!important;gap:10px!important}
 .online-avatar{width:48px!important;height:48px!important;flex-basis:48px!important;border-radius:17px!important;font-size:18px!important}
 .online-user-name{gap:6px!important}.online-user-name b{font-size:18px!important}.online-user-name span{font-size:11px!important}
 .online-user-meta{gap:5px!important;margin-top:7px!important}.online-user-meta span,.flag-pill{font-size:11px!important;padding:5px 7px!important}.perf-badge{width:100%;justify-content:center;margin-top:7px!important;border-radius:14px!important}
 .online-motto{margin-top:8px!important;font-size:12px!important;padding:8px 9px!important}.online-motto:before{content:'✦ ';color:#61ff9a;font-weight:900}
 .online-info-grid{grid-template-columns:1fr 1fr!important;gap:8px!important}.online-info-box{padding:9px!important}.online-info-box:nth-child(3){grid-column:1/-1}.online-info-box small,.online-recent>small{font-size:10px!important}.online-info-box strong{font-size:13px!important}.online-info-box code{font-size:12px!important}
 .online-recent{padding:9px!important}.online-recent li{display:block!important;padding:7px!important}.online-recent time{display:block;margin-top:3px}.inspect-btn{width:100%;justify-content:center;min-height:42px}.traffic-box{font-size:12px!important}
}
@media(max-width:420px){.online-info-grid{grid-template-columns:1fr!important}.online-info-box:nth-child(3){grid-column:auto}.mode-section-head h2{font-size:22px}.mode-count{width:100%;text-align:center}}
@media(prefers-reduced-motion:reduce){.online-card.online-card-0148{transition:none!important}.online-card.online-card-0148:hover{transform:none!important}}


/* 0151: Ultra strong mobile notices + Surnuriigi action safety polish (CSS-only) */
.notice, .card.notice{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(103,255,105,.34);
  background:linear-gradient(135deg,rgba(5,28,15,.94),rgba(2,10,7,.90));
  box-shadow:0 18px 52px rgba(0,0,0,.42), inset 0 0 0 1px rgba(255,255,255,.04);
}
.notice:before, .card.notice:before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(180deg,#68ff6a,#21a83f);
  box-shadow:0 0 20px rgba(103,255,105,.55);
}
.notice.err, .card.notice.err{
  border-color:rgba(255,98,98,.45)!important;
  background:linear-gradient(135deg,rgba(44,10,12,.94),rgba(5,10,8,.91));
  color:#ffe8e8;
}
.notice.err:before, .card.notice.err:before{
  background:linear-gradient(180deg,#ff6262,#b91616);
  box-shadow:0 0 20px rgba(255,80,80,.5);
}
.shadow-actions-0143 .btn{min-height:52px}
@media(max-width:700px){
  .notice, .card.notice{
    margin:10px 0!important;
    padding:14px 14px 14px 18px!important;
    border-radius:18px!important;
    font-size:14px!important;
    line-height:1.35!important;
  }
  .notice p, .card.notice p{margin:4px 0!important}
  .toast.show{
    left:12px!important; right:12px!important; bottom:82px!important; max-width:none!important;
    border-radius:18px!important; padding:13px 15px!important;
    background:rgba(4,22,12,.96)!important; border:1px solid rgba(103,255,105,.38)!important;
  }
}


/* 0152: update page alignment + modern notice design */
.notice{
  position:relative;
  overflow:hidden;
  border-radius:22px !important;
  padding:16px 18px !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(91,255,104,.12), transparent 34%),
    linear-gradient(180deg, rgba(10,42,24,.82), rgba(3,17,11,.74)) !important;
  border:1px solid rgba(103,255,116,.34) !important;
  box-shadow:0 18px 48px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08) !important;
}
.notice.err{
  background:
    radial-gradient(circle at 12% 0%, rgba(255,94,94,.14), transparent 34%),
    linear-gradient(180deg, rgba(43,13,17,.86), rgba(12,5,8,.74)) !important;
  border-color:rgba(255,105,105,.52) !important;
  color:#ffe6e6 !important;
}
.notice.ok{
  background:
    radial-gradient(circle at 12% 0%, rgba(92,255,101,.18), transparent 34%),
    linear-gradient(180deg, rgba(9,55,26,.86), rgba(3,22,12,.76)) !important;
}
.notice p{margin:7px 0;line-height:1.45}
.notice p:first-child{margin-top:0}.notice p:last-child{margin-bottom:0}
.update-body{min-height:100vh;overflow-x:hidden}
.update-body .wrap{
  width:min(1320px,94vw) !important;
  max-width:none !important;
  margin:0 auto !important;
  padding:22px 0 44px !important;
}
.update-body .card{
  width:100% !important;
  max-width:1120px !important;
  margin:28px auto !important;
  padding:clamp(22px,3vw,36px) !important;
  border-radius:28px !important;
}
.update-body h1{margin-top:0;font-size:clamp(30px,4vw,52px);letter-spacing:-.04em}
.update-body .notice{
  max-height:68vh;
  overflow:auto;
  padding:14px !important;
  scrollbar-width:thin;
  scrollbar-color:rgba(99,255,113,.55) rgba(255,255,255,.08);
}
.update-body .notice p{
  margin:6px 0;
  padding:9px 11px;
  border-radius:14px;
  background:rgba(0,0,0,.16);
  border:1px solid rgba(255,255,255,.055);
}
.update-body .notice p:before{content:'✓';color:#6dff73;font-weight:950;margin-right:9px;text-shadow:0 0 12px rgba(85,255,98,.5)}
.update-body .notice.err p:before{content:'!';color:#ff8b8b}
.flash-stack,.toast-stack{position:fixed;right:18px;bottom:18px;z-index:9999;display:grid;gap:10px;max-width:min(420px,calc(100vw - 28px))}
.game-toast,.modern-notice{
  border-radius:20px;
  padding:14px 16px;
  color:#fff;
  background:linear-gradient(135deg, rgba(5,36,18,.96), rgba(7,78,31,.88));
  border:1px solid rgba(91,255,105,.42);
  box-shadow:0 18px 46px rgba(0,0,0,.44), 0 0 26px rgba(72,255,91,.18);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.game-toast.err,.modern-notice.err{background:linear-gradient(135deg, rgba(48,10,15,.96), rgba(91,21,25,.88));border-color:rgba(255,111,111,.56)}
@media(max-width:720px){
  .update-body .wrap{width:100% !important;padding:10px 10px 28px !important}
  .update-body .card{border-radius:22px !important;margin:10px auto !important;padding:18px !important}
  .update-body .notice{max-height:72vh;font-size:14px}
  .update-body .notice p{padding:8px 9px}
  .flash-stack,.toast-stack{left:10px;right:10px;bottom:10px;max-width:none}
  .notice{border-radius:18px !important;padding:13px 14px !important}
}


/* 0156 Shadow Realm better action cards - CSS only, light */
.shadow-realm-0156 .shadow-action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin:18px 0}
.shadow-action-card{margin:0;padding:0;border:0;background:transparent}
.shadow-action-card button{width:100%;min-height:132px;text-align:left;display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:8px 12px;align-items:center;padding:17px;border-radius:22px;border:1px solid rgba(183,126,255,.28);background:linear-gradient(145deg,rgba(25,10,44,.88),rgba(7,5,18,.86));color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 14px 35px rgba(0,0,0,.22);cursor:pointer;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}
.shadow-action-card button:hover{transform:translateY(-2px);border-color:rgba(205,160,255,.55);box-shadow:0 18px 42px rgba(86,30,150,.22)}
.shadow-action-card .me-inline{grid-row:1/3;width:42px;height:42px}
.shadow-action-card b{font-size:18px;line-height:1.05}
.shadow-action-card small{color:#d9c8ef;font-weight:750;line-height:1.28}
.shadow-action-card.danger button{border-color:rgba(255,95,112,.34);background:linear-gradient(145deg,rgba(60,10,34,.9),rgba(13,5,18,.88))}
.shadow-action-card.shadow-fight button{border-color:rgba(128,255,120,.28);background:linear-gradient(145deg,rgba(11,46,27,.88),rgba(8,8,20,.86))}
@media(max-width:720px){.shadow-realm-0156 .shadow-action-cards{grid-template-columns:1fr}.shadow-action-card button{min-height:105px;padding:14px}.shadow-action-card b{font-size:17px}}


/* 0158: mobile notices clean compact safe-area */
.notice,
.card.notice {
  max-width: min(1180px, calc(100vw - 28px));
  margin-left: auto;
  margin-right: auto;
  overflow-wrap: anywhere;
  word-break: normal;
  line-height: 1.45;
  box-sizing: border-box;
}
.notice p,
.card.notice p {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: normal;
}
@media (max-width: 760px) {
  .wrap {
    width: min(100% - 18px, 100%);
    padding-left: max(9px, env(safe-area-inset-left));
    padding-right: max(9px, env(safe-area-inset-right));
    padding-bottom: calc(92px + env(safe-area-inset-bottom));
    box-sizing: border-box;
  }
  .notice,
  .card.notice {
    width: calc(100vw - 22px) !important;
    max-width: calc(100vw - 22px) !important;
    margin: 10px auto 14px !important;
    padding: 13px 14px !important;
    border-radius: 18px !important;
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.38 !important;
    overflow: hidden;
  }
  .notice.err,
  .card.notice.err {
    border-left: 6px solid rgba(255,92,92,.9) !important;
    background: linear-gradient(135deg, rgba(86,18,23,.92), rgba(18,4,9,.82)) !important;
  }
  .notice:not(.err),
  .card.notice:not(.err) {
    border-left: 6px solid rgba(103,255,105,.85) !important;
    background: linear-gradient(135deg, rgba(7,42,22,.94), rgba(2,18,12,.84)) !important;
  }
  .notice p,
  .card.notice p {
    margin: 0 0 6px;
  }
  .notice p:last-child,
  .card.notice p:last-child {
    margin-bottom: 0;
  }
  #content,
  .page-main {
    overflow-x: hidden;
  }
}
@media (max-width: 430px) {
  .notice,
  .card.notice {
    width: calc(100vw - 16px) !important;
    max-width: calc(100vw - 16px) !important;
    padding: 11px 12px !important;
    border-radius: 16px !important;
  }
}


/* 0159: uus mobiili teadete kujundus - kompaktne, kitsas ja turvaline */
.notices-page{max-width:980px;margin-left:auto;margin-right:auto;overflow:hidden}
.notices-page>h1{margin-bottom:8px}
.notice-list{display:grid;gap:12px;margin-top:16px;max-width:920px;margin-left:auto;margin-right:auto}
.notice-item{position:relative;display:grid;grid-template-columns:1fr;gap:5px;padding:14px 16px 14px 18px;border-radius:20px;background:linear-gradient(135deg,rgba(4,20,13,.92),rgba(0,0,0,.78));border:1px solid rgba(103,255,105,.16);box-shadow:0 12px 38px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.04);overflow:hidden;max-width:100%;box-sizing:border-box}
.notice-item:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:4px;border-radius:99px;background:rgba(103,255,105,.75);box-shadow:0 0 16px rgba(103,255,105,.35)}
.notice-item b{font-size:18px;line-height:1.15;margin:0;color:#fff;max-width:100%;overflow-wrap:anywhere}
.notice-item span{font-size:15px;line-height:1.42;color:#dff7e7;margin:0;max-width:100%;overflow-wrap:anywhere;word-break:normal;hyphens:auto}
.notice-item small{font-size:13px;line-height:1.2;color:#9dc8aa;margin-top:2px;max-width:100%;overflow-wrap:anywhere}
.notice-item.warning{border-color:rgba(255,199,60,.28);box-shadow:0 12px 38px rgba(0,0,0,.34),0 0 20px rgba(255,199,60,.08)}
.notice-item.warning:before{background:rgba(255,199,60,.84);box-shadow:0 0 16px rgba(255,199,60,.38)}
.notice-item.danger{border-color:rgba(255,80,92,.30);box-shadow:0 12px 38px rgba(0,0,0,.34),0 0 20px rgba(255,80,92,.08)}
.notice-item.danger:before{background:rgba(255,80,92,.88);box-shadow:0 0 16px rgba(255,80,92,.36)}
.notice-item.system{border-color:rgba(103,255,105,.24)}
.push-card{max-width:920px;margin-left:auto;margin-right:auto;box-sizing:border-box;overflow:hidden}
@media(max-width:760px){
  .notices-page{width:100%;max-width:100%;padding:14px 12px 118px!important;margin:10px auto!important;border-radius:22px!important;box-sizing:border-box;overflow:hidden}
  .notices-page>h1{font-size:28px!important;line-height:1.08;margin:0 0 8px!important}
  .notices-page>p{font-size:14px!important;line-height:1.36;margin:0 0 12px!important;color:#cce7d3!important;overflow-wrap:anywhere}
  .push-card{padding:12px!important;border-radius:18px!important;margin:10px 0 12px!important;width:100%;max-width:100%;box-sizing:border-box}
  .notice-list{gap:9px;margin-top:10px;width:100%;max-width:100%;box-sizing:border-box}
  .notice-item{width:100%;max-width:100%;min-width:0;padding:12px 12px 12px 15px!important;border-radius:17px!important;box-sizing:border-box;background:linear-gradient(135deg,rgba(4,18,12,.96),rgba(0,0,0,.84))!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
  .notice-item:before{top:10px;bottom:10px;width:3px}
  .notice-item b{font-size:15.5px!important;line-height:1.14!important;letter-spacing:-.01em}
  .notice-item span{font-size:14px!important;line-height:1.32!important;display:block;white-space:normal!important;overflow-wrap:anywhere!important;word-break:break-word!important;max-width:100%}
  .notice-item small{font-size:12.5px!important;line-height:1.15!important;color:#98bda3!important}
}
@media(max-width:430px){
  .notices-page{padding-left:10px!important;padding-right:10px!important}
  .notice-item{padding:11px 11px 11px 14px!important;border-radius:16px!important}
  .notice-item b{font-size:15px!important}
  .notice-item span{font-size:13.5px!important}
}
