.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:var(--color-bg)}.login-page__title{font-size:2.4rem;color:var(--color-primary);margin-bottom:.5rem}.login-page__tagline{color:var(--color-text);opacity:.6;margin-bottom:2rem;font-size:1rem}.login-page__card{background:#ffffff0d;border-radius:1rem;padding:2rem;width:100%;max-width:380px}.login-page__tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid rgba(255,255,255,.1)}.login-page__tab{flex:1;padding:.75rem;background:none;border:none;color:var(--color-text);opacity:.5;font-size:1rem;cursor:pointer;transition:opacity .2s,border-bottom .2s;border-bottom:2px solid transparent;margin-bottom:-2px}.login-page__tab--active{opacity:1;border-bottom-color:var(--color-primary)}.login-page__form{display:flex;flex-direction:column;gap:1rem}.login-page__input{padding:.85rem 1rem;border-radius:.6rem;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:var(--color-text);font-size:1rem;outline:none;transition:border-color .2s}.login-page__input:focus{border-color:var(--color-primary)}.login-page__btn{padding:.85rem;border-radius:.6rem;border:none;background:var(--color-primary);color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.login-page__btn:disabled{opacity:.5;cursor:not-allowed}.login-page__divider{text-align:center;color:var(--color-text);opacity:.4;font-size:.85rem;margin:.5rem 0}.login-page__social{display:flex;flex-direction:column;gap:.6rem}.login-page__social-btn{padding:.75rem;border-radius:.6rem;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:var(--color-text);font-size:.95rem;cursor:pointer;transition:background .2s}.login-page__social-btn:hover{background:#ffffff1a}.login-page__error{background:#e74c3c26;color:#e74c3c;padding:.6rem;border-radius:.5rem;text-align:center;font-size:.9rem}.catalog{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg);padding:1rem 1rem 5rem}.catalog__header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0 1rem}.catalog__title{font-size:1.5rem;color:var(--color-text)}.catalog__filters{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:1rem;-webkit-overflow-scrolling:touch}.catalog__chip{flex-shrink:0;padding:.45rem 1rem;border-radius:2rem;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:var(--color-text);font-size:.85rem;cursor:pointer;transition:all .2s}.catalog__chip--active{background:var(--color-primary);border-color:var(--color-primary)}.catalog__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.catalog__card{background:#ffffff0f;border-radius:.8rem;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.catalog__card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #6c5ce733}.catalog__thumb{width:100%;aspect-ratio:16/10;background:#6c5ce726;display:flex;align-items:center;justify-content:center;font-size:2.5rem}.catalog__card-body{padding:.6rem .75rem}.catalog__card-title{color:var(--color-text);font-size:.95rem;font-weight:600;margin-bottom:.2rem}.catalog__card-meta{color:var(--color-text);opacity:.5;font-size:.75rem}.catalog__empty{text-align:center;color:var(--color-text);opacity:.4;padding:3rem}.profile-page{display:flex;flex-direction:column;min-height:100vh;padding:1.5rem 1rem 5rem;background:var(--color-bg)}.profile__avatar{width:100px;height:100px;border-radius:50%;background:var(--color-primary);margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:2.8rem}.profile__name{text-align:center;color:var(--color-text);font-size:1.4rem;font-weight:700;margin-bottom:.25rem}.profile__role{text-align:center;color:var(--color-text);opacity:.5;font-size:.85rem;margin-bottom:1.5rem}.profile__section{margin-bottom:1.5rem}.profile__section-title{color:var(--color-text);opacity:.6;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;padding:0 .25rem}.profile__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.profile__stat{background:#ffffff0f;border-radius:.7rem;padding:.75rem;text-align:center}.profile__stat-value{color:var(--color-primary);font-size:1.4rem;font-weight:700}.profile__stat-label{color:var(--color-text);opacity:.5;font-size:.75rem}.profile__clan{display:flex;align-items:center;gap:.75rem;background:#ffffff0f;border-radius:.7rem;padding:.85rem 1rem}.profile__clan-badge{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem}.profile__clan-name{color:var(--color-text);font-weight:600}.profile__logout{margin-top:auto;padding:.85rem;border-radius:.6rem;border:1px solid rgba(231,76,60,.3);background:#e74c3c1a;color:#e74c3c;font-size:1rem;cursor:pointer;transition:background .2s}.profile__logout:hover{background:#e74c3c33}.clans-page{display:flex;flex-direction:column;min-height:100vh;padding:1.5rem 1rem 5rem;background:var(--color-bg)}.clans__title{font-size:1.5rem;color:var(--color-text);margin-bottom:1.5rem}.clans__picker{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:2rem}.clans__option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.2rem;border-radius:.8rem;border:2px solid rgba(255,255,255,.08);background:#ffffff0a;cursor:pointer;transition:all .2s}.clans__option--selected{border-color:var(--color-primary);background:#6c5ce71a}.clans__option-emoji{font-size:2rem}.clans__option-name{color:var(--color-text);font-weight:600;font-size:.95rem}.clans__section-title{color:var(--color-text);opacity:.6;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.clans__matches{display:flex;flex-direction:column;gap:.6rem}.clans__match{display:flex;align-items:center;gap:.75rem;background:#ffffff0f;border-radius:.7rem;padding:.85rem 1rem}.clans__match-versus{display:flex;align-items:center;gap:.5rem;flex:1}.clans__match-clan{font-size:1.4rem}.clans__match-vs{color:var(--color-text);opacity:.4;font-size:.8rem}.clans__match-score{color:var(--color-primary);font-weight:700;font-size:1rem}.clans__match-status{font-size:.75rem;padding:.2rem .6rem;border-radius:1rem;background:#ffffff1a;color:var(--color-text);opacity:.6}.clans__match-status--active{background:#6c5ce733;color:var(--color-primary);opacity:1}.clans__join-btn{padding:.75rem;border-radius:.6rem;border:none;background:var(--color-primary);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;margin-top:1rem}.clans__join-btn:disabled{opacity:.5}.clans__empty{text-align:center;color:var(--color-text);opacity:.4;padding:2rem}.supervisor{display:flex;flex-direction:column;min-height:100vh;padding:1.5rem 1rem 5rem;background:var(--color-bg)}.supervisor__title{font-size:1.5rem;color:var(--color-text);margin-bottom:1.5rem}.supervisor__code-box{background:#6c5ce71a;border:1px solid rgba(108,92,231,.3);border-radius:.7rem;padding:1rem;margin-bottom:1.5rem;text-align:center}.supervisor__code-label{color:var(--color-text);opacity:.6;font-size:.8rem;margin-bottom:.4rem}.supervisor__code{color:var(--color-primary);font-size:1.8rem;font-weight:700;font-family:monospace;letter-spacing:.15em}.supervisor__students-title{color:var(--color-text);opacity:.6;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.supervisor__student-list{display:flex;flex-direction:column;gap:.6rem}.supervisor__student{display:flex;align-items:center;gap:.75rem;background:#ffffff0f;border-radius:.7rem;padding:.85rem 1rem;cursor:pointer;transition:background .2s}.supervisor__student:hover{background:#ffffff1a}.supervisor__student-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:1rem}.supervisor__student-info{flex:1}.supervisor__student-name{color:var(--color-text);font-weight:600;font-size:.95rem}.supervisor__student-meta{color:var(--color-text);opacity:.5;font-size:.75rem}.supervisor__student-streak{color:var(--color-primary);font-weight:700;font-size:.9rem}.supervisor__empty{text-align:center;color:var(--color-text);opacity:.4;padding:3rem}.supervisor__detail{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.supervisor__detail-card{background:#1a1a2e;border-radius:1rem;padding:1.5rem;width:90%;max-width:420px;max-height:80vh;overflow-y:auto}.supervisor__detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.supervisor__detail-name{color:var(--color-text);font-size:1.2rem;font-weight:700}.supervisor__detail-close{background:none;border:none;color:var(--color-text);opacity:.5;font-size:1.4rem;cursor:pointer}.supervisor__progress-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.supervisor__progress-label{flex:1;color:var(--color-text);font-size:.85rem}.supervisor__progress-bar{width:120px;height:8px;border-radius:4px;background:#ffffff1a;overflow:hidden}.supervisor__progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .4s}.settings-page{display:flex;flex-direction:column;min-height:100vh;padding:1.5rem 1rem 5rem;background:var(--color-bg)}.settings__title{font-size:1.5rem;color:var(--color-text);margin-bottom:1.5rem}.settings__group{margin-bottom:1.5rem}.settings__group-title{color:var(--color-text);opacity:.6;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;padding:0 .25rem}.settings__row{display:flex;align-items:center;justify-content:space-between;background:#ffffff0f;border-radius:.7rem;padding:.85rem 1rem;margin-bottom:.4rem}.settings__label{color:var(--color-text);font-size:.95rem}.settings__toggle{position:relative;width:48px;height:26px;border-radius:13px;border:none;cursor:pointer;background:#ffffff26;transition:background .3s}.settings__toggle--on{background:var(--color-primary)}.settings__toggle:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .3s}.settings__toggle--on:after{transform:translate(22px)}.settings__select{padding:.4rem .6rem;border-radius:.4rem;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:var(--color-text);font-size:.9rem}.settings__version{text-align:center;color:var(--color-text);opacity:.3;font-size:.75rem;margin-top:auto;padding:1rem}.numpad{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px}.numpad__display{min-width:120px;min-height:48px;font-size:2rem;font-weight:700;text-align:center;background:var(--color-surface, #fff);border:3px solid var(--color-primary, #6c5ce7);border-radius:12px;padding:4px 16px;color:var(--color-text, #222)}.numpad__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:280px}.numpad__key{width:80px;height:64px;font-size:1.6rem;font-weight:700;border:none;border-radius:14px;background:var(--color-primary, #6c5ce7);color:#fff;cursor:pointer;transition:transform .08s,box-shadow .08s;box-shadow:0 4px 0 var(--color-primary-dark, #5a4bd1);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.numpad__key:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px 0 var(--color-primary-dark, #5a4bd1)}.numpad__key:disabled{opacity:.4;cursor:default}.numpad__key--action{background:var(--color-muted, #b2bec3);box-shadow:0 4px #95a5a6}.numpad__key--confirm{background:var(--color-success, #00b894);box-shadow:0 4px #00997a;font-size:1.8rem}.numpad__key--op{width:80px;height:64px;font-size:1.8rem;background:var(--color-accent, #fdcb6e);color:#2d3436;box-shadow:0 4px #e0ab3e}.numpad--operator{flex-direction:row;gap:12px}.exercise{display:flex;flex-direction:column;align-items:center;gap:24px;padding:24px;width:100%;max-width:600px;margin:0 auto}.exercise--horizontal .exercise__equation{display:flex;align-items:center;gap:12px;font-size:2.4rem;font-weight:700}.exercise__value{min-width:48px;text-align:center}.exercise__operator,.exercise__equals{font-size:2rem;color:var(--color-muted, #636e72)}.exercise__slot{min-width:56px;min-height:56px;font-size:2rem;font-weight:700;border:3px dashed var(--color-primary, #6c5ce7);border-radius:12px;background:var(--color-surface, #fff);color:var(--color-primary, #6c5ce7);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center}.exercise__slot--active{border-style:solid;box-shadow:0 0 0 3px #6c5ce74d;animation:pulse-slot 1s infinite}.exercise__slot--filled{border-style:solid;background:var(--color-primary, #6c5ce7);color:#fff}@keyframes pulse-slot{0%,to{box-shadow:0 0 0 3px #6c5ce74d}50%{box-shadow:0 0 0 6px #6c5ce726}}.exercise__spacer{display:inline-block;width:8px}.vert{display:flex;flex-direction:column;align-items:flex-end;font-family:SF Mono,Fira Code,monospace;font-size:2.2rem;font-weight:700}.vert__row{display:flex;gap:4px}.vert__row--carry{font-size:1.2rem;color:var(--color-accent, #fdcb6e)}.vert__row--carry .vert__cell--input{width:28px;height:28px;font-size:1rem}.vert__row--bottom{border-bottom:none}.vert__cell{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.vert__cell--op{color:var(--color-muted, #636e72)}.vert__cell--input{border:3px dashed var(--color-primary, #6c5ce7);border-radius:8px;background:var(--color-surface, #fff);color:var(--color-primary, #6c5ce7);cursor:pointer;font-weight:700;font-size:inherit;transition:all .15s}.vert__cell--active{border-style:solid;box-shadow:0 0 0 3px #6c5ce74d}.vert__line{width:100%;height:4px;background:var(--color-text, #2d3436);border-radius:2px;margin:4px 0}.vert__row--result{color:var(--color-success, #00b894)}.exercise--image .exercise__image-container{width:100%;max-width:400px;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.exercise__image{width:100%;display:block}.exercise__slot--image{min-width:64px}.exercise__feedback{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:100;pointer-events:none}.exercise__feedback--correct{animation:feedback-pop .6s ease-out forwards}.exercise__feedback--wrong{animation:feedback-shake .5s ease-out forwards}@keyframes feedback-pop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3);opacity:1}to{transform:scale(1);opacity:0}}@keyframes feedback-shake{0%,to{transform:translate(0);opacity:1}20%{transform:translate(-20px)}40%{transform:translate(20px)}60%{transform:translate(-10px)}80%{transform:translate(10px);opacity:0}}.exercise--recognition .exercise__image-container{width:100%;max-width:320px;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.exercise--recognition .exercise__image{width:100%;display:block}.exercise__equation--large{display:flex;align-items:center;gap:16px;font-size:3rem;font-weight:800}.video-player{position:relative;width:100%;max-width:800px;margin:0 auto;background:#000;border-radius:.8rem;overflow:hidden}.video-player__video{width:100%;display:block}.video-player__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;transition:opacity .3s}.video-player__overlay--hidden{opacity:0;pointer-events:none}.video-player__play-btn{width:64px;height:64px;border-radius:50%;background:var(--color-primary);border:none;color:#fff;font-size:1.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.video-player__play-btn:hover{transform:scale(1.1)}.video-player__controls{position:absolute;bottom:0;left:0;right:0;padding:.5rem .75rem;background:linear-gradient(transparent,#000000b3);display:flex;align-items:center;gap:.5rem}.video-player__progress{flex:1;height:4px;border-radius:2px;background:#fff3;cursor:pointer;overflow:hidden}.video-player__progress-fill{height:100%;background:var(--color-primary);transition:width .1s}.video-player__time{color:#fff;font-size:.7rem;opacity:.7;min-width:40px;text-align:right}.video-player__skip{background:#ffffff26;border:none;color:#fff;padding:.35rem .75rem;border-radius:.4rem;font-size:.8rem;cursor:pointer;transition:background .2s}.video-player__skip:hover{background:#ffffff40}.core-session{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;gap:24px}.core-session__progress{font-size:.9rem;color:var(--color-muted, #636e72);font-weight:600;letter-spacing:.5px}.core-session__spinner{width:48px;height:48px;border:5px solid var(--color-border, #dfe6e9);border-top-color:var(--color-primary, #6c5ce7);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.core-session__btn{padding:12px 32px;font-size:1.1rem;font-weight:700;border:none;border-radius:12px;background:var(--color-primary, #6c5ce7);color:#fff;cursor:pointer;transition:transform .1s}.core-session__btn:active{transform:scale(.96)}.core-session__btn--primary{font-size:1.3rem;padding:16px 48px}.core-session--video{background:#1a1a2e;color:#fff}.core-session__video-player{width:100%;max-width:720px;aspect-ratio:16/9;background:#111;border-radius:16px;overflow:hidden}.core-session__review-label{font-size:1.3rem;font-weight:700;color:#ffeaa7}.core-session--exercise{position:relative}.core-session--shake{animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.core-session__feedback{position:fixed;top:40%;left:50%;transform:translate(-50%);font-size:4rem;font-weight:900;pointer-events:none;z-index:100;animation:feedback-float 1.2s ease-out forwards}.core-session__feedback--correct{color:#00b894;text-shadow:0 2px 8px rgba(0,184,148,.4)}.core-session__feedback--wrong{color:#d63031;text-shadow:0 2px 8px rgba(214,48,49,.4)}@keyframes feedback-float{0%{opacity:0;transform:translate(-50%) translateY(0)}15%{opacity:1}to{opacity:0;transform:translate(-50%) translateY(-80px)}}.core-session--results{text-align:center}.core-session__stars-row{display:flex;gap:8px;justify-content:center;animation:stars-bounce .6s ease-out}.core-session__star{font-size:3.2rem;color:#dfe6e9;transition:color .3s}.core-session__star--filled{color:#fdcb6e;text-shadow:0 2px 8px rgba(253,203,110,.5)}@keyframes stars-bounce{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.core-session__rating-label{font-size:2rem;margin:8px 0}.core-session--error{text-align:center;color:var(--color-error, #d63031)}.tycoon-wrapper{position:relative;width:100%;height:100vh;overflow:hidden;background:#2d3436}.tycoon-wrapper--loading{display:flex;align-items:center;justify-content:center;color:#dfe6e9;font-size:1.4rem}.tycoon-wrapper__canvas{width:100%;height:100%}.tycoon-wrapper__canvas canvas{display:block}.tycoon-wrapper__hud{position:absolute;top:16px;right:16px;display:flex;gap:8px;z-index:20}.tycoon-wrapper__exit{padding:8px 16px;font-size:.9rem;font-weight:700;border:none;border-radius:8px;background:#2d3436d9;color:#dfe6e9;cursor:pointer}.tycoon-wrapper__exit:hover{background:#2d3436}.tycoon-wrapper__toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:16px 36px;font-size:1.8rem;font-weight:700;color:#ffeaa7;background:#2d3436e6;border-radius:16px;z-index:50;animation:toast-pop 2s ease-out forwards;pointer-events:none}@keyframes toast-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.6)}20%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}80%{opacity:1;transform:translate(-50%,-60%) scale(1)}to{opacity:0;transform:translate(-50%,-80%) scale(.8)}}.vn-wrapper{position:relative;width:100%;height:100vh;overflow:hidden;background-color:#1a1a2e;background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer;-webkit-user-select:none;user-select:none}.vn-wrapper--loading{display:flex;align-items:center;justify-content:center;color:#dfe6e9;font-size:1.4rem;cursor:default}.vn-wrapper--end{display:flex;align-items:center;justify-content:center;cursor:default}.vn__exit{position:absolute;top:16px;left:16px;padding:8px 16px;font-size:.9rem;font-weight:700;border:none;border-radius:8px;background:#1a1a2ed9;color:#dfe6e9;cursor:pointer;z-index:20}.vn__character{position:absolute;bottom:200px;left:50%;transform:translate(-50%);z-index:5}.vn__character-placeholder{width:200px;height:300px;border-radius:12px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-weight:700;opacity:.7}.vn__dialogue-box{position:relative;margin:0 24px 24px;padding:20px 28px;background:#1a1a2eeb;border:2px solid rgba(108,92,231,.5);border-radius:16px;z-index:10;min-height:120px}.vn__speaker-name{font-size:.9rem;font-weight:700;color:var(--color-primary, #6c5ce7);margin-bottom:8px;letter-spacing:.5px}.vn__text{color:#dfe6e9;font-size:1.15rem;line-height:1.6;margin:0}.vn__tap-hint{position:absolute;bottom:8px;right:16px;color:#636e72;animation:bounce-hint 1s infinite}@keyframes bounce-hint{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.vn__choice-panel{margin:0 24px 24px;display:flex;flex-direction:column;gap:12px;z-index:10}.vn__choice-btn{padding:16px 24px;font-size:1.1rem;font-weight:700;border:2px solid rgba(108,92,231,.5);border-radius:12px;background:#1a1a2eeb;color:#dfe6e9;cursor:pointer;transition:all .15s;text-align:left}.vn__choice-btn:hover{background:#6c5ce74d;border-color:#6c5ce7;transform:translate(4px)}.vn__end-panel{text-align:center;padding:40px;background:#1a1a2eeb;border-radius:20px;border:2px solid rgba(108,92,231,.5)}.vn__end-panel h2{color:#ffeaa7;font-size:2rem;margin:0 0 24px}.vn__btn{padding:12px 32px;font-size:1.1rem;font-weight:700;border:none;border-radius:12px;background:var(--color-primary, #6c5ce7);color:#fff;cursor:pointer}.vn__image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:8;background:#0009}.vn__image-overlay img{max-width:90%;max-height:80%;border-radius:12px;box-shadow:0 8px 40px #0006}.portal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;overflow:hidden;pointer-events:all;background:radial-gradient(circle at center,transparent 0%,#0a0a1a 70%)}.portal__vortex{width:0;height:0;border-radius:50%;background:radial-gradient(circle,var(--portal-color, #6c5ce7),transparent 70%);transition:all .4s cubic-bezier(.34,1.56,.64,1)}.portal--start .portal__vortex{width:40px;height:40px;opacity:.6}.portal--peak .portal__vortex{width:300px;height:300px;opacity:1;box-shadow:0 0 120px var(--portal-color, #6c5ce7),0 0 240px var(--portal-color, #6c5ce7)}.portal--end .portal__vortex{width:3000px;height:3000px;opacity:0}.portal__particles{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.portal__particle{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--portal-color, #6c5ce7);box-shadow:0 0 8px var(--portal-color, #6c5ce7);animation:portal-spiral var(--portal-duration, 1.8s) ease-in-out forwards;animation-delay:var(--delay, 0s);transform:rotate(var(--angle, 0deg)) translate(200px)}@keyframes portal-spiral{0%{transform:rotate(var(--angle, 0deg)) translate(300px);opacity:0}30%{transform:rotate(calc(var(--angle, 0deg) + 180deg)) translate(150px);opacity:1}70%{transform:rotate(calc(var(--angle, 0deg) + 540deg)) translate(30px);opacity:1}to{transform:rotate(calc(var(--angle, 0deg) + 720deg)) translate(0);opacity:0}}.portal__flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;opacity:0;pointer-events:none}.portal--end .portal__flash{animation:portal-flash .3s ease-out forwards}@keyframes portal-flash{0%{opacity:0}50%{opacity:.8}to{opacity:0}}.portal__text{position:absolute;font-size:1.4rem;font-weight:700;color:#fff;text-shadow:0 0 20px var(--portal-color, #6c5ce7);letter-spacing:2px;animation:portal-text-appear .5s ease-out;text-align:center;padding:0 24px}@keyframes portal-text-appear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.portal--exit .portal__vortex{animation-direction:reverse}.portal--exit.portal--start .portal__vortex{width:3000px;height:3000px;opacity:0}.portal--exit.portal--peak .portal__vortex{width:300px;height:300px;opacity:1}.portal--exit.portal--end .portal__vortex{width:0;height:0;opacity:0}.petfling-wrapper{position:fixed;top:0;left:0;width:100vw;height:100vh;overflow:hidden;background:#1a1a2e;z-index:100}.petfling-wrapper__canvas{width:100%;height:100%}.petfling-wrapper__canvas canvas{display:block}.petfling-wrapper__exit{position:absolute;top:12px;right:12px;background:#2d3436cc;color:#dfe6e9;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-family:Arial,sans-serif;cursor:pointer;z-index:20;transition:background .2s}.petfling-wrapper__exit:hover{background:#2d3436}.pf-editor{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;background:#1a1a2e;overflow:hidden;z-index:1000}.pf-editor__panel{width:260px;min-width:260px;height:100%;background:#16213e;color:#e0e0e0;display:flex;flex-direction:column;gap:0;overflow-y:auto;overflow-x:hidden;z-index:10;box-shadow:2px 0 8px #00000080}.pf-editor__panel-title{background:#0f3460;color:#f0f0f0;font-weight:700;font-size:14px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;letter-spacing:.3px;flex-shrink:0}.pf-editor__exit-btn{background:#e74c3c;color:#fff;border:none;border-radius:4px;padding:3px 8px;cursor:pointer;font-size:11px}.pf-editor__exit-btn:hover{background:#c0392b}.pf-editor__section{padding:8px 10px;border-bottom:1px solid #0f3460;flex-shrink:0}.pf-editor__section-title{font-size:11px;font-weight:600;text-transform:uppercase;color:#7eb8f7;letter-spacing:.5px;margin-bottom:6px}.pf-editor__section label{display:flex;flex-direction:column;font-size:11px;color:#b0b0cc;margin-bottom:6px;gap:3px}.pf-editor__section input[type=number],.pf-editor__section input[type=text],.pf-editor__section select{background:#0f3460;color:#e0e0e0;border:1px solid #2a5298;border-radius:4px;padding:4px 6px;font-size:12px;width:100%;box-sizing:border-box}.pf-editor__section input:focus,.pf-editor__section select:focus{outline:none;border-color:#7eb8f7}.pf-editor__palette{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;max-height:240px;overflow-y:auto}.pf-editor__palette-item{background:#0f3460;border:2px solid transparent;border-radius:5px;cursor:pointer;display:flex;flex-direction:column;align-items:center;padding:3px 2px;transition:border-color .15s,background .15s;gap:2px}.pf-editor__palette-item:hover{background:#1a4a80}.pf-editor__palette-item{-webkit-user-drag:none;user-drag:none}.pf-editor__palette-item--active{border-color:#7eb8f7;background:#1a4a80}.pf-editor__palette-item img{width:36px;height:36px;object-fit:contain;image-rendering:pixelated;pointer-events:none;-webkit-user-drag:none;user-drag:none}.pf-editor__palette-item span{font-size:8px;color:#a0b0cc;text-align:center;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.pf-editor__controls{display:flex;gap:6px}.pf-editor__btn{background:#0f3460;color:#e0e0e0;border:1px solid #2a5298;border-radius:5px;padding:5px 8px;font-size:11px;cursor:pointer;transition:background .15s;white-space:nowrap}.pf-editor__btn:hover{background:#1a4a80}.pf-editor__btn--active{background:#2a5298;border-color:#7eb8f7;color:#7eb8f7}.pf-editor__btn--danger{border-color:#e74c3c;color:#e74c3c}.pf-editor__btn--danger:hover{background:#e74c3c;color:#fff}.pf-editor__btn--primary{background:#27ae60;border-color:#2ecc71;color:#fff}.pf-editor__btn--primary:hover{background:#219a52}.pf-editor__btn--full{width:100%;text-align:center}.pf-editor__textarea{width:100%;box-sizing:border-box;background:#0a1628;color:#87ceeb;border:1px solid #2a5298;border-radius:4px;padding:5px 6px;font-size:10px;font-family:monospace;resize:vertical;margin-top:4px}.pf-editor__textarea:focus{outline:none;border-color:#7eb8f7}.pf-editor__hints{font-size:10px;color:#8090a0;line-height:1.6}.pf-editor__hints kbd{background:#0f3460;border:1px solid #2a5298;border-radius:3px;padding:1px 4px;font-size:10px;color:#c0d0e0}.pf-editor__preview-badge{background:#27ae60;color:#fff;font-size:11px;font-weight:700;padding:6px 12px;text-align:center;letter-spacing:.3px}.pf-editor__canvas{flex:1;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:default}.pf-editor__canvas--placing{cursor:crosshair}.pf-editor__canvas canvas{max-width:100%;max-height:100%}.pf-editor__ghost{position:fixed;pointer-events:none;transform:translate(-50%,-50%);z-index:9000;opacity:.7}.pf-editor__ghost img{display:block;object-fit:fill;image-rendering:pixelated;filter:drop-shadow(0 0 6px rgba(126,184,247,.9))}.pf-editor__toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#0f3460f2;color:#87ceeb;border:1px solid #2a5298;border-radius:8px;padding:8px 20px;font-size:13px;font-weight:600;z-index:9999;pointer-events:none;animation:pf-toast-in .2s ease}@keyframes pf-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pf-editor__panel::-webkit-scrollbar{width:5px}.pf-editor__panel::-webkit-scrollbar-track{background:#16213e}.pf-editor__panel::-webkit-scrollbar-thumb{background:#2a5298;border-radius:3px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background:#0a0a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-around;align-items:center;z-index:50;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;gap:.15rem;background:none;border:none;color:var(--color-text);opacity:.4;font-size:.65rem;cursor:pointer;transition:opacity .2s;padding:.4rem .8rem}.bottom-nav__item--active{opacity:1;color:var(--color-primary)}.bottom-nav__icon{font-size:1.3rem;line-height:1}:root{--color-bg: #0a0a1a;--color-text: #e8e8f0;--color-primary: #6c5ce7;--color-fire: #e74c3c;--color-water: #3498db;--color-earth: #27ae60;--color-air: #ecf0f1}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden;background:var(--color-bg);color:var(--color-text);font-family:system-ui,-apple-system,sans-serif}.app{width:100%;height:100%;display:flex;flex-direction:column}
