:root{--font-display: "Baloo 2", system-ui, sans-serif;--font-body: "Quicksand", system-ui, sans-serif;--c-sky: #7ec8e3;--c-cream: #fff8ec;--c-sand: #f2d49b;--c-leaf: #63b85c;--c-coffee: #8a5a3b;--c-coral: #ff8a72;--c-berry: #e84d6f;--c-sun: #ffd166;--c-lavanda: #9d8df1;--c-ink: #3c3246;--c-ink-soft: #6d6280;--shadow-pop: 0 6px 0 rgba(60, 50, 70, .18);--radius-bubble: 22px}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{width:100%;height:100%;overflow:hidden;overscroll-behavior:none}body{font-family:var(--font-body);color:var(--c-ink);background:linear-gradient(#aee3f7,#fdf3da);touch-action:none;user-select:none;-webkit-user-select:none}#root{position:relative}canvas{display:block;outline:none}button{font-family:var(--font-display);border:none;cursor:pointer;background:none;color:inherit}input,textarea{font-family:var(--font-body)}.k-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 26px;border-radius:999px;font-size:18px;font-weight:800;letter-spacing:.3px;color:#fff;background:linear-gradient(180deg,#ffa56b,#ff7d54);box-shadow:0 5px #d65a38,0 10px 22px #d65a3859;transition:transform .12s ease,box-shadow .12s ease,filter .2s ease}.k-btn:hover{transform:translateY(-2px) scale(1.02);filter:brightness(1.05)}.k-btn:active{transform:translateY(3px);box-shadow:0 2px #d65a38,0 6px 12px #d65a384d}.k-btn.secondary{background:linear-gradient(180deg,#8ed1f0,#5fb2dd);box-shadow:0 5px #3c8cb8,0 10px 22px #3c8cb84d}.k-btn.secondary:active{box-shadow:0 2px #3c8cb8}.k-btn.leaf{background:linear-gradient(180deg,#8fd07a,#63b85c);box-shadow:0 5px #43914a,0 10px 22px #43914a4d}.k-btn.leaf:active{box-shadow:0 2px #43914a}.k-btn.ghost{background:#ffffffd9;color:var(--c-ink);box-shadow:0 4px #3c324626}.k-btn:disabled{filter:grayscale(.6) brightness(.9);cursor:not-allowed;transform:none}.k-card{background:var(--c-cream);border-radius:var(--radius-bubble);box-shadow:0 8px #3c32461f,0 24px 60px #283c5a40;border:3px solid #fff}.k-chip{display:inline-flex;align-items:center;gap:6px;background:#ffffffeb;border-radius:999px;padding:8px 14px;font-family:var(--font-display);font-weight:700;box-shadow:var(--shadow-pop)}@keyframes k-pop-in{0%{opacity:0;transform:translateY(18px) scale(.92)}60%{opacity:1;transform:translateY(-4px) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes k-float{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}@keyframes k-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.07)}}@keyframes k-wiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes k-drift{0%{transform:translate(-12%)}to{transform:translate(112%)}}@keyframes k-shine{0%{background-position:-200% 0}to{background-position:200% 0}}.k-pop{animation:k-pop-in .45s cubic-bezier(.22,1.4,.36,1) both}.ui-layer{position:absolute;inset:0;pointer-events:none;z-index:10;font-family:var(--font-body)}.ui-layer>*{pointer-events:auto}.welcome{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;background:radial-gradient(ellipse at 50% 120%,rgba(255,209,102,.35),transparent 60%),linear-gradient(180deg,#8fd3f4,#b8e6f5 45%,#fdedc4);overflow:hidden;padding:20px}.welcome:before,.welcome:after{content:"";position:absolute;border-radius:50%;filter:blur(2px);opacity:.85}.welcome:before{width:220px;height:70px;background:#fff;top:12%;left:-240px;border-radius:60px;box-shadow:60px 18px 0 -8px #fff,-50px 20px 0 -14px #fff;animation:k-drift 70s linear infinite}.welcome:after{width:160px;height:52px;background:#ffffffd9;top:28%;left:-180px;border-radius:60px;box-shadow:45px 14px 0 -6px #ffffffd9;animation:k-drift 95s linear 12s infinite}.welcome-logo{text-align:center;z-index:2}.welcome-logo .pre{font-family:var(--font-display);font-weight:700;color:#3c7a9e;letter-spacing:4px;text-transform:uppercase;font-size:clamp(11px,2.4vw,14px)}.welcome-logo h1{font-family:var(--font-display);font-size:clamp(44px,9vw,84px);font-weight:800;line-height:.95;color:#fff;text-shadow:0 3px 0 #e8a02c,0 7px 0 rgba(60,50,70,.22),0 18px 40px rgba(60,50,70,.25);animation:k-float 5s ease-in-out infinite}.welcome-logo .post{font-family:var(--font-display);font-weight:700;font-size:clamp(15px,3vw,21px);color:#5a4a36;margin-top:6px}.welcome-card{z-index:2;padding:26px 30px;width:min(560px,94vw);max-height:64vh;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.welcome-card h2{font-family:var(--font-display);font-size:22px;color:var(--c-ink)}.field-label{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--c-ink-soft);margin-bottom:6px;display:block}.name-input{width:100%;padding:13px 18px;font-size:18px;font-weight:600;border:3px solid #e8ddc8;border-radius:14px;background:#fff;color:var(--c-ink);outline:none;transition:border-color .2s}.name-input:focus{border-color:var(--c-sun)}.role-row{display:flex;flex-wrap:wrap;gap:8px}.role-chip{padding:9px 16px;border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:14px;background:#f1e9d8;color:var(--c-ink-soft);border:2.5px solid transparent;transition:all .15s}.role-chip.active{background:#fff;color:var(--c-ink);border-color:var(--c-sun);transform:scale(1.06);box-shadow:0 4px 10px #e8a02c4d}.swatch-row{display:flex;gap:8px;flex-wrap:wrap}.swatch{width:34px;height:34px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 6px #3c324640;transition:transform .12s}.swatch:hover{transform:scale(1.15)}.swatch.active{border-color:var(--c-ink);transform:scale(1.2)}.hat-row{display:flex;gap:8px;flex-wrap:wrap}.hat-chip{padding:8px 14px;border-radius:12px;background:#f1e9d8;font-size:20px;border:2.5px solid transparent;transition:all .15s}.hat-chip.active{background:#fff;border-color:var(--c-sun);transform:scale(1.1)}.parent-gate{background:#fdf2dc;border:2px dashed #e8c87a;border-radius:14px;padding:14px 16px;font-size:14px;color:#6b5a3a;display:flex;flex-direction:column;gap:10px}.parent-gate strong{font-family:var(--font-display)}.gate-check{display:flex;gap:10px;align-items:flex-start;cursor:pointer;line-height:1.45}.gate-check input{width:20px;height:20px;margin-top:1px;accent-color:#e8a02c;flex-shrink:0}.gate-question{display:flex;align-items:center;gap:10px}.gate-question input{width:76px;padding:9px 12px;font-size:17px;font-weight:700;border:2.5px solid #e8c87a;border-radius:10px;text-align:center;outline:none;background:#fff}.hud-bar{position:absolute;top:max(10px,env(safe-area-inset-top));left:max(14px,env(safe-area-inset-left));right:max(14px,env(safe-area-inset-right));display:flex;justify-content:space-between;align-items:center;pointer-events:none;z-index:6}.hud-brand{display:flex;flex-direction:column;line-height:1;text-shadow:0 2px 12px rgba(20,40,60,.45);pointer-events:none}.hud-brand-pre{font-family:var(--font-display);font-weight:800;font-size:clamp(11px,2.2vw,13px);letter-spacing:.28em;color:#ffffffeb}.hud-brand-name{font-family:var(--font-display);font-weight:800;font-size:clamp(18px,4vw,24px);letter-spacing:.06em;color:#fff}.hud-tools{display:flex;gap:8px;align-items:center;pointer-events:auto}.hud-btn{width:42px;height:42px;border-radius:50%;background:#ffffffe0;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #1e283238;border:2px solid rgba(255,255,255,.65);transition:transform .12s}.hud-btn:hover{transform:scale(1.08)}.hud-btn:active{transform:scale(.94)}.hud-crown{background:linear-gradient(135deg,#ffe08a,#ffc857);cursor:default}.hud-premium-btn{display:flex;align-items:center;gap:6px;height:42px;padding:0 14px;border-radius:999px;background:radial-gradient(ellipse at 20% 0%,rgba(255,255,255,.22),transparent 55%),linear-gradient(135deg,#8d6fe8,#b197fc);color:#fff;font-family:var(--font-display);font-weight:800;font-size:clamp(12px,2.6vw,13px);letter-spacing:.05em;text-transform:uppercase;border:2px solid rgba(255,255,255,.58);box-shadow:0 4px 16px #6d4ec86b;transition:transform .12s;animation:hud-premium-glow 2.8s ease-in-out infinite}.hud-premium-btn:hover{transform:scale(1.06)}.hud-premium-btn:active{transform:scale(.96)}.hud-premium-icon{font-size:16px;line-height:1}@media(max-width:380px){.hud-premium-text{display:none}.hud-premium-btn{width:42px;padding:0;justify-content:center}}@keyframes hud-premium-glow{0%,to{box-shadow:0 4px 16px #6d4ec86b}50%{box-shadow:0 6px 22px #8d6fe8b8}}.interact-prompt{position:absolute;bottom:max(22vh,140px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#28323cc7;color:#fff;padding:9px 16px;border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:14px;box-shadow:0 8px 20px #141e2847;backdrop-filter:blur(4px);z-index:5}.interact-prompt--touch{pointer-events:auto;touch-action:manipulation;border:2px solid rgba(255,255,255,.22);gap:12px;padding:12px 20px 12px 14px;min-height:56px;max-width:min(92vw,360px);text-align:left;transition:transform .12s ease,box-shadow .12s ease}.interact-prompt--touch:active{transform:translate(-50%) scale(.97);box-shadow:0 4px 14px #141e2838}.interact-prompt__ring{position:relative;width:40px;height:40px;flex-shrink:0}.interact-prompt__ring svg{width:100%;height:100%;transform:rotate(-90deg)}.interact-prompt__ring-bg{fill:none;stroke:#fff3;stroke-width:3}.interact-prompt__ring-fill{fill:none;stroke:#7ee8a0;stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .08s linear}.interact-prompt__icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:18px}.interact-prompt__text{line-height:1.25}.interact-prompt__hint{display:block;font-size:11px;font-weight:600;opacity:.78;margin-top:2px}.interact-prompt .key{background:#fff;color:var(--c-ink);border-radius:7px;padding:2px 9px;font-size:12px;box-shadow:0 2px #c9bfa8}.dialogue-wrap{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;padding:0 16px calc(16px + env(safe-area-inset-bottom))}.dialogue{width:min(680px,100%);background:#fff8ecf7;border-radius:24px 24px 20px 20px;border:3px solid #fff;box-shadow:0 -4px #3c324614,0 20px 50px #281e3259;padding:18px 22px 14px;animation:k-pop-in .35s cubic-bezier(.22,1.4,.36,1) both}.dialogue .speaker{display:inline-block;font-family:var(--font-display);font-weight:800;font-size:15px;color:#fff;background:linear-gradient(120deg,#ff8a72,#e84d6f);padding:5px 16px;border-radius:999px;margin-top:-32px;box-shadow:0 4px 12px #e84d6f66}.dialogue .speaker .role{font-weight:600;opacity:.85;font-size:12.5px}.dialogue .text{font-size:clamp(16px,2.6vw,19px);line-height:1.55;color:var(--c-ink);min-height:58px;margin-top:8px;font-weight:500}.dialogue .next{display:flex;justify-content:flex-end;align-items:center;gap:8px;font-size:13px;color:var(--c-ink-soft);font-family:var(--font-display);font-weight:700}.dialogue .next .key{background:#fff;border-radius:7px;padding:2px 9px;box-shadow:0 2px #d8cdb4}.dialogue .arrow{animation:k-float 1.2s ease-in-out infinite;font-size:18px}.classroom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 0%,rgba(116,192,252,.25),transparent 55%),#282438c7;backdrop-filter:blur(7px);padding:16px}.classroom-card{width:min(720px,96vw);max-height:92vh;overflow-y:auto;display:flex;flex-direction:column;background:var(--c-cream);border-radius:26px;border:3px solid #fff;box-shadow:0 30px 80px #140f238c;animation:k-pop-in .45s cubic-bezier(.22,1.4,.36,1) both}.class-head{display:flex;align-items:center;gap:12px;padding:16px 22px;border-radius:23px 23px 0 0;color:#fff}.class-head .emoji{font-size:30px}.class-head .title{font-family:var(--font-display);font-weight:800;font-size:clamp(16px,3vw,20px);line-height:1.15}.class-head .sub{font-size:12.5px;opacity:.92;font-weight:600}.class-head .close{margin-left:auto;width:38px;height:38px;border-radius:50%;background:#ffffff40;color:#fff;font-size:17px;font-weight:800;flex-shrink:0}.class-progress{height:8px;background:#eee2cb;position:relative}.class-progress .fill{height:100%;background:linear-gradient(90deg,#ffd166,#ff8a72);border-radius:0 6px 6px 0;transition:width .6s cubic-bezier(.22,1,.36,1)}.class-body{padding:24px 28px 28px;display:flex;flex-direction:column;gap:16px}.slide-art{font-size:clamp(56px,12vw,92px);text-align:center;line-height:1.1;animation:k-float 3.4s ease-in-out infinite;filter:drop-shadow(0 10px 18px rgba(60,50,70,.2))}.slide-title{font-family:var(--font-display);font-weight:800;font-size:clamp(20px,4vw,26px);color:var(--c-ink);text-align:center}.slide-text{font-size:clamp(15.5px,2.7vw,18px);line-height:1.65;color:var(--c-ink);text-align:center;font-weight:500}.grownups{background:#f0eafc;border-left:4px solid #b197fc;border-radius:12px;padding:12px 16px;font-size:13.5px;line-height:1.55;color:#5a4a7d}.grownups b{font-family:var(--font-display)}.option-list{display:flex;flex-direction:column;gap:10px}.option-btn{text-align:left;padding:15px 18px;border-radius:16px;background:#fff;border:3px solid #eadfc8;font-size:16px;font-weight:600;color:var(--c-ink);transition:all .15s;line-height:1.4}.option-btn:hover{border-color:var(--c-sun);transform:translate(4px)}.option-btn.correct{border-color:#63b85c;background:#eef9ea;animation:k-pulse .5s ease}.option-btn.wrong{border-color:#e84d6f;background:#fdeef2;opacity:.7}.kira-bubble{display:flex;gap:14px;align-items:flex-start;background:linear-gradient(135deg,#e4fbf4,#d4f4ff);border-radius:18px;padding:16px 18px;border:2.5px solid #9be8d8;animation:k-pop-in .4s cubic-bezier(.22,1.4,.36,1) both}.kira-bubble .kira-face{font-size:34px;flex-shrink:0;animation:k-float 2.2s ease-in-out infinite}.kira-bubble .kira-name{font-family:var(--font-display);font-weight:800;font-size:13px;color:#1e8a72;letter-spacing:.5px}.kira-bubble .kira-text{font-size:15.5px;line-height:1.55;color:#234f46;font-weight:500}.kira-thinking{display:inline-flex;gap:5px;align-items:center;height:18px}.kira-thinking i{width:8px;height:8px;border-radius:50%;background:#1e8a72;animation:k-pulse 1s ease-in-out infinite}.kira-thinking i:nth-child(2){animation-delay:.18s}.kira-thinking i:nth-child(3){animation-delay:.36s}.board-input{width:100%;min-height:110px;resize:vertical;padding:15px 18px;font-size:16px;line-height:1.55;border:3px solid #eadfc8;border-radius:16px;background:#fff;color:var(--c-ink);outline:none}.board-input:focus{border-color:#74c0fc}.board-chalk{background:linear-gradient(160deg,#2e4a3e,#1f3830);border-radius:18px;padding:18px 22px;color:#f3f0d9;font-size:clamp(15px,2.6vw,17.5px);line-height:1.6;font-weight:500;border:6px solid #8a5a3b;box-shadow:inset 0 0 30px #0000004d}.class-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:4px}.hint-link{font-size:14px;color:#3c7a9e;font-weight:700;text-decoration:underline;font-family:var(--font-display)}.map-overlay{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:center;background:#282438b8;backdrop-filter:blur(6px);padding:max(58px,calc(env(safe-area-inset-top) + 48px)) 12px max(12px,env(safe-area-inset-bottom));overflow-y:auto}.map-shell{width:min(560px,100%);max-height:min(78vh,640px);display:flex;flex-direction:column;background:#fff8ec;border-radius:20px;border:4px solid #fff;box-shadow:0 20px 60px #140f2380;animation:k-pop-in .35s cubic-bezier(.22,1.4,.36,1) both;overflow:hidden}.map-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 14px 10px;background:linear-gradient(135deg,#4a7c9e,#3c6480);color:#fff}.map-header-main{display:flex;flex-direction:column;gap:2px;min-width:0}.map-header-title{font-family:var(--font-display);font-weight:800;font-size:15px;letter-spacing:.02em}.map-header-here{font-size:12px;font-weight:600;opacity:.95}.map-header-here--muted{opacity:.72}.map-close{flex-shrink:0;width:34px;height:34px;border-radius:50%;background:#fff8ecf2;color:var(--c-ink);font-size:15px;font-weight:800;box-shadow:var(--shadow-pop)}.map-body{display:flex;flex:1;min-height:0}.map-view{position:relative;flex:0 0 min(42vw,220px);width:min(42vw,220px);aspect-ratio:1;background:radial-gradient(circle at 50% 45%,#7ec46a,#6fb85f 38%,#f2d49b 56%,#6fd6d0 62%,#2e8fb8);border-right:2px solid rgba(60,50,70,.08)}.map-pin{position:absolute;transform:translate(-50%,-50%);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff8ece0;border:2px solid rgba(255,255,255,.9);box-shadow:0 2px 6px #28243840;transition:transform .15s ease,box-shadow .15s ease}.map-pin:active{transform:translate(-50%,-50%) scale(.92)}.map-pin--active{transform:translate(-50%,-50%) scale(1.12);box-shadow:0 0 0 3px #ff54708c,0 3px 10px #2824384d;z-index:2}.map-pin-icon{font-size:15px;line-height:1;filter:drop-shadow(0 1px 2px rgba(60,50,70,.3))}.map-player{position:absolute;width:12px;height:12px;border-radius:50%;background:#ff5470;border:2.5px solid #fff;transform:translate(-50%,-50%);box-shadow:0 0 0 4px #ff547059;animation:k-pulse 1.6s ease-in-out infinite;z-index:3;pointer-events:none}.map-nav{flex:1;min-width:0;display:flex;flex-direction:column;background:#fff8ec}.map-nav-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;padding:8px 12px 6px;font-family:var(--font-display);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#6a5a72;border-bottom:1px solid rgba(60,50,70,.08)}.map-nav-head-hint{font-size:10px;font-weight:600;text-transform:none;letter-spacing:0;opacity:.7}.map-nav-list{list-style:none;margin:0;padding:4px 6px 8px;overflow-y:auto;flex:1}.map-nav-item{width:100%;display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:6px;padding:7px 8px;border-radius:12px;text-align:left;transition:background .12s ease}.map-nav-item:hover,.map-nav-item.active{background:#4a7c9e1f}.map-nav-item.active{background:#ff54701a}.map-nav-icon{font-size:16px;line-height:1;text-align:center}.map-nav-label{font-family:var(--font-display);font-size:13px;font-weight:700;color:#3c3246;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-nav-meta{display:flex;align-items:center;gap:5px;font-family:var(--font-display);font-size:12px;font-weight:700;color:#5a6a78;white-space:nowrap}.map-nav-arrow{font-size:14px;color:#4a7c9e;width:16px;text-align:center}.map-nav-dist{min-width:42px;text-align:right}.sub-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#282438c7;backdrop-filter:blur(7px);padding:16px;overflow-y:auto}.sub-card{width:min(560px,96vw);max-height:94vh;overflow-y:auto;background:var(--c-cream);border-radius:26px;border:3px solid #fff;box-shadow:0 30px 80px #140f238c;animation:k-pop-in .45s cubic-bezier(.22,1.4,.36,1) both}.sub-head{background:radial-gradient(ellipse at 20% 0%,rgba(255,255,255,.25),transparent 50%),linear-gradient(135deg,#8d6fe8,#b197fc);color:#fff;padding:26px 28px 20px;border-radius:23px 23px 0 0;text-align:center}.sub-head .crown{font-size:44px;display:block;animation:k-float 3s ease-in-out infinite}.sub-head h2{font-family:var(--font-display);font-size:clamp(22px,4.5vw,28px);font-weight:800;margin-top:6px}.sub-head p{font-size:14.5px;opacity:.95;margin-top:4px}.sub-body{padding:22px 28px 28px;display:flex;flex-direction:column;gap:18px}.sub-price{text-align:center}.sub-price .amount{font-family:var(--font-display);font-size:42px;font-weight:800;color:var(--c-ink)}.sub-price .per{font-size:15px;color:var(--c-ink-soft);font-weight:600}.sub-recurring{font-size:13.5px;line-height:1.45;color:var(--c-ink-soft);text-align:center;margin:-6px 0 0}.k-btn-premium{background:radial-gradient(ellipse at 20% 0%,rgba(255,255,255,.2),transparent 55%),linear-gradient(135deg,#8d6fe8,#b197fc)!important;color:#fff!important;border-color:#ffffff8c!important;box-shadow:0 8px 24px #6d4ec861}.sub-perks{display:flex;flex-direction:column;gap:10px}.perk{display:flex;gap:12px;align-items:flex-start;font-size:15px;line-height:1.45;color:var(--c-ink);font-weight:500}.perk .pi{font-size:20px;flex-shrink:0}.sub-trust{text-align:center;font-size:12.5px;color:var(--c-ink-soft);line-height:1.6}.payment-badges{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.pay-badge{background:#fff;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;font-family:var(--font-display);color:#5a5a6b;box-shadow:0 2px 6px #3c32461f}.intro-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#1e1a30e0,#322846d1);backdrop-filter:blur(6px);padding:18px;z-index:20}.intro-card{width:min(620px,95vw);max-height:90vh;overflow-y:auto;background:var(--c-cream);border-radius:26px;padding:32px 34px;text-align:center;box-shadow:0 30px 90px #0a081999;animation:k-pop-in .6s cubic-bezier(.22,1.4,.36,1) both}.intro-card .tree{font-size:64px;animation:k-float 3.5s ease-in-out infinite}.intro-card h2{font-family:var(--font-display);font-size:clamp(22px,4.5vw,30px);font-weight:800;color:var(--c-ink);margin:10px 0 16px}.intro-card p{font-size:clamp(15px,2.7vw,17px);line-height:1.7;color:var(--c-ink-soft);margin-bottom:14px;font-weight:500}.intro-card p b{color:var(--c-ink)}.touch-zone{position:absolute;inset:0;pointer-events:none}.joystick{position:absolute;bottom:calc(26px + env(safe-area-inset-bottom));left:24px;width:124px;height:124px;border-radius:50%;background:#fff8ec47;border:2.5px solid rgba(255,248,236,.55);pointer-events:auto;touch-action:none}.joystick .stick{position:absolute;width:56px;height:56px;border-radius:50%;background:#fff8eceb;box-shadow:0 5px 14px #281e3259;left:50%;top:50%;transform:translate(-50%,-50%)}.touch-actions{position:absolute;bottom:calc(34px + env(safe-area-inset-bottom));right:24px;display:flex;flex-direction:column;gap:14px;align-items:center;pointer-events:auto}.touch-btn{width:76px;height:76px;border-radius:50%;background:#ffd366eb;font-family:var(--font-display);font-weight:800;font-size:15px;color:#6b4a12;box-shadow:0 6px #b4821e8c,0 12px 24px #281e324d;display:flex;align-items:center;justify-content:center;touch-action:none}.touch-btn:active{transform:translateY(4px);box-shadow:0 2px #b4821e8c}.touch-btn--jump .touch-btn__glyph{font-size:34px;font-weight:800;line-height:1;margin-top:-2px}.touch-btn.small .touch-btn__glyph{font-size:26px}.touch-btn--interact{width:88px;height:88px;background:#7ee8a0f2;color:#1a4a2e;box-shadow:0 6px #328c508c,0 12px 24px #281e324d;animation:interact-pulse 1.6s ease-in-out infinite}.touch-btn--interact:active{box-shadow:0 2px #328c508c}.touch-btn__glyph{font-size:30px;line-height:1}@keyframes interact-pulse{0%,to{box-shadow:0 6px #328c508c,0 12px 24px #281e324d}50%{box-shadow:0 6px #328c508c,0 14px 28px #50c87873}}.touch-btn.small{width:58px;height:58px;font-size:22px;background:#fff8ecd9}.loading-screen{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:linear-gradient(180deg,#8fd3f4,#fdedc4);z-index:50}.loading-screen .sun{width:84px;height:84px;border-radius:50%;background:radial-gradient(circle at 38% 35%,#fff3d0,#ffd166);box-shadow:0 0 60px 18px #ffd1668c;animation:k-pulse 2s ease-in-out infinite}.loading-screen .label{font-family:var(--font-display);font-weight:800;font-size:19px;color:#5a4a36}.loading-bar{width:min(280px,70vw);height:12px;border-radius:999px;background:#fff9;overflow:hidden}.loading-bar .fill{height:100%;width:40%;border-radius:999px;background:linear-gradient(90deg,#ffd166,#ff8a72);animation:loading-slide 1.3s ease-in-out infinite}@keyframes loading-slide{0%{transform:translate(-110%)}to{transform:translate(290%)}}.k-phone-device{position:absolute;right:max(12px,env(safe-area-inset-right));bottom:max(12px,env(safe-area-inset-bottom));z-index:8}.k-phone-device-shell{display:block;padding:0;border:none;background:transparent;cursor:pointer;transition:transform .14s ease}.k-phone-device-shell:hover{transform:scale(1.04)}.k-phone-device-shell:active{transform:scale(.97)}.k-phone-device-screen{width:clamp(78px,19vw,96px);padding:7px 7px 5px;border-radius:16px;background:linear-gradient(180deg,#fff,#fff8f4);border:3px solid #f4a89a;box-shadow:0 5px #c86e5a38,0 14px 28px #281e3238}.k-phone-app-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.k-phone-app-icon{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:1;font-size:clamp(15px,3.8vw,18px);background:#fff0ebf2;border:1.5px solid rgba(244,168,154,.45);border-radius:11px;transition:transform .1s,background .1s}.k-phone-app-icon:hover{background:#fff;transform:scale(1.06)}.k-phone-app-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#ff5c5c;color:#fff;font-family:var(--font-display);font-weight:800;font-size:9px;line-height:16px;text-align:center;box-shadow:0 2px 6px #c8323266}.k-phone-currency{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:5px;padding:4px 8px;border-radius:999px;background:#ffffffe6;border:1.5px solid rgba(244,168,154,.35);font-family:var(--font-display);font-weight:800;font-size:12px;color:#6b4a12}.k-phone-device.has-badge .k-phone-device-screen{animation:k-phone-nudge 2.4s ease-in-out infinite}.k-phone-device-pulse{position:absolute;top:-3px;right:-3px;width:12px;height:12px;border-radius:50%;background:#ff5c5c;box-shadow:0 0 #ff5c5c8c;animation:k-phone-pulse 1.8s ease-out infinite;pointer-events:none}@keyframes k-phone-nudge{0%,to{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}}@keyframes k-phone-pulse{0%{box-shadow:0 0 #ff5c5c8c}70%{box-shadow:0 0 0 10px #ff5c5c00}to{box-shadow:0 0 #ff5c5c00}}.k-phone-overlay{position:absolute;inset:0;z-index:18;display:flex;align-items:flex-end;justify-content:center;padding:max(12px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left));background:#281e3c59;backdrop-filter:blur(3px)}.k-phone{width:min(380px,100%);max-height:min(78vh,640px);animation:k-pop-in .28s cubic-bezier(.34,1.4,.64,1)}.k-phone-frame{background:linear-gradient(180deg,#ffe8dc,#fff5ef);border-radius:clamp(24px,6vw,32px);padding:12px 12px 10px;box-shadow:0 10px #b4785a33,0 24px 50px #281e3259;border:4px solid rgba(255,255,255,.85);display:flex;flex-direction:column;max-height:inherit}.k-phone-nav{display:flex;align-items:center;gap:6px;background:#fff;border-radius:999px;padding:6px 8px;margin-bottom:10px;box-shadow:0 2px 8px #3c324614}.k-phone-tab{position:relative;width:clamp(36px,9vw,42px);height:clamp(36px,9vw,42px);border-radius:50%;font-size:clamp(16px,4vw,19px);display:flex;align-items:center;justify-content:center;background:transparent;transition:background .15s,transform .12s;flex-shrink:0}.k-phone-tab-badge{position:absolute;top:0;right:0;min-width:14px;height:14px;padding:0 3px;border-radius:999px;background:#ff5c5c;color:#fff;font-size:8px;font-weight:800;line-height:14px}.k-phone-tab.active{background:#e8f4ff;box-shadow:inset 0 0 0 2px #7ec8e3}.k-phone-tab:hover{transform:scale(1.08)}.k-phone-close{margin-left:auto;width:clamp(34px,8vw,38px);height:clamp(34px,8vw,38px);border-radius:50%;background:#5ee6c8;color:#2d2868;font-weight:800;font-size:16px;box-shadow:0 3px #3aab96;flex-shrink:0}.k-phone-screen{flex:1;overflow-y:auto;background:linear-gradient(180deg,#f0faff,#fff);border-radius:18px;padding:16px 14px;min-height:180px}.k-phone-title{font-family:var(--font-display);font-weight:800;font-size:clamp(18px,4vw,22px);color:#3c3246;margin-bottom:6px}.k-phone-desc{font-size:13.5px;color:var(--c-ink-soft);line-height:1.5;margin-bottom:14px}.k-phone-stat{text-align:center;margin-bottom:14px}.k-phone-stat-num{display:block;font-family:var(--font-display);font-weight:800;font-size:36px;color:#d97f1e}.k-phone-stat-lbl{font-size:13px;color:var(--c-ink-soft);font-weight:600}.k-phone-list{list-style:none;display:flex;flex-direction:column;gap:8px}.k-phone-list li{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;padding:8px 10px;background:#fffc;border-radius:12px;color:var(--c-ink-soft)}.k-phone-list li.done{color:var(--c-ink)}.k-phone-inbox{list-style:none;display:flex;flex-direction:column;gap:8px;margin:0;padding:0}.k-phone-inbox-item{display:flex;gap:10px;align-items:flex-start;width:100%;text-align:left;padding:10px 12px;background:#ffffffeb;border-radius:14px;border:1.5px solid rgba(126,200,227,.35);transition:background .12s}.k-phone-inbox-item:hover{background:#fff}.k-phone-inbox-icon{font-size:22px;flex-shrink:0}.k-phone-inbox-title{font-family:var(--font-display);font-weight:800;font-size:13.5px;color:var(--c-ink)}.k-phone-inbox-body{font-size:12.5px;color:var(--c-ink-soft);line-height:1.4;margin-top:2px}.k-phone-empty{text-align:center;padding:24px 12px;color:var(--c-ink-soft)}.k-phone-empty span{font-size:36px;display:block;margin-bottom:8px}.k-phone-controls-card{margin-top:12px;padding:14px 12px 12px;background:linear-gradient(165deg,#f8fcff,#eef6fb);border-radius:16px;border:2px solid rgba(126,200,227,.35);box-shadow:inset 0 1px #ffffffe6}.k-phone-controls-title{font-family:var(--font-display);font-weight:800;font-size:14px;margin:0 0 4px;color:var(--c-ink)}.k-phone-controls-lead{font-size:12.5px;line-height:1.45;color:var(--c-ink-soft);margin:0 0 12px}.k-phone-controls-grid{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.k-phone-control-item{display:flex;gap:10px;align-items:flex-start;padding:10px 11px;background:#ffffffeb;border-radius:12px;border:1.5px solid rgba(180,210,230,.45)}.k-phone-control-icon{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:20px;background:linear-gradient(145deg,#e8f6fc,#d4ebf8);border-radius:10px;border:1.5px solid rgba(126,200,227,.4)}.k-phone-control-name{font-family:var(--font-display);font-weight:800;font-size:13px;color:var(--c-ink);margin-bottom:2px}.k-phone-control-desc{font-size:12px;line-height:1.4;color:var(--c-ink-soft)}.k-phone-controls-tip{margin:10px 0 0;padding:9px 11px;font-size:11.5px;line-height:1.4;color:#4a6a82;background:#fff8dca6;border-radius:10px;border:1px dashed rgba(232,168,44,.45)}.k-phone-support-link{width:100%;text-align:center}.k-phone-support-top{margin:0 0 14px;padding:12px 14px;border-radius:14px;background:#ffffffeb;border:2px solid rgba(126,200,227,.45);font-family:var(--font-display);font-weight:800;font-size:14px}.k-phone-back{background:none;border:none;color:#3b82c4;font-weight:700;font-size:13px;margin-bottom:8px;padding:0}.k-phone-balance{text-align:center;font-family:var(--font-display);font-weight:800;font-size:clamp(32px,8vw,42px);color:#d97f1e;margin:12px 0 18px}.k-phone-cta{display:block;width:100%;padding:14px;border-radius:999px;background:linear-gradient(180deg,#b197fc,#8d6fe8);color:#fff;font-family:var(--font-display);font-weight:800;font-size:15px;box-shadow:0 4px #6a4cc4}.k-phone-family-card{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:14px;margin-bottom:12px}.k-phone-avatar-dot{width:44px;height:44px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px #0000001f}.k-phone-family-name{font-family:var(--font-display);font-weight:800;font-size:16px}.k-phone-family-role{font-size:12px;color:var(--c-ink-soft);text-transform:capitalize}.k-phone-nav-scroll{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}.k-phone-nav-scroll::-webkit-scrollbar{display:none}.k-phone-support-zone{display:flex;flex-direction:column;gap:8px}.k-phone-label{font-size:12px;font-weight:700;color:var(--c-ink-soft);margin-top:4px}.k-phone-select,.k-phone-input,.k-phone-textarea{width:100%;padding:10px 12px;border-radius:12px;border:2px solid #e8dff5;background:#fff;font-family:var(--font-body);font-size:14px;outline:none}.k-phone-textarea{resize:vertical;min-height:88px}.k-phone-select:focus,.k-phone-input:focus,.k-phone-textarea:focus{border-color:#9d8df1}.k-phone-support-err{font-size:13px;color:#e84d6f;font-weight:600}.k-phone-support-ok{text-align:center;padding:16px 8px;background:#eefaf4;border-radius:14px;font-size:14px;color:#2d6a4a;font-weight:600}.k-phone-support-ok span{font-size:28px;display:block;margin-bottom:8px}.k-phone-link-btn{margin-top:10px;font-size:13px;color:#3c7a9e;font-weight:700;text-decoration:underline}.k-phone-account-zone{margin-top:16px}.k-phone-account-divider{height:1px;background:linear-gradient(90deg,transparent,#d4cff5,transparent);margin-bottom:12px}.k-phone-account-label{font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#8a7a9a;margin-bottom:4px}.k-phone-account-email{font-size:13px;color:var(--c-ink-soft);margin-bottom:10px}.k-phone-logout-card{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border-radius:14px;background:#ffffffe6;border:2px solid #f0e8f8;text-align:left;transition:border-color .15s,background .15s}.k-phone-logout-card:hover{border-color:#e8c4d0;background:#fff5f7}.k-phone-logout-icon{font-size:22px;flex-shrink:0}.k-phone-logout-card strong{display:block;font-family:var(--font-display);font-size:15px;color:var(--c-ink)}.k-phone-logout-card small{display:block;font-size:12px;color:#8a7a9a;margin-top:2px}.kira-chat-wrap{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding:12px 12px max(18vh,80px);background:linear-gradient(180deg,transparent 40%,rgba(20,40,50,.35));pointer-events:auto;z-index:25}.kira-chat{width:min(480px,96vw);max-height:min(62vh,520px);display:flex;flex-direction:column;background:var(--c-cream);border-radius:22px;border:3px solid #9af0dd;box-shadow:0 20px 60px #140f2373;animation:k-pop-in .4s cubic-bezier(.22,1.4,.36,1) both;overflow:hidden}.kira-chat-head{display:flex;align-items:center;gap:10px;padding:12px 14px;background:linear-gradient(135deg,#1f9a82,#4adbb8);color:#fff}.kira-chat-avatar{font-size:28px}.kira-chat-title{font-family:var(--font-display);font-weight:800;font-size:15px}.kira-chat-sub{font-size:11.5px;opacity:.9}.kira-chat-close{margin-left:auto;width:34px;height:34px;border-radius:50%;background:#ffffff40;color:#fff;font-weight:800}.kira-chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;min-height:120px;max-height:36vh}.kira-bubble{display:flex;gap:8px;align-items:flex-start;max-width:92%}.kira-bubble.user{align-self:flex-end;flex-direction:row-reverse}.kira-bubble p{margin:0;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.45}.kira-bubble.kira p{background:#e8faf5;border:2px solid #b8f0e4;color:#1e4a40}.kira-bubble.user p{background:#fff;border:2px solid #d8e8f0;color:var(--c-ink)}.kira-bubble-icon{font-size:20px;flex-shrink:0}.kira-typing{font-style:italic;opacity:.75}.kira-suggestions{display:flex;flex-wrap:wrap;gap:6px;padding:0 12px 8px}.kira-suggest{font-size:11.5px;padding:6px 10px;border-radius:999px;background:#f0faf8;border:1.5px solid #9af0dd;color:#1f6b5c;font-weight:600}.kira-chat-input{display:flex;gap:8px;padding:10px 12px 12px;border-top:2px solid #e8f5f0;background:#fff}.kira-chat-input input{flex:1;border:2px solid #d0ebe4;border-radius:14px;padding:10px 12px;font-size:14px;font-family:var(--font-body)}.kira-chat-input .k-btn{padding:10px 16px;font-size:13px;white-space:nowrap}@media(max-width:640px){.interact-prompt{bottom:max(24vh,150px);font-size:13px}.interact-prompt--touch{bottom:max(26vh,168px);font-size:14px}.interact-prompt__hint{font-size:10px}.kira-chat-wrap{padding-bottom:max(22vh,calc(env(safe-area-inset-bottom) + 100px))}.k-phone-device{bottom:max(14px,env(safe-area-inset-bottom))}.touch-zone{padding-bottom:env(safe-area-inset-bottom)}.map-overlay{padding:max(52px,calc(env(safe-area-inset-top) + 44px)) 10px max(100px,calc(env(safe-area-inset-bottom) + 88px))}.map-shell{max-height:none}.map-body{flex-direction:column}.map-view{flex:none;width:100%;max-width:220px;margin:0 auto;aspect-ratio:1;border-right:none;border-bottom:2px solid rgba(60,50,70,.08)}.map-nav-list{max-height:42vh}.map-nav-label{font-size:12px}}.map-overlay{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:clamp(14px,3vw,34px);overflow:hidden;background:#1c2538b8;backdrop-filter:blur(12px) saturate(.7)}.map-overlay:before{content:"";position:absolute;z-index:0;top:57%;left:50%;width:min(760px,76vw);height:min(900px,92vh);border-radius:46% 44% 36% 38%;background:radial-gradient(circle at 28% 18%,rgba(255,225,209,.7),transparent 31%),linear-gradient(145deg,#efb094,#df927d);box-shadow:0 35px 80px #1b1b3959;opacity:.96;transform:translate(-46%,-50%) rotate(11deg)}.map-overlay:after{content:"";position:absolute;z-index:0;top:37%;left:calc(50% + 245px);width:150px;height:330px;border-radius:999px;background:linear-gradient(120deg,#f2b398,#df927d);box-shadow:inset 12px 0 24px #ffe0cf3d;transform:rotate(-8deg)}.map-shell{position:relative;z-index:1;display:block;width:min(610px,calc(100vw - 28px));height:min(820px,calc(100dvh - clamp(28px,6vw,68px)));min-height:520px;max-height:none;overflow:hidden;border:14px solid #ffd9cf;border-radius:54px;background:#2db9db;box-shadow:0 0 0 5px #e9958c,0 36px 90px #0b192b80,0 12px #97444857;animation:map-open .48s cubic-bezier(.2,.9,.25,1.12) both;isolation:isolate}@keyframes map-open{0%{opacity:0;transform:translateY(26px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}.map-brand{position:absolute;top:24px;left:28px;z-index:8;display:none;flex-direction:column;color:#fff;line-height:.9;text-shadow:0 3px 16px rgba(0,74,106,.38);pointer-events:none}.map-brand span{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.3em}.map-brand strong{font-family:var(--font-display);font-size:25px;letter-spacing:.04em}.map-toolbar{position:absolute;z-index:12;top:20px;left:50%;display:flex;align-items:center;gap:5px;padding:7px;border:2px solid rgba(255,255,255,.92);border-radius:999px;background:#fffffff5;box-shadow:0 8px #33336c33,0 18px 40px #192d5040;transform:translate(-50%)}.map-tool{position:relative;display:grid;place-items:center;width:48px;height:48px;flex:0 0 48px;border-radius:50%;color:#5d5794;transition:transform .14s ease,color .14s ease,background .14s ease}.map-tool svg,.map-places-head button svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}.map-tool:hover{background:#f0effd;transform:translateY(-2px)}.map-tool:active{transform:scale(.92)}.map-tool.active{color:#168ac2;background:#d9f1ff;box-shadow:inset 0 0 0 2px #ffffffe6}.map-tool--close{color:#fff;background:#35c6ad;box-shadow:0 4px #1a9d89}.map-tool--close:hover{color:#fff;background:#42d4ba}.map-toolbar-divider{width:2px;height:32px;margin:0 2px;border-radius:99px;background:#e5e2f3}.map-stage{position:absolute;inset:0;overflow:hidden;background:radial-gradient(circle at 18% 15%,rgba(255,255,255,.18),transparent 26%),#26b9dd;cursor:grab;touch-action:none}.map-stage:active{cursor:grabbing}.map-canvas{position:absolute;top:50%;left:50%;width:max(100%,100dvh);aspect-ratio:1;transform-origin:center;will-change:transform}.map-artwork{position:absolute;inset:0;display:block;width:100%;height:100%}.map-pin{position:absolute;z-index:4;display:block;width:0;height:0;overflow:visible;border:0;background:transparent;box-shadow:none;filter:drop-shadow(0 5px 5px rgba(24,55,71,.3));transform:none}.map-pin:active{transform:none}.map-pin-marker{position:absolute;top:0;left:0;display:grid;place-items:center;width:50px;height:50px;border:5px solid #fff;border-radius:50% 50% 50% 12px;background:#fff7ee;box-shadow:0 0 0 6px #5a5096;transform:translate(-50%,-88%) rotate(-45deg);transition:transform .18s cubic-bezier(.2,.9,.3,1.3),box-shadow .18s ease}.map-pin-icon{font-size:22px;line-height:1;filter:none;transform:rotate(45deg)}.map-pin-pulse{position:absolute;top:0;left:0;width:16px;height:16px;border:4px solid #fff;border-radius:50%;background:#5a5096;box-shadow:0 3px 8px #2828504d;transform:translate(-50%,-50%)}.map-pin-label{position:absolute;top:14px;left:0;min-width:max-content;max-width:170px;padding:7px 12px;border-radius:11px;color:#3b3562;background:#fffffff5;box-shadow:0 5px 18px #18374738;font-family:var(--font-display);font-size:13px;font-weight:800;line-height:1;opacity:0;transform:translate(-50%,8px) scale(.92);transition:opacity .16s ease,transform .16s ease;pointer-events:none}.map-pin:hover .map-pin-label,.map-pin--active .map-pin-label{opacity:1;transform:translate(-50%,8px) scale(1)}.map-pin--active{z-index:7;box-shadow:none;transform:none}.map-pin--active .map-pin-marker{box-shadow:0 0 0 7px #ff7279,0 12px 25px #852b4147;transform:translate(-50%,-96%) rotate(-45deg) scale(1.14)}.map-pin--active .map-pin-pulse{background:#ff7279;animation:map-pin-pulse 1.5s ease-out infinite}@keyframes map-pin-pulse{0%{box-shadow:0 0 #ff7279a6}75%,to{box-shadow:0 0 0 18px #ff727900}}.map-player{position:absolute;z-index:6;display:grid;place-items:center;width:43px;height:43px;border:5px solid #fff;border-radius:50%;color:#fff;background:#1ec9e6;box-shadow:0 0 0 5px #484b97d9,0 8px 18px #18374752;animation:none;transform:translate(-50%,-50%);pointer-events:none}.map-player-face{font-family:var(--font-display);font-size:20px;font-weight:800;line-height:1}.map-player-arrow{position:absolute;top:-20px;left:50%;width:0;height:0;border-right:8px solid transparent;border-bottom:13px solid #4d4a90;border-left:8px solid transparent;transform:translate(-50%) rotate(var(--map-player-rotation));transform-origin:50% 34px}.map-pan{position:absolute;z-index:9;display:grid;place-items:center;width:52px;height:52px;border:3px solid rgba(255,255,255,.85);border-radius:50%;color:#4b4786;background:#fffffff0;box-shadow:0 7px 18px #1c345238;font-family:var(--font-display);font-size:25px;font-weight:800;transition:transform .12s ease}.map-pan:hover{transform:scale(1.08)}.map-pan:active{transform:scale(.92)}.map-pan--north{top:96px;left:50%;transform:translate(-50%)}.map-pan--north:hover{transform:translate(-50%) scale(1.08)}.map-pan--north:active{transform:translate(-50%) scale(.92)}.map-pan--south{bottom:24px;left:50%;transform:translate(-50%)}.map-pan--south:hover{transform:translate(-50%) scale(1.08)}.map-pan--south:active{transform:translate(-50%) scale(.92)}.map-pan--west{top:50%;left:24px;transform:translateY(-50%)}.map-pan--west:hover{transform:translateY(-50%) scale(1.08)}.map-pan--west:active{transform:translateY(-50%) scale(.92)}.map-pan--east{top:50%;right:24px;transform:translateY(-50%)}.map-pan--east:hover{transform:translateY(-50%) scale(1.08)}.map-pan--east:active{transform:translateY(-50%) scale(.92)}.map-zoom{position:absolute;right:24px;bottom:24px;z-index:10;display:flex;flex-direction:column;overflow:hidden;border:2px solid rgba(255,255,255,.85);border-radius:16px;background:#fffffff0;box-shadow:0 7px 18px #1c345238}.map-zoom button{width:43px;height:40px;color:#4b4786;font-size:24px;font-weight:800}.map-zoom button+button{border-top:1px solid #dedbed}.map-place-card{position:absolute;bottom:24px;left:24px;z-index:11;display:flex;align-items:center;gap:13px;width:min(380px,calc(100% - 170px));padding:13px 17px 13px 13px;border:3px solid rgba(255,255,255,.82);border-radius:22px;background:#fffffff2;box-shadow:0 10px 30px #18374747;backdrop-filter:blur(8px)}.map-place-card-icon{display:grid;place-items:center;width:52px;height:52px;flex:0 0 52px;border-radius:16px;background:#ffe5df;font-size:27px}.map-place-card-copy{display:flex;min-width:0;flex-direction:column}.map-place-card-copy>span{color:#168ac2;font-family:var(--font-display);font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.map-place-card-copy strong{color:#3b3562;font-family:var(--font-display);font-size:18px;line-height:1.1}.map-place-card-copy small{margin-top:3px;overflow:hidden;color:#6e6988;font-size:11px;font-weight:700;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.map-drag-hint{position:absolute;bottom:30px;left:50%;z-index:8;padding:8px 13px;border-radius:999px;color:#ffffffe6;background:#294b6973;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;transform:translate(-50%);backdrop-filter:blur(5px);pointer-events:none}.map-places{position:absolute;top:18px;right:18px;bottom:18px;z-index:20;display:flex;width:min(360px,calc(100% - 36px));flex-direction:column;overflow:hidden;border:3px solid rgba(255,255,255,.86);border-radius:26px;background:#fffaf3f7;box-shadow:0 24px 60px #18284861;opacity:0;transform:translate(calc(100% + 30px));transition:transform .28s cubic-bezier(.2,.9,.3,1),opacity .2s ease;pointer-events:none}.map-places--open{opacity:1;transform:translate(0);pointer-events:auto}.map-places-head{display:flex;align-items:center;justify-content:space-between;padding:18px 17px 13px 20px;border-bottom:1px solid #e9dfd4}.map-places-head>div{display:flex;flex-direction:column}.map-places-head span{color:#df6d6f;font-family:var(--font-display);font-size:9px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.map-places-head strong{color:#3b3562;font-family:var(--font-display);font-size:19px}.map-places-head button{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;color:#5b568b;background:#efedf9}.map-places-list{flex:1;min-height:0;padding:8px;overflow-y:auto;overscroll-behavior:contain}.map-places-list>button{display:grid;width:100%;grid-template-columns:42px minmax(0,1fr) auto;align-items:center;gap:10px;padding:9px 10px;border-radius:15px;text-align:left;transition:background .12s ease,transform .12s ease}.map-places-list>button:hover,.map-places-list>button.active{background:#ffe7df}.map-places-list>button:active{transform:scale(.98)}.map-places-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:13px;background:#fff;box-shadow:0 3px 10px #3930581a;font-size:21px}.map-places-name{display:flex;min-width:0;flex-direction:column}.map-places-name strong{overflow:hidden;color:#3b3562;font-family:var(--font-display);font-size:13px;text-overflow:ellipsis;white-space:nowrap}.map-places-name small{overflow:hidden;color:#827b91;font-size:10px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.map-places-distance{color:#168ac2;font-family:var(--font-display);font-size:11px;font-weight:800;white-space:nowrap}@media(max-width:700px){.map-overlay{padding:0;background:#26b9dd;backdrop-filter:none}.map-overlay:before,.map-overlay:after{display:none}.map-shell{width:100vw;height:100dvh;min-height:0;border:0;border-radius:0;box-shadow:none}.map-brand{display:none}.map-toolbar{top:max(14px,env(safe-area-inset-top));right:12px;left:12px;justify-content:center;padding:6px;transform:none}.map-tool{width:44px;height:44px;flex-basis:44px}.map-tool svg{width:22px;height:22px}.map-canvas{width:max(100%,100dvh)}.map-pin-marker{width:44px;height:44px;border-width:4px;box-shadow:0 0 0 5px #5a5096}.map-pin-icon{font-size:19px}.map-pin--active .map-pin-marker{box-shadow:0 0 0 6px #ff7279,0 10px 20px #852b4147}.map-pin-label{max-width:130px;padding:6px 9px;font-size:11px}.map-player{width:39px;height:39px;border-width:4px;box-shadow:0 0 0 4px #484b97d9,0 7px 16px #1837474d}.map-pan{width:48px;height:48px;font-size:22px}.map-pan--north{top:max(82px,calc(env(safe-area-inset-top) + 68px))}.map-pan--south{bottom:max(16px,env(safe-area-inset-bottom))}.map-pan--west{left:12px}.map-pan--east{right:12px}.map-zoom,.map-drag-hint{display:none}.map-place-card{right:12px;bottom:max(76px,calc(env(safe-area-inset-bottom) + 66px));left:12px;width:auto;padding:10px 13px 10px 10px;border-width:2px;border-radius:18px}.map-place-card-icon{width:44px;height:44px;flex-basis:44px;border-radius:13px;font-size:23px}.map-place-card-copy strong{font-size:16px}.map-place-card-copy small{font-size:10px}.map-places{top:auto;right:8px;bottom:max(8px,env(safe-area-inset-bottom));left:8px;width:auto;height:min(56dvh,470px);border-radius:24px;opacity:0;transform:translateY(calc(100% + 24px))}.map-places--open{opacity:1;transform:translateY(0)}}@media(max-width:390px){.map-toolbar{gap:2px}.map-tool{width:42px;height:42px;flex-basis:42px}.map-toolbar-divider{margin:0}}@media(prefers-reduced-motion:reduce){.map-shell,.map-pin--active .map-pin-pulse{animation:none}}.splash{position:absolute;inset:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;background:linear-gradient(165deg,#3b337f,#4a3d8f 45%,#2d2868);color:#fff}.splash-brand{text-align:center}.splash-pre{font-family:var(--font-display);font-weight:700;font-size:clamp(10px,2vw,13px);letter-spacing:5px;opacity:.85;margin-bottom:8px}.splash-title{line-height:.95}.splash-k{display:block;font-family:var(--font-display);font-weight:800;font-size:clamp(36px,8vw,58px);letter-spacing:6px;color:#fff}.splash-club{display:block;font-family:var(--font-display);font-weight:800;font-size:clamp(52px,12vw,96px);letter-spacing:2px;color:#5ee6c8;text-shadow:0 4px 0 rgba(0,0,0,.15)}.splash-progress{display:flex;flex-direction:column;align-items:center;gap:14px}.splash-num{font-family:var(--font-display);font-weight:800;font-size:42px;letter-spacing:2px;min-width:64px;text-align:center}.splash-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:splash-spin .85s linear infinite}@keyframes splash-spin{to{transform:rotate(360deg)}}.splash-legal{position:absolute;bottom:max(20px,env(safe-area-inset-bottom));left:24px;right:24px;text-align:center;font-size:11.5px;line-height:1.55;opacity:.75;max-width:520px;margin:0 auto}.splash-legal-accent{color:#5ee6c8}.landing{position:absolute;inset:0;z-index:12;display:flex;align-items:center;justify-content:center;pointer-events:none}.landing-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,rgba(255,248,236,.92) 0%,rgba(255,248,236,.55) 35%,transparent 62%),linear-gradient(to bottom,rgba(168,221,242,.35) 0%,transparent 40%);pointer-events:none}.landing-content{position:relative;z-index:2;text-align:center;padding:24px;max-width:520px;pointer-events:auto}.landing-welcome{font-family:var(--font-display);font-weight:600;font-size:clamp(16px,3vw,20px);color:#3c3246;margin-bottom:4px}.landing-title{font-family:var(--font-display);font-weight:800;font-size:clamp(42px,10vw,72px);line-height:1;color:#3c3246;margin-bottom:8px;text-shadow:0 2px 0 rgba(255,255,255,.8)}.landing-k{color:#e84d6f}.landing-tagline{font-size:clamp(14px,2.5vw,17px);color:#6d6280;font-weight:600;margin-bottom:28px}.landing-cta{display:inline-flex;align-items:center;justify-content:center;gap:12px;width:min(100%,380px);padding:18px 32px;border-radius:999px;font-family:var(--font-display);font-weight:800;font-size:clamp(17px,3vw,20px);color:#2d2868;background:#fff;box-shadow:0 6px #3c32462e,0 16px 40px #281e3240;transition:transform .12s ease,box-shadow .12s ease;cursor:pointer;border:none}.landing-cta:hover{transform:translateY(-3px) scale(1.02)}.landing-cta:active{transform:translateY(2px);box-shadow:0 3px #3c32462e}.landing-cta-icon{font-size:1.3em}.landing-sub{margin-top:18px;font-size:14px;color:#6d6280;font-weight:600}.landing-link{background:none;border:none;color:#3c7a9e;font-family:var(--font-display);font-weight:800;font-size:inherit;text-decoration:underline;cursor:pointer;padding:0}.landing-link:hover{color:#e84d6f}.auth-screen{position:absolute;inset:0;z-index:14;display:flex;align-items:center;justify-content:center;padding:16px;overflow-y:auto;background:linear-gradient(to bottom,#a8ddf28c,#fff8ece0 55%,#fff8ecf2);backdrop-filter:blur(4px)}.auth-card{position:relative;width:min(520px,96vw);max-height:90vh;overflow-y:auto;padding:28px 30px;display:flex;flex-direction:column;gap:14px}.avatar-card{width:min(560px,96vw)}.auth-back{position:absolute;top:14px;left:14px;width:40px;height:40px;border-radius:50%;background:#fff8ece6;font-size:20px;font-weight:800;box-shadow:var(--shadow-pop);border:none;cursor:pointer;color:var(--c-ink)}.auth-title{font-family:var(--font-display);font-weight:800;font-size:clamp(22px,4vw,28px);color:var(--c-ink);margin-top:8px}.auth-sub{font-size:14.5px;color:var(--c-ink-soft);line-height:1.5;margin-bottom:4px}.auth-error{background:#fdeef2;border-left:4px solid #e84d6f;border-radius:10px;padding:10px 14px;font-size:14px;color:#8a3a4a;font-weight:600}.auth-switch{text-align:center;font-size:14px;color:var(--c-ink-soft);margin-top:4px}.auth-card-google{text-align:center;align-items:center}.auth-hero-icon{font-size:42px;margin-top:4px;line-height:1}.auth-trust{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--c-ink-soft);margin-top:4px}.auth-terms{font-size:11.5px;color:#8a7a9a;line-height:1.45;margin-top:2px;max-width:36ch}.landing-google-wrap{width:min(320px,88vw);margin:8px 0 4px}.google-sign-in{display:inline-flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:13px 20px;border-radius:999px;background:#fff;border:2px solid #e8e0d4;box-shadow:0 4px #d8cdb4,0 10px 24px #3c32461f;font-family:var(--font-display);font-weight:800;font-size:15px;color:var(--c-ink);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.google-sign-in:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 5px #d8cdb4,0 14px 28px #3c324629}.google-sign-in:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #d8cdb4,0 6px 16px #3c32461a}.google-sign-in:disabled{opacity:.65;cursor:wait}.google-sign-in-lg{padding:15px 22px;font-size:16px}.google-sign-in-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#fff;flex-shrink:0}.google-sign-in-text{white-space:nowrap}.avatar-screen .auth-card{margin-top:12px}.wave-transition{position:absolute;inset:0;z-index:22;overflow:hidden;pointer-events:none}.wave-sky{position:absolute;inset:0;background:linear-gradient(180deg,#7ec8e3,#eef6ff 18%,#fff 28%)}.wave-reveal .wave-layer{position:absolute;left:-8%;right:-8%;height:42%;border-radius:50% 50% 0 0/18% 18% 0 0;transition:transform .12s linear;will-change:transform}.wave-reveal .wave-l1{bottom:52%;background:#d4cff5}.wave-reveal .wave-l2{bottom:38%;background:#a89ee8}.wave-reveal .wave-l3{bottom:24%;background:#7b6fd4}.wave-reveal .wave-l4{bottom:10%;background:#5248a8}.wave-reveal .wave-l5{bottom:-4%;background:#3b337f}
