:root{--ink: #261333;--muted: #6f5d58;--cream: #fff1c9;--paper: #ffe3a6;--gold: #f2a900;--gold-dark: #a75c00;--purple: #6d2da6;--purple-dark: #251345;--blue: #1d74ba;--green: #62ba32;--red: #e7435a;--line: rgba(68, 35, 18, .22);--shadow: 0 18px 48px rgba(37, 19, 69, .28);--soft-shadow: 0 8px 20px rgba(52, 28, 21, .18);--card-radius: 14px;--pill-radius: 999px}*{box-sizing:border-box}html,body,#root{height:100%;min-height:100%}body{margin:0;color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#2193e8;overflow-x:hidden}@media (min-width: 861px){html,body,#root{overflow:hidden}}body:before{position:fixed;inset:0;z-index:-2;background:linear-gradient(180deg,#1869be1a,#4925616b),url(../generated/background-desert.png) center / cover no-repeat;content:""}body:after{position:fixed;inset:0;z-index:-1;pointer-events:none;background:linear-gradient(90deg,rgba(21,22,70,.18),transparent 28%,rgba(37,19,69,.16));content:""}button{border:0;font:inherit}button:not(:disabled){cursor:pointer}img{display:block;max-width:100%}[hidden]{display:none!important}:root{color-scheme:dark}h1,h2,h3,p{margin-top:0}h1,h2{margin-bottom:0;color:#3a1d13;font-weight:1000;line-height:1}h1{font-size:clamp(2rem,4vw,2.8rem)}h2{font-size:clamp(1.55rem,3vw,2.2rem)}h3{margin-bottom:8px}.app-shell{display:grid;grid-template-columns:142px minmax(0,1fr);height:100dvh;min-height:0;padding:14px 22px 12px;gap:14px;overflow:hidden}.side-nav{display:flex;flex-direction:column;gap:18px;min-width:0}.brand-lockup{display:grid;justify-items:center;width:100%;padding:12px 8px 14px;color:#ffcf32;text-shadow:0 4px 0 #68218d,0 7px 10px rgba(0,0,0,.28);background:radial-gradient(circle at 50% 20%,rgba(255,255,255,.24),transparent 42%),linear-gradient(180deg,#7734b5f2,#3e1c7cf5);border:2px solid rgba(255,215,92,.72);border-radius:var(--card-radius);box-shadow:var(--shadow)}.brand-line{font-weight:1000;font-size:clamp(1.7rem,4vw,2.28rem);line-height:.86}.brand-ribbon{width:fit-content;margin-top:8px;padding:4px 8px;color:#fff;font-size:.72rem;font-weight:900;text-shadow:0 1px 0 rgba(0,0,0,.38);background:linear-gradient(180deg,#8b3ec0,#552181);border-radius:8px}.nav-stack{display:grid;gap:10px;padding:12px;background:linear-gradient(180deg,#4d2477f5,#21154bf5);border:2px solid rgba(255,207,67,.68);border-radius:var(--card-radius);box-shadow:var(--shadow)}.nav-button,.bottom-button{display:grid;justify-items:center;gap:4px;color:#fff;font-weight:900;text-shadow:0 2px 0 rgba(0,0,0,.35);background:transparent;border-radius:10px;transition:transform .12s ease,background .12s ease}.nav-button{width:100%;min-height:80px;padding:10px 8px}.nav-button span{font-size:.9rem;line-height:1.08;white-space:nowrap}.nav-button img,.bottom-button img{width:42px;height:42px;object-fit:contain;filter:drop-shadow(0 4px 4px rgba(0,0,0,.24))}.nav-button.is-active,.nav-button:hover{background:linear-gradient(180deg,#8647c1eb,#4e1f82eb);outline:2px solid rgba(255,220,86,.72);outline-offset:-2px}.game-stage{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-width:0;min-height:0;height:100%;gap:10px;overflow:hidden}.top-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;min-height:52px;flex-wrap:wrap}.resource-row{display:flex;gap:12px;flex-wrap:wrap}.resource-pill,.profile-chip{display:inline-flex;align-items:center;min-height:52px;color:#fff;font-size:1.04rem;font-weight:950;text-shadow:0 2px 0 rgba(0,0,0,.35);background:linear-gradient(180deg,#274282eb,#1c214ef5);border:2px solid rgba(255,255,255,.5);border-radius:var(--pill-radius);box-shadow:var(--soft-shadow)}.resource-pill{gap:9px;min-width:110px;padding:6px 16px 6px 10px}.resource-pill img{width:38px;height:38px;flex:0 0 auto}.resource-pill .pill-value{font-weight:1000;font-size:1.05rem;color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.4);flex:0 0 auto;min-width:14px}.resource-pill .pill-label{font-weight:800;font-size:.92rem;color:#ffffffe6;flex:0 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-chip{gap:8px;padding:5px 12px 5px 6px;max-width:min(280px,100%)}.profile-chip img{width:44px;height:44px;object-fit:contain}.profile-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-chip button.icon-button{background:transparent;padding:4px 6px;color:#fff}.profile-switcher{position:relative;display:grid;justify-items:end;gap:3px}.profile-switch-tip{padding:2px 9px;color:#fff;font-size:.72rem;font-weight:900;line-height:1.1;text-shadow:0 2px 0 rgba(0,0,0,.35);background:#18103e85;border:1px solid rgba(255,255,255,.2);border-radius:999px}.profile-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:30;display:grid;gap:10px;width:min(330px,calc(100vw - 24px));padding:12px;color:#3a1d13;text-shadow:none;background:linear-gradient(180deg,#fff1c9fa,#ffdd97fa),radial-gradient(circle at 50% 0%,white,transparent 54%);border:3px solid rgba(114,67,24,.42);border-radius:14px;box-shadow:var(--shadow)}.switch-hint{margin:0;padding:9px 10px;color:#4b2417;font-size:.88rem;font-weight:900;line-height:1.25;background:#fff9e7b8;border:2px solid rgba(104,62,26,.18);border-radius:10px}.profile-menu-list{display:grid;gap:8px;max-height:250px;overflow-y:auto}.profile-menu-row{display:grid;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:10px;width:100%;padding:8px;color:var(--ink);text-align:left;background:#fff9e7c7;border:2px solid rgba(104,62,26,.22);border-radius:10px}.profile-menu-row.is-active{background:#f1ffdeeb;outline:3px solid rgba(109,186,45,.72);outline-offset:-3px}.profile-menu-row img{width:44px;height:44px;object-fit:contain}.profile-menu-row span{display:grid;gap:2px;min-width:0}.profile-menu-row strong,.profile-menu-row small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-menu-row small{color:#6b4a34;font-weight:850}.profile-menu-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.profile-menu-actions button{min-height:40px;padding:8px 10px;color:#fff;font-weight:950;background:linear-gradient(180deg,#6d2da6,#3d1d75);border-radius:10px;text-shadow:0 2px 0 rgba(0,0,0,.28)}.icon-button{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#4e9dd4,#1c5e97);color:#fff;font-size:1.1rem;font-weight:1000;border-radius:999px;padding:8px 14px;box-shadow:var(--soft-shadow);border:2px solid rgba(255,255,255,.45)}.screen-container{display:grid;min-width:0;min-height:0;height:100%;overflow:hidden;align-items:stretch}.screen-container>*{min-height:0}.app-credits{display:flex;flex-wrap:wrap;justify-content:center;gap:6px 14px;margin:0 auto;padding:5px 12px;width:fit-content;max-width:100%;color:#fffffff0;font-size:.72rem;font-weight:850;line-height:1.25;text-align:center;text-shadow:0 2px 0 rgba(0,0,0,.34);background:#18103e6b;border:1px solid rgba(255,255,255,.16);border-radius:999px}.app-credits a{color:#ffe469;font-weight:950;text-decoration:none}.app-credits a:hover{text-decoration:underline}.panel,.wide-panel,.play-panel,.mission-board{background:linear-gradient(180deg,#fff1c9f5,#ffda90f2),radial-gradient(circle at 50% 0%,rgba(255,255,255,.72),transparent 42%);border:3px solid rgba(114,67,24,.38);border-radius:var(--card-radius);box-shadow:var(--shadow)}.panel{padding:clamp(14px,3vw,24px)}.play-panel,.wide-panel{width:min(100%,980px);margin:0 auto;padding:clamp(16px,3vw,28px)}.scroll-panel{position:relative;align-self:stretch;height:100%;max-height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable;scrollbar-color:rgba(109,45,166,.95) rgba(255,249,231,.72);scrollbar-width:auto;background:linear-gradient(180deg,#fff1c9f5,#ffda90f2),radial-gradient(circle at 50% 0%,rgba(255,255,255,.72),transparent 42%)}.scroll-panel::-webkit-scrollbar{width:18px}.scroll-panel::-webkit-scrollbar-track{background:#fff9e7b8;border-left:2px solid rgba(104,62,26,.18);border-radius:999px}.scroll-panel::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#8b3ec0,#552181);border:4px solid rgba(255,249,231,.72);border-radius:999px}.scroll-panel::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#9e50d0,#633092)}.world-map-panel{width:min(100%,1180px)}.section-title{display:flex;align-items:center;gap:12px}.section-title img{width:48px;height:48px}.eyebrow{margin:0 0 2px;color:#804014;font-size:.78rem;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.primary-action,.primary-small,.secondary-action{min-height:48px;border-radius:10px;color:#fff;font-weight:1000;text-shadow:0 2px 0 rgba(109,51,0,.58);box-shadow:inset 0 2px #ffffff8c,0 7px #9a5200e6,0 12px 18px #4a22043d;transition:transform .12s ease}.primary-action:hover,.primary-small:hover{transform:translateY(-1px)}.primary-action{width:min(100%,280px);margin:0 auto;padding:14px 24px;font-size:1.4rem;background:linear-gradient(180deg,#ffd44a,#f19a00)}.primary-small{padding:11px 18px;background:linear-gradient(180deg,#ffd44a,#f19a00)}.secondary-action{padding:11px 16px;background:linear-gradient(180deg,#4d9bd1,#1f6eab);box-shadow:inset 0 2px #ffffff73,0 7px #114a78f2,0 12px 18px #0d30493d}.primary-action:disabled,.primary-small:disabled,.secondary-action:disabled{cursor:default;filter:grayscale(.6) opacity(.7)}.challenge-copy{width:fit-content;max-width:100%;margin:18px auto 20px;padding:12px 22px;color:#34120f;font-weight:950;background:#ffe7bfeb;border:2px solid rgba(134,74,34,.2);border-radius:10px;box-shadow:0 8px 20px #341c152e;text-align:center}.mini-progress{width:100%;height:16px;overflow:hidden;background:#412d2747;border-radius:999px}.mini-progress span{display:block;height:100%;width:0%;background:linear-gradient(180deg,#8edb3d,#31a82c);border-radius:inherit;transition:width .24s ease}.toast{position:fixed;left:50%;bottom:22px;z-index:50;min-width:min(320px,calc(100vw - 32px));padding:13px 16px;color:#fff;font-weight:950;text-align:center;pointer-events:none;opacity:0;transform:translate(-50%,22px);background:linear-gradient(180deg,#4c2683fa,#251345fa);border:2px solid rgba(255,218,86,.68);border-radius:10px;box-shadow:var(--shadow);transition:opacity .18s ease,transform .18s ease}.toast.is-visible{opacity:1;transform:translate(-50%)}.bottom-nav{display:none}.home-layout{display:grid;grid-template-columns:minmax(250px,42vw) minmax(340px,520px);align-items:center;justify-content:center;gap:clamp(16px,3vw,44px);height:100%;min-height:0;transform:translateY(-18px)}.home-character-wrap{position:relative;justify-self:end;width:min(390px,100%)}.home-character-wrap .static-bubble{position:absolute;right:0;bottom:50%;max-width:240px}.home-mission-board{display:grid;gap:12px;padding:18px}.home-mission-board h1{font-size:clamp(1.8rem,3.4vw,2.55rem)}.home-mission-board h3{margin:4px 0 8px}.next-level-card{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;background:#fff9e7d9;border:2px solid rgba(104,62,26,.32);border-radius:12px;box-shadow:0 8px 20px #341c152e}.panel-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:stretch}.panel-actions .secondary-action{flex:0 0 auto}.panel-actions .panel-primary{flex:1 1 auto;width:auto;min-width:180px;margin:0}@media (max-width: 520px){.panel-actions{flex-direction:column-reverse}.panel-actions .secondary-action,.panel-actions .panel-primary{width:100%}}@media (max-width: 520px){.next-level-card{grid-template-columns:1fr}.next-level-card .primary-action{width:100%}}@media (max-width: 860px){html,body,#root{height:auto;min-height:100%}body{overflow-x:hidden}.home-layout{grid-template-columns:1fr;height:auto;min-height:0;gap:8px;transform:none}.home-character-wrap{justify-self:center;width:min(220px,60vw)}.home-character-wrap .static-bubble{position:static;max-width:100%;margin:8px auto 0}}@media (max-width: 1120px){.app-shell{grid-template-columns:110px minmax(0,1fr);padding:12px}.nav-button{min-height:70px;font-size:.82rem}}.top-bar-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.world-name-tag{color:#fff;font-weight:950;text-shadow:0 2px 0 rgba(0,0,0,.4)}@media (max-width: 860px){.app-shell{display:block;height:auto;min-height:100vh;overflow:visible;padding:8px 8px 92px}.screen-container{display:block;height:auto;overflow:visible}.side-nav{display:none}.top-bar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:auto;padding:0}.resource-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;width:100%}.resource-pill{flex-direction:column;min-width:0;min-height:56px;gap:1px;padding:4px 6px 5px;justify-content:center;align-items:center;white-space:nowrap;border-radius:14px}.resource-pill img{width:26px;height:26px}.resource-pill .pill-value{font-size:.95rem;line-height:1;min-width:12px;text-align:center}.resource-pill .pill-label{display:none}.desktop-only{display:none!important}.world-name-tag{display:none}.top-bar-right{gap:6px;flex-wrap:nowrap;justify-content:flex-end}.profile-chip{min-height:36px;max-width:160px;padding:2px 10px 2px 2px;font-size:.82rem;gap:6px}.profile-chip img{width:32px;height:32px}.profile-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-menu{right:-44px;width:min(330px,calc(100vw - 16px))}.profile-switch-tip{display:none}.icon-button{flex:0 0 auto;min-width:36px;min-height:36px;padding:4px 8px;font-size:.95rem}.play-panel,.wide-panel{width:100%;padding:12px;min-height:auto}.scroll-panel{height:auto;max-height:none;overflow:visible;scrollbar-width:auto;background:linear-gradient(180deg,#fff1c9f5,#ffda90f2),radial-gradient(circle at 50% 0%,rgba(255,255,255,.72),transparent 42%)}.scroll-panel::-webkit-scrollbar{width:initial}.app-credits{margin-top:8px;border-radius:14px}.bottom-nav{position:fixed;left:6px;right:6px;bottom:6px;display:grid;grid-template-columns:repeat(6,1fr);gap:2px;padding:5px;z-index:25;background:linear-gradient(180deg,#4e2479fa,#21154bfa);border:2px solid rgba(255,207,67,.62);border-radius:12px;box-shadow:var(--shadow)}.bottom-button{min-width:0;padding:3px 0;border-radius:8px;font-size:.6rem;line-height:1}.bottom-button img{width:24px;height:24px}.bottom-button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bottom-button.is-active{background:#8b3ec0bf}}@media (max-width: 600px){.battle-stage{grid-template-columns:1fr!important}.battle-stage>img{width:min(140px,32vw)!important}.play-panel{padding:12px!important}.challenge-copy{margin:10px auto 12px!important;padding:8px 14px!important;font-size:.92rem}}@media (max-width: 380px){.resource-pill{font-size:.78rem;padding:2px 4px}.resource-pill img{width:20px;height:20px}.profile-chip{max-width:120px}.profile-menu{right:-40px}.profile-menu-actions{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
