:root{--bg-primary: #FFF8F0;--bg-secondary: #FFF2E6;--bg-card: rgba(255,255,255,.9);--color-math: #FF6B6B;--color-english: #4ECDC4;--color-korean: #FFE66D;--color-coin: #FFD700;--color-star: #FF9F43;--color-level: #A29BFE;--accent: #6C5CE7;--accent2: #00B894;--text-primary: #2D3436;--text-secondary: #636E72;--text-muted: #B2BEC3;--border: rgba(0,0,0,.08);--shadow: 0 4px 20px rgba(0,0,0,.06);--radius: 20px;--font-title: "Jua","Noto Sans KR",sans-serif;--font-body: "Noto Sans KR",sans-serif;--font-en: "Outfit",sans-serif;--transition: all .3s ease;--container: 1100px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;overscroll-behavior-y:contain;-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}button{font-family:inherit;cursor:pointer;border:none;background:none;-webkit-tap-highlight-color:transparent}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:14px 0;background:#fff8f0eb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:var(--transition)}.navbar.scrolled{padding:10px 0;box-shadow:var(--shadow)}.nav-container{max-width:var(--container);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}.logo{font-family:var(--font-title);font-size:1.8rem;display:flex;align-items:center;gap:6px}.logo-real{color:#3e2723}.logo-n{color:#ff7675;text-shadow:2px 2px 0px rgba(255,118,117,.2)}.nav-links{display:flex;gap:24px;list-style:none;align-items:center}.nav-links a{font-size:.95rem;font-weight:500;color:var(--text-secondary);transition:var(--transition);position:relative}.nav-links a:hover{color:var(--accent)}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:var(--transition)}.nav-links a:hover:after{width:100%}.nav-links li.auth-item{margin-left:4px}.mobile-menu-btn{display:none;flex-direction:column;gap:5px;padding:5px}.mobile-menu-btn span{display:block;width:24px;height:2px;background:var(--text-primary);transition:var(--transition)}.user-profile{position:relative;display:flex;align-items:center}.user-profile.hidden{display:none}.profile-icon{width:38px;height:38px;border-radius:50%;background:var(--accent2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;cursor:pointer;box-shadow:0 2px 10px #00b8944d;border:2px solid rgba(255,255,255,.5);transition:var(--transition);-webkit-user-select:none;user-select:none;z-index:1001}.profile-icon:hover{transform:scale(1.08)}.profile-dropdown{position:absolute;top:120%;right:0;background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px;min-width:140px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:var(--transition);box-shadow:0 10px 30px #0000001f;z-index:1000}.user-profile.active .profile-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:block;width:100%;padding:10px 16px;color:var(--text-primary);text-align:left;border-radius:8px;font-size:.9rem;transition:var(--transition)}.dropdown-item:hover{background:var(--bg-secondary)}.nav-login-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:#fff;box-shadow:0 2px 8px #0000001a;transition:var(--transition);border:none;cursor:pointer}.nav-login-icon:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.hero-section{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:120px 24px 80px;background:linear-gradient(180deg,#fff9f2,#fffdf0 60%,#e8f8f5)}#particle-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.hero-content{position:relative;z-index:2;text-align:center;max-width:800px}.hero-headline{margin-bottom:28px}.headline-sub{display:inline-block;font-family:var(--font-title);font-size:1.25rem;font-weight:400;color:#795548;background:#ffe0b2;padding:4px 16px;border-radius:20px;margin-bottom:12px;box-shadow:0 2px #7955481a}.headline-main{display:block;font-family:var(--font-title);font-size:clamp(2.4rem,6vw,4rem);color:#3e2723;text-shadow:2px 2px 0px rgba(0,0,0,.03);line-height:1.3}.hero-subtext{font-size:1.1rem;color:#5d4037;line-height:1.8;margin-bottom:36px}.hero-subtext strong{color:#ff7675;font-weight:600}.subject-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:720px;margin:0 auto 60px}.subject-card{background:#fff;border:3px solid rgba(0,0,0,.05);border-radius:28px;padding:36px 20px;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 8px #00000005,0 12px 24px #00000008;position:relative}.subject-card:hover{transform:translateY(-8px);box-shadow:0 16px #00000005,0 20px 35px #0000000d}.subject-card.math{border-color:#ffc0c0;background:#fff5f5}.subject-card.math:hover{border-color:var(--color-math);background:#ffeaea}.subject-card.english{border-color:#b2f5ea;background:#f0fdfa}.subject-card.english:hover{border-color:var(--color-english);background:#e6fffa}.subject-card.korean{border-color:#fefcbf;background:ivory}.subject-card.korean:hover{border-color:var(--color-korean);background:#ffffe0}.subject-icon{font-size:3.2rem;margin-bottom:12px;display:block;transition:all .3s ease}.subject-card:hover .subject-icon{transform:scale(1.15) rotate(5deg)}.subject-name{font-family:var(--font-title);font-size:1.4rem;color:#3e2723;margin-bottom:6px}.subject-desc{font-size:.88rem;color:#795548;font-weight:500}.cta-button{display:inline-flex;align-items:center;gap:10px;padding:18px 44px;background:linear-gradient(135deg,#ff7675,#ff8e53);border-radius:50px;font-family:var(--font-title);font-size:1.25rem;color:#fff;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 8px #d63031,0 15px 30px #ff76754d;border:2.5px solid white}.cta-button:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 12px #d63031,0 20px 40px #ff767573}.cta-button:active{transform:translateY(2px) scale(.98);box-shadow:0 2px #d63031,0 4px 10px #ff76754d}.philosophy-section{padding:90px 0;background:linear-gradient(180deg,#fffdf0,#fff5ea)}.section-container{max-width:var(--container);margin:0 auto;padding:0 24px}.section-header{text-align:center;margin-bottom:60px}.section-label{display:inline-block;font-family:var(--font-title);font-size:1rem;color:#ff7675;background:#ffe8e8;padding:4px 16px;border-radius:20px;letter-spacing:1px;margin-bottom:12px;box-shadow:0 2px #ff767514}.section-title{font-family:var(--font-title);font-size:clamp(1.9rem,4vw,2.7rem);color:#3e2723;line-height:1.4}.section-title .highlight{color:#ff7675}.philosophy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.philosophy-card{background:#fff;border:3px solid rgba(0,0,0,.04);border-radius:28px;padding:38px 28px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 8px #00000004,0 12px 24px #00000005;position:relative;overflow:hidden}.philosophy-card:hover{transform:translateY(-6px);border-color:#ff767540;box-shadow:0 14px #00000004,0 20px 35px #ff767514}.card-glow{display:none}.card-content{position:relative;z-index:1}.card-emoji{font-size:2.8rem;margin-bottom:16px;display:block;transition:transform .3s ease}.philosophy-card:hover .card-emoji{transform:scale(1.2) rotate(-8deg)}.card-label{display:inline-block;font-size:.75rem;font-weight:700;color:#ff7675;text-transform:uppercase;letter-spacing:2px;margin-bottom:10px}.card-title{font-family:var(--font-title);font-size:1.45rem;color:#3e2723;margin-bottom:6px}.card-subtitle{font-size:.95rem;color:#795548;margin-bottom:14px;font-style:italic}.card-desc{font-size:.92rem;color:#5d4037;line-height:1.8}.scroll-indicator{position:absolute;bottom:32px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:.8rem;animation:floatUp 2s ease-in-out infinite}.mouse{width:22px;height:36px;border:2px solid var(--text-muted);border-radius:11px;position:relative}.wheel{width:3px;height:7px;background:var(--text-muted);border-radius:2px;position:absolute;top:7px;left:50%;transform:translate(-50%);animation:scrollWheel 2s ease-in-out infinite}@keyframes floatUp{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-8px)}}@keyframes scrollWheel{0%,to{opacity:1;top:7px}50%{opacity:.3;top:18px}}.footer{padding:40px 0;background:#fff;border-top:1px solid var(--border)}.footer-container{max-width:var(--container);margin:0 auto;padding:0 24px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.footer-brand .logo{font-size:1.4rem}.footer-tagline{font-size:.8rem;color:var(--text-muted);margin-top:4px}.footer-links{display:flex;align-items:center;gap:12px;font-size:.8rem;color:var(--text-secondary)}.footer-links a:hover{color:var(--accent)}.footer-links .divider{color:var(--border)}.footer-copyright{font-size:.75rem;color:var(--text-muted)}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 18px;background:#fff;border:1.5px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:1rem;transition:var(--transition)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6c5ce71a}.form-group textarea{resize:vertical;min-height:100px}.submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 32px;background:linear-gradient(135deg,var(--accent),#a29bfe);border-radius:12px;font-size:1rem;font-weight:600;color:#fff;transition:var(--transition)}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #6c5ce759}.fade-in{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease}.fade-in.visible{opacity:1;transform:translateY(0)}.hidden{display:none!important}.study-container{max-width:600px;margin:80px auto 40px;padding:24px;overscroll-behavior-y:contain}.study-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 20px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.study-stats{display:flex;gap:16px;font-family:var(--font-title);font-size:1rem}.stat-item{display:flex;align-items:center;gap:4px}.subject-tabs{display:flex;gap:8px;margin-bottom:24px}.subject-tab{flex:1;padding:14px;border-radius:14px;font-family:var(--font-title);font-size:1rem;text-align:center;border:2px solid var(--border);background:#fff;transition:var(--transition)}.subject-tab:hover{transform:translateY(-2px)}.subject-tab.active-math{border-color:var(--color-math);background:#ff6b6b1a;color:var(--color-math)}.subject-tab.active-english{border-color:var(--color-english);background:#4ecdc41a;color:#2d9e96}.subject-tab.active-korean{border-color:var(--color-korean);background:#ffe66d26;color:#c9a200}.question-area{background:var(--bg-card);border-radius:var(--radius);padding:40px 28px;text-align:center;box-shadow:var(--shadow);min-height:360px;display:flex;flex-direction:column;align-items:center;justify-content:center}.question-text{font-family:var(--font-title);font-size:clamp(2.2rem,8vw,3.6rem);margin-bottom:32px;line-height:1.6}.question-area #questionContent{font-size:clamp(2rem,7vw,3.2rem);line-height:1.7}.choices-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:420px}.choice-btn{padding:20px 18px;border-radius:14px;font-family:var(--font-title);font-size:1.5rem;border:2px solid var(--border);background:#fff;transition:var(--transition);cursor:pointer}.choice-btn:hover{border-color:var(--accent);transform:scale(1.03)}.choice-btn.correct{background:#d4edda;border-color:#28a745;color:#155724;animation:popIn .3s ease}.choice-btn.wrong{background:#f8d7da;border-color:#dc3545;color:#721c24;animation:shake .4s ease}.progress-bar{width:100%;height:10px;background:var(--border);border-radius:5px;margin-top:24px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:5px;transition:width .4s ease}.progress-text{font-size:.85rem;color:var(--text-muted);margin-top:8px;text-align:center}.result-screen{text-align:center;padding:40px 20px}.result-emoji{font-size:4rem;margin-bottom:16px;animation:popIn .5s ease}.result-title{font-family:var(--font-title);font-size:2rem;margin-bottom:8px}.result-stats{display:flex;justify-content:center;gap:24px;margin:20px 0;font-family:var(--font-title);font-size:1.1rem}.result-stars{font-size:2.5rem;margin:16px 0}.result-buttons{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap}.result-btn{padding:14px 28px;border-radius:14px;font-family:var(--font-title);font-size:1rem;transition:var(--transition)}.result-btn.primary{background:linear-gradient(135deg,var(--accent),#a29bfe);color:#fff}.result-btn.secondary{background:#fff;border:2px solid var(--border);color:var(--text-primary)}.result-btn:hover{transform:translateY(-2px)}.char-select-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center}.char-select-box{background:#fff;border-radius:24px;padding:40px;max-width:480px;width:90%;text-align:center;box-shadow:0 20px 60px #0003}.char-select-title{font-family:var(--font-title);font-size:1.6rem;margin-bottom:8px}.char-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:20px 0;max-height:240px;overflow-y:auto;padding:8px;border-radius:12px;background:#f8f9fa;border:1px solid #e9ecef}.char-option{width:100%;aspect-ratio:1;max-width:64px;border-radius:50%;border:3px solid var(--border);cursor:pointer;font-size:2.4rem;display:flex;align-items:center;justify-content:center;transition:var(--transition);background:#fff;margin:0 auto;box-sizing:border-box}.char-option:hover,.char-option.selected{border-color:var(--accent);transform:scale(1.05);box-shadow:0 4px 16px #6c5ce74d}.char-name-input{margin:16px auto;padding:12px 20px;border:2px solid var(--border);border-radius:12px;font-family:var(--font-title);font-size:1.1rem;text-align:center;width:80%;outline:none}.char-name-input:focus{border-color:var(--accent)}.char-confirm-btn{padding:14px 40px;border-radius:50px;background:linear-gradient(135deg,var(--accent),#a29bfe);color:#fff;font-family:var(--font-title);font-size:1.1rem;transition:var(--transition);margin-top:8px}.char-confirm-btn:hover{transform:translateY(-2px)}.parent-container{max-width:900px;margin:90px auto 40px;padding:24px}.parent-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px}.child-selector{padding:10px 20px;border-radius:12px;border:2px solid var(--border);font-family:var(--font-title);font-size:1rem;background:#fff}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}.stat-card{background:var(--bg-card);border-radius:var(--radius);padding:24px;text-align:center;box-shadow:var(--shadow);border:2px solid var(--border)}.stat-card h3{font-family:var(--font-title);font-size:1rem;margin-bottom:8px}.stat-card .stat-value{font-family:var(--font-title);font-size:2rem;color:var(--accent)}.stat-card .stat-sub{font-size:.8rem;color:var(--text-muted);margin-top:4px}.history-list{background:var(--bg-card);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.history-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}.history-item:last-child{border-bottom:none}.badge-grid{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.badge-item{padding:10px 16px;border-radius:12px;background:var(--bg-secondary);font-size:.9rem;border:1px solid var(--border)}.badge-item.locked{opacity:.4;filter:grayscale(1)}.notice-header{padding:100px 24px 40px;text-align:center;background:linear-gradient(180deg,var(--bg-primary),var(--bg-secondary))}.notice-grid{max-width:var(--container);margin:0 auto;padding:24px}.notice-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:16px;padding:24px;margin-bottom:16px;cursor:pointer;transition:var(--transition)}.notice-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}.notice-card .card-category{font-size:.75rem;color:var(--accent);text-transform:uppercase;letter-spacing:1px}.notice-card h2{font-size:1.1rem;margin:8px 0}.notice-card .card-date{font-size:.8rem;color:var(--text-muted)}.blog-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;opacity:0;pointer-events:none;transition:var(--transition);overflow-y:auto}.blog-modal.active{opacity:1;pointer-events:all}.modal-content{max-width:700px;margin:80px auto;padding:36px;background:#fff;border-radius:20px;position:relative;box-shadow:0 20px 60px #0003}.close-btn{position:absolute;top:16px;right:20px;color:var(--text-muted);font-size:1.8rem;cursor:pointer}.post-content img{max-width:100%;border-radius:8px;margin:16px 0}.admin-container{max-width:900px;margin:90px auto;padding:24px}.login-box{max-width:380px;margin:100px auto;padding:36px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:20px;text-align:center;box-shadow:var(--shadow)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px}.post-editor{background:var(--bg-card);padding:28px;border-radius:20px;margin-bottom:32px;box-shadow:var(--shadow)}.post-list-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border);background:#00000003;margin-bottom:8px;border-radius:8px}.btn-sm{padding:6px 14px;font-size:.8rem;margin-left:8px;border-radius:6px;cursor:pointer}.btn-delete{background:#ff32321a;color:#e74c3c}@keyframes popIn{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}@keyframes confettiFall{0%{transform:translateY(-100vh) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.confetti{position:fixed;top:0;width:10px;height:10px;border-radius:2px;animation:confettiFall 2.5s ease-in forwards;z-index:9999;pointer-events:none}.avatar-container-wrapper{position:relative;width:52px;height:52px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:3px solid white;box-shadow:0 4px 8px #0000000f;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);-webkit-user-select:none;user-select:none;background:#fff2e6;overflow:visible}.avatar-container-wrapper:hover{transform:scale(1.08) rotate(5deg);box-shadow:0 6px 12px #0000001a}.avatar-bg-circle{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;z-index:1;transition:background-color .3s ease}.avatar-character{position:relative;z-index:2;font-size:2.2rem;display:flex;align-items:center;justify-content:center;margin-top:1px}.avatar-hat-item{position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:1.6rem;z-index:3;transition:all .3s ease;pointer-events:none}.avatar-glasses-item{position:absolute;top:13px;left:50%;transform:translate(-50%);font-size:1.3rem;z-index:4;transition:all .3s ease;pointer-events:none}.avatar-container-wrapper.preview-large{width:100px;height:100px;border-width:5px;box-shadow:0 8px 16px #00000014}.avatar-container-wrapper.preview-large .avatar-character{font-size:4.2rem;margin-top:2px}.avatar-container-wrapper.preview-large .avatar-hat-item{top:-30px;font-size:3rem}.avatar-container-wrapper.preview-large .avatar-glasses-item{top:24px;font-size:2.6rem}.shop-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#ffe0b2,#ffcc80);border:2px solid #FFA726;border-radius:16px;font-family:var(--font-title);font-size:.95rem;color:#5d4037;box-shadow:0 4px #e65100;transition:all .15s ease;margin-left:8px}.shop-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 6px #e65100}.shop-toggle-btn:active{transform:translateY(2px);box-shadow:0 0 #e65100}.shop-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}.shop-modal.visible{opacity:1;pointer-events:all}.shop-box{background:#fffbf7;border:4px solid #8D6E63;border-radius:28px;max-width:720px;width:92%;max-height:85vh;box-shadow:0 20px 50px #00000026,inset 0 -6px #0000000d;display:flex;flex-direction:column;overflow:hidden;animation:popIn .4s cubic-bezier(.175,.885,.32,1.15) forwards}.shop-header{background:linear-gradient(180deg,#fff2e6,#fff9f2);border-bottom:3px dashed #D7CCC8;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.shop-title-text{font-family:var(--font-title);font-size:1.5rem;color:#4e342e;display:flex;align-items:center;gap:8px}.shop-coin-tag{display:inline-flex;align-items:center;gap:6px;background:#fff;border:2px solid var(--color-coin);border-radius:20px;padding:6px 16px;font-family:var(--font-title);font-size:1.1rem;color:#e65100;box-shadow:0 3px #ffd70033}.shop-body{padding:24px;display:flex;gap:20px;overflow:hidden;height:480px}.shop-preview-pane{flex:0 0 200px;background:#fff;border:3px solid #E0E0E0;border-radius:20px;padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:inset 0 4px 10px #00000005}.preview-title{font-family:var(--font-title);font-size:1rem;color:#795548;margin-bottom:12px}.preview-name{font-family:var(--font-title);font-size:1.15rem;color:#3e2723;margin-top:14px;background:#fff3e0;padding:4px 12px;border-radius:12px}.preview-help-text{font-size:.75rem;color:var(--text-secondary);margin-top:12px;line-height:1.4}.shop-catalog-pane{flex:1;display:flex;flex-direction:column;overflow:hidden}.shop-tabs{display:flex;gap:8px;margin-bottom:14px;flex-shrink:0}.shop-tab-btn{flex:1;padding:10px;border-radius:14px;border:2px solid #BCAAA4;background:#fff;font-family:var(--font-title);font-size:1rem;color:#795548;box-shadow:0 3px #bcaaa4;transition:all .15s ease}.shop-tab-btn:hover{background:#efebe9}.shop-tab-btn.active{background:linear-gradient(135deg,#ff7675,#ff8e53);border-color:#ff7675;color:#fff;box-shadow:0 3px #d63031}.shop-tab-btn.active:active{transform:translateY(2px);box-shadow:0 0 #d63031}.category-filters{display:flex;gap:6px;margin-bottom:14px;flex-shrink:0}.filter-btn{padding:6px 14px;border-radius:20px;border:1.5px solid #D7CCC8;background:#faf8f5;font-family:var(--font-title);font-size:.85rem;color:#8d6e63;transition:var(--transition)}.filter-btn:hover{background:#efebe9}.filter-btn.active{background:#e8f5e9;border-color:#a5d6a7;color:#2e7d32;box-shadow:inset 0 2px 4px #00000008}.item-scroll-area{flex:1;overflow-y:auto;padding-right:4px}.item-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.item-card{background:#fff;border:2.5px solid #E0E0E0;border-radius:18px;padding:12px;text-align:center;position:relative;transition:all .2s cubic-bezier(.175,.885,.32,1.2);display:flex;flex-direction:column;justify-content:space-between;min-height:120px}.item-card:hover{transform:translateY(-3px);box-shadow:0 6px 12px #0000000a}.item-card.equipped{border-color:#ff8e53;background:#fff5f0}.item-card.owned{border-color:#6c5ce7;background:#f8f7ff}.item-emoji-display{font-size:2.4rem;margin-bottom:6px;display:block}.item-name-label{font-family:var(--font-title);font-size:.9rem;color:#3e2723;margin-bottom:8px}.item-action-btn{width:100%;padding:6px 10px;border-radius:12px;font-family:var(--font-title);font-size:.85rem;transition:all .15s ease;border:none}.item-action-btn.buy{background:#fff9c4;border:1.5px solid #FBC02D;color:#f57f17;box-shadow:0 2.5px #f9a825}.item-action-btn.buy:hover{background:#fff59d}.item-action-btn.buy:active{transform:translateY(1.5px);box-shadow:0 0 #f9a825}.item-action-btn.equip{background:#e8f5e9;border:1.5px solid #A5D6A7;color:#2e7d32;box-shadow:0 2.5px #81c784}.item-action-btn.equip:hover{background:#c8e6c9}.item-action-btn.equip:active{transform:translateY(1.5px);box-shadow:0 0 #81c784}.item-action-btn.unequip{background:#ffebee;border:1.5px solid #EF9A9A;color:#c62828;box-shadow:0 2.5px #e57373}.item-action-btn.unequip:hover{background:#ffcdd2}.item-action-btn.unequip:active{transform:translateY(1.5px);box-shadow:0 0 #e57373}.item-action-btn.disabled{background:#eceff1!important;border:1.5px solid #CFD8DC!important;color:#90a4ae!important;box-shadow:none!important;cursor:not-allowed;transform:none!important}.shop-footer{padding:14px 24px;background:#fff3e0;border-top:3px dashed #FFE0B2;display:flex;justify-content:flex-end;flex-shrink:0}.shop-close-btn{padding:10px 30px;border-radius:20px;background:linear-gradient(135deg,#8d6e63,#795548);border:2px solid white;font-family:var(--font-title);font-size:1rem;color:#fff;box-shadow:0 4px #4e342e;transition:all .15s ease}.shop-close-btn:hover{transform:translateY(-2px);box-shadow:0 6px #4e342e}.shop-close-btn:active{transform:translateY(2px);box-shadow:0 0 #4e342e}.item-scroll-area::-webkit-scrollbar{width:8px}.item-scroll-area::-webkit-scrollbar-track{background:#f5ebe6;border-radius:4px}.item-scroll-area::-webkit-scrollbar-thumb{background:#c7b7af;border-radius:4px;border:1px solid #F5EBE6}.item-scroll-area::-webkit-scrollbar-thumb:hover{background:#a89890}@media(max-width:900px){.philosophy-grid,.stats-grid{grid-template-columns:1fr}.subject-cards{grid-template-columns:1fr;max-width:300px}}@media(max-width:768px){.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff8f0fa;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-direction:column;padding:16px;gap:0;border-bottom:1px solid var(--border)}.nav-links.active{display:flex}.nav-links li{width:100%;text-align:center;border-bottom:1px solid var(--border)}.nav-links li:last-child{border-bottom:none}.nav-links a,.nav-links button{display:block;padding:12px;width:100%}.nav-links .auth-item{margin-left:0;padding:12px 0}.mobile-menu-btn{display:flex}.mobile-menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.hero-section{padding:100px 16px 60px}.choices-grid{grid-template-columns:1fr 1fr}.char-grid{grid-template-columns:repeat(5,1fr);max-height:180px;gap:8px;margin:16px 0;padding:6px}.char-option{max-width:52px;font-size:2rem;border-width:2px}.char-select-box{padding:20px 16px;width:95%}.shop-box{width:96%;height:95vh;max-height:95vh;border-radius:20px;border-width:3px}.shop-body{flex-direction:column;flex:1;min-height:0;overflow:hidden;padding:10px;gap:10px}.shop-preview-pane{flex:none;width:100%;height:52px;padding:4px 10px;flex-direction:row!important;align-items:center;justify-content:space-between;gap:8px;border-radius:12px}.shop-preview-pane .preview-title,.shop-preview-pane .preview-help-text{display:none!important}.shop-preview-pane .avatar-container-wrapper.preview-large{width:44px;height:44px;border-width:3px;margin:0;flex-shrink:0;transform:none}.shop-preview-pane .avatar-container-wrapper.preview-large .avatar-character{font-size:1.8rem;margin-top:0}.shop-preview-pane .avatar-container-wrapper.preview-large .avatar-hat-item{top:-14px;font-size:1.2rem}.shop-preview-pane .avatar-container-wrapper.preview-large .avatar-glasses-item{top:8px;font-size:1.1rem}.shop-preview-pane .preview-name{margin-top:0;font-size:.78rem;padding:2px 8px;border-radius:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.shop-catalog-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.shop-tabs{gap:4px;margin-bottom:6px;flex-shrink:0}.shop-tab-btn{padding:5px 8px;font-size:.75rem;border-radius:8px}.item-scroll-area{flex:1;overflow-y:auto;padding-right:2px;min-height:0}.item-grid{grid-template-columns:repeat(2,1fr);gap:6px}.item-card{padding:6px;min-height:80px;border-radius:12px;border-width:1.5px}.item-emoji-display{font-size:1.5rem}.item-name-label{font-size:.72rem;margin:2px 0}.item-action-btn{font-size:.7rem;padding:3px 6px;border-radius:6px}.shop-footer{padding:6px 12px;flex-shrink:0;display:flex;justify-content:center}.shop-close-btn{font-size:.85rem;padding:6px 20px;border-radius:12px;width:100%;max-width:180px}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr 1fr}.result-buttons{flex-direction:column}}@keyframes glowAura{0%{box-shadow:0 0 5px #6c5ce733,0 4px 8px #0000000f}50%{box-shadow:0 0 20px #6c5ce799,0 4px 15px #6c5ce74d}to{box-shadow:0 0 5px #6c5ce733,0 4px 8px #0000000f}}.avatar-container-wrapper{animation:glowAura 3s infinite ease-in-out}@keyframes bounceAvatar{0%,to{transform:scale(1) translateY(0)}25%{transform:scale(1.2,.8) translateY(0)}50%{transform:scale(.85,1.15) translateY(-24px)}75%{transform:scale(1.05,.95) translateY(0)}}@keyframes shakeAvatar{0%,to{transform:translate(0) rotate(0)}20%,60%{transform:translate(-8px) rotate(-8deg)}40%,80%{transform:translate(8px) rotate(8deg)}}.bounce-avatar{animation:bounceAvatar .65s cubic-bezier(.175,.885,.32,1.275) forwards!important}.shake-avatar{animation:shakeAvatar .5s ease-in-out forwards!important}.streak-fire{position:fixed;top:25%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-title);font-size:2.8rem;z-index:1800;pointer-events:none;background:#fffffff2;border:4px solid #FF7675;padding:12px 32px;border-radius:40px;box-shadow:0 12px 40px #ff767566,inset 0 -4px #0000000d;text-shadow:0 2px 4px rgba(0,0,0,.1);display:flex;align-items:center;gap:10px;animation:streakFlame 1.3s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes streakFlame{0%{transform:translate(-50%,-30%) scale(.6);opacity:0}15%{transform:translate(-50%,-50%) scale(1.2);opacity:1}30%{transform:translate(-50%,-50%) scale(1);opacity:1}80%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-70%) scale(.85);opacity:0}}.floating-toast{position:fixed;top:40%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-title);font-size:1.8rem;color:var(--accent);z-index:1900;pointer-events:none;background:#fff;padding:12px 36px;border-radius:24px;box-shadow:0 10px 35px #6c5ce740,inset 0 -4px #0000000d;border:4px solid var(--accent);animation:popInFloat 1.8s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes popInFloat{0%{transform:translate(-50%,-30%) scale(.6);opacity:0}15%{transform:translate(-50%,-50%) scale(1.15);opacity:1}30%{transform:translate(-50%,-50%) scale(1);opacity:1}85%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-70%) scale(.85);opacity:0}}@keyframes badgePop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.badge-unlock-modal{animation:badgePop .5s cubic-bezier(.175,.885,.32,1.275) forwards}.badge-item{transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.badge-item:hover{transform:scale(1.06) translateY(-3px);box-shadow:0 6px 15px #00000014}@keyframes avatarBreath{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.015)}}.avatar-character{animation:avatarBreath 3s ease-in-out infinite}.avatar-aura-ring{position:absolute;inset:-5px;border-radius:50%;z-index:0;background:linear-gradient(135deg,#ff767559,#6c5ce759,#00b89459);animation:spinAura 10s linear infinite,glowAura 2s ease-in-out infinite alternate;pointer-events:none}@keyframes spinAura{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes glowAura{0%{box-shadow:0 0 3px #6c5ce726}to{box-shadow:0 0 12px #6c5ce780}}.emote-particle{position:fixed;font-size:1.6rem;z-index:2200;pointer-events:none;animation:emoteFloat 1.2s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes emoteFloat{0%{transform:translate(-50%,-50%) scale(.3) rotate(0);opacity:0}15%{transform:translate(-50%,-50%) scale(1.3) rotate(15deg);opacity:1}35%{transform:translate(calc(-50% + var(--dx, 0px)),calc(-50% + var(--dy, -30px))) scale(1) rotate(-10deg);opacity:1}to{transform:translate(calc(-50% + var(--dx, 0px) * 1.6),calc(-50% + var(--dy, -30px) * 1.6 - 25px)) scale(.5) rotate(45deg);opacity:0}}.avatar-speech-bubble{position:absolute;bottom:125%;left:50%;transform:translate(-50%) scale(0);transform-origin:bottom center;background:#fff;border:3.5px solid var(--accent);color:var(--text-primary);font-family:var(--font-title);font-size:.95rem;padding:8px 16px;border-radius:18px;white-space:nowrap;box-shadow:0 10px 30px #6c5ce733;z-index:1000;pointer-events:none;transition:transform .4s cubic-bezier(.175,.885,.32,1.275),opacity .4s;opacity:0}.avatar-speech-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:9px solid transparent;border-top-color:#fff}.avatar-speech-bubble:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:12px solid transparent;border-top-color:var(--accent);z-index:-1}.avatar-speech-bubble.visible{transform:translate(-50%) scale(1);opacity:1}.badge-celebration-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#2d3436b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2800;display:flex;align-items:center;justify-content:center;animation:overlayFadeIn .35s ease forwards}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.badge-celebration-box{background:#fff;border:6px solid #FF9F43;border-radius:36px;padding:35px 25px;width:90%;max-width:440px;text-align:center;box-shadow:0 24px 60px #00000040,inset 0 -6px #0000000d;transform:scale(.65);animation:boxPopIn .6s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes boxPopIn{to{transform:scale(1)}}.celebration-shield{width:136px;height:136px;margin:10px auto 25px;background:radial-gradient(circle,#ffeaa7,#ffd32a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:4.8rem;box-shadow:0 8px #e2b600,0 16px 32px #ffd32a73;border:4.5px solid white;position:relative;animation:spinShield 16s linear infinite}@keyframes spinShield{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.celebration-shield-inner{position:absolute;width:100%;height:100%;display:flex;align-items:center;justify-content:center;animation:counterRotate 16s linear infinite}@keyframes counterRotate{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.badge-celeb-title{font-family:var(--font-title);font-size:2.2rem;color:#2d3436;margin-bottom:8px}.badge-celeb-name{font-family:var(--font-title);font-size:1.4rem;color:var(--accent);background:#f3f0ff;display:inline-block;padding:4px 18px;border-radius:20px;margin-bottom:12px}.badge-celeb-desc{color:var(--text-secondary);font-size:1.05rem;margin-bottom:24px}.shop-tabs{display:flex;border-bottom:2.5px solid var(--border);margin-bottom:16px}.shop-tab-btn{flex:1;text-align:center;padding:12px;font-family:var(--font-title);font-size:1.05rem;color:var(--text-secondary);border-bottom:3px solid transparent;margin-bottom:-2.5px;transition:var(--transition)}.shop-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.badge-grid-closet{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:14px;padding:10px 4px;max-height:280px;overflow-y:auto}.badge-card-closet{background:#fff2e6;border:3px solid white;border-radius:20px;padding:12px 6px;text-align:center;box-shadow:0 4px 10px #0000000a;transition:all .3s cubic-bezier(.175,.885,.32,1.275);position:relative}.badge-card-closet.locked{filter:grayscale(1) opacity(.55);background:#f1f2f6}.badge-card-closet.equipped{border-color:var(--accent);background:#f3f0ff;box-shadow:0 6px 14px #6c5ce726}.badge-card-closet:hover:not(.locked){transform:translateY(-4px) scale(1.04);box-shadow:0 8px 16px #0000000f}.badge-icon-closet{font-size:2.4rem;margin-bottom:4px;display:block}.badge-title-closet{font-family:var(--font-title);font-size:.85rem;color:#2d3436;display:block;margin-bottom:6px}.badge-action-btn{font-family:var(--font-title);font-size:.75rem;padding:3px 8px;border-radius:12px;background:#fff;border:1.5px solid var(--accent);color:var(--accent);transition:var(--transition)}.badge-card-closet.equipped .badge-action-btn{background:var(--accent);color:#fff}.badge-locked-overlay{position:absolute;top:4px;right:4px;font-size:.8rem;background:#0000000d;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.parent-badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:16px;margin:14px 0}.parent-badge-card{text-align:center;padding:10px 4px;border-radius:16px;background:#fff9f3;border:2px solid white;box-shadow:0 4px 10px #00000008;transition:all .3s}.parent-badge-card.locked{filter:grayscale(1) opacity(.45);background:#f1f2f6}.parent-badge-card .badge-icon{font-size:2.3rem;margin-bottom:4px;display:block}.parent-badge-card .badge-name{font-family:var(--font-title);font-size:.8rem;color:#2d3436}.parent-badge-card .badge-desc{font-size:.65rem;color:var(--text-secondary)}.parent-progress-container{margin-top:10px}.parent-progress-label-row{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-secondary);margin-bottom:4px}.parent-progress-bg{height:10px;background:#0000000d;border-radius:6px;overflow:hidden}.parent-progress-fill{height:100%;border-radius:6px;transition:width .6s ease}.blush-cheeks{position:absolute;top:50%;width:14%;height:8%;background:#ff6b81b3;border-radius:50%;filter:blur(1.5px);z-index:3;opacity:0;transform:translateY(-50%);transition:opacity .3s ease;pointer-events:none}.blush-cheeks.left{left:22%}.blush-cheeks.right{right:22%}.avatar-character.happy~.blush-cheeks{opacity:.85;animation:blushGlow 1.5s ease-in-out infinite alternate}@keyframes blushGlow{0%{transform:translateY(-50%) scale(1);filter:blur(1.5px)}to{transform:translateY(-50%) scale(1.2);filter:blur(.8px)}}.pet-care-panel{background:var(--bg-card);border:3.5px solid #FFCC80;border-radius:var(--radius);padding:16px;margin-top:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:12px;position:relative;transition:var(--transition)}.pet-care-panel:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ffcc8040}.pet-care-title{font-family:var(--font-title);font-size:1.05rem;color:#795548;display:flex;align-items:center;gap:6px}.pet-affection-container{width:100%;display:flex;align-items:center;gap:10px;background:#fff5f5;border-radius:15px;padding:6px 12px;border:2px solid #FFC0C0}.heart-icon{font-size:1.3rem;animation:heartPulse 1.2s ease infinite alternate}@keyframes heartPulse{0%{transform:scale(1)}to{transform:scale(1.25)}}.affection-bg{flex:1;height:12px;background:#0000000d;border-radius:6px;overflow:hidden;position:relative}.affection-fill{height:100%;background:linear-gradient(90deg,#ff6b81,#ff4757);border-radius:6px;width:0%;transition:width .5s cubic-bezier(.175,.885,.32,1.2)}.affection-text{font-family:var(--font-title);font-size:.85rem;color:#ff4757;min-width:32px;text-align:right}.food-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%}.feed-btn{background:#fff;border:2.5px solid #FFD2FC;border-radius:16px;padding:10px 4px;font-family:var(--font-title);font-size:.85rem;color:#6d214f;box-shadow:0 4px #ffd2fc;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .15s ease}.feed-btn:hover{transform:translateY(-2px);box-shadow:0 6px #ffd2fc}.feed-btn:active{transform:translateY(2px);box-shadow:0 1px #ffd2fc}.feed-btn .food-emoji{font-size:1.8rem;transition:transform .2s}.feed-btn:hover .food-emoji{transform:scale(1.2) rotate(8deg)}.flying-food{position:fixed;font-size:2.2rem;z-index:2900;pointer-events:none;transition:all .8s cubic-bezier(.25,.46,.45,.94)}.scratch-card-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#2d3436d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}.scratch-card-overlay.visible{opacity:1;pointer-events:auto}.scratch-ticket-box{background:radial-gradient(circle at top left,#fff,#fff9f2);border:7px solid #FFD700;border-radius:36px;padding:24px;width:92%;max-width:380px;text-align:center;box-shadow:0 24px 60px #00000059,inset 0 -6px #0000000d;position:relative;transform:scale(.7);transition:transform .4s cubic-bezier(.175,.885,.32,1.25)}.scratch-card-overlay.visible .scratch-ticket-box{transform:scale(1)}.scratch-header{font-family:var(--font-title);font-size:1.6rem;color:#e2b600;text-shadow:1px 1px 0px white;margin-bottom:6px}.scratch-subtitle{font-size:.88rem;color:#795548;margin-bottom:18px}.scratch-area-container{width:250px;height:250px;margin:0 auto 20px;position:relative;border-radius:20px;overflow:hidden;box-shadow:0 8px 20px #0000001f;border:3.5px dashed #FFD700}.scratch-prize-layer{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#fff9e6,#fff2cc);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}.scratch-prize-emoji{font-size:4rem;animation:bounceAvatar 1.5s infinite}.scratch-prize-label{font-family:var(--font-title);font-size:1.3rem;color:#d6a2e8;margin-top:10px}.scratch-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2;cursor:crosshair;touch-action:none}.scratch-close-btn{background:linear-gradient(135deg,#ff6b81,#ff4757);color:#fff;font-family:var(--font-title);font-size:1rem;padding:10px 24px;border-radius:20px;box-shadow:0 4px 8px #ff47574d;margin-top:8px}.scratch-close-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #ff475766}.dashboard-scratch-banner{background:linear-gradient(135deg,#fff3b0,#caecff);border:3px solid white;border-radius:20px;padding:14px 18px;margin:18px 0;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);cursor:pointer;transition:var(--transition)}.dashboard-scratch-banner:hover{transform:translateY(-2.5px) scale(1.015);box-shadow:0 8px 24px #0000000f}.dashboard-scratch-banner:active{transform:translateY(1px) scale(.98);box-shadow:0 2px 8px #0000000d}.scratch-banner-left{display:flex;align-items:center;gap:12px}.scratch-banner-icon{font-size:2.2rem;animation:bounceAvatar 1s infinite alternate}.scratch-banner-text h4{font-family:var(--font-title);font-size:1.05rem;color:#2d3436}.scratch-banner-text p{font-size:.8rem;color:var(--text-secondary)}.scratch-banner-go{background:var(--accent);color:#fff;font-family:var(--font-title);font-size:.85rem;padding:6px 14px;border-radius:14px;box-shadow:0 3px 6px #6c5ce733}.scratch-banner-go:hover{background:#5b4cc4}
