: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 .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:center;justify-content:center;background:#282438b3;backdrop-filter:blur(5px);padding:18px}.map-card{position:relative;width:min(520px,92vw);aspect-ratio:1;background:radial-gradient(circle at 50% 45%,#7ec46a,#6fb85f 38%,#f2d49b 56%,#6fd6d0 62%,#2e8fb8);border-radius:26px;border:6px solid #fff8ec;box-shadow:0 30px 80px #140f238c;animation:k-pop-in .4s cubic-bezier(.22,1.4,.36,1) both;overflow:hidden}.map-title{position:absolute;top:14px;left:50%;transform:translate(-50%);font-family:var(--font-display);font-weight:800;font-size:17px;color:#fff;background:#3c32468c;padding:6px 18px;border-radius:999px;white-space:nowrap}.map-pin{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:1px;font-size:11px;font-family:var(--font-display);font-weight:700;color:#3c3246;text-align:center}.map-pin .dot{font-size:20px;filter:drop-shadow(0 3px 4px rgba(60,50,70,.4))}.map-pin .lbl{background:#fff8eceb;padding:2px 8px;border-radius:999px;white-space:nowrap}.map-player{position:absolute;width:16px;height:16px;border-radius:50%;background:#ff5470;border:3.5px solid #fff;transform:translate(-50%,-50%);box-shadow:0 0 0 5px #ff547059;animation:k-pulse 1.6s ease-in-out infinite}.map-close{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:50%;background:#fff8ecf2;font-size:17px;font-weight:800;box-shadow:var(--shadow-pop)}.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.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}.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)}}.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}
