:root{--green-50: #ecfdf5;--green-100: #d1fae5;--green-200: #a7f3d0;--green-300: #6ee7b7;--green-400: #34d399;--green-500: #10b981;--green-600: #0f9d76;--green-700: #047857;--green-800: #065f46;--teal-500: #14b8a6;--ink: #1f2937;--ink-soft: #4b5563;--muted: #6b7280;--line: #e5e7eb;--bg: #f6faf8;--card: #ffffff;--amber: #f59e0b;--rose: #ef4444;--sky: #0ea5e9;--violet: #8b5cf6;--pink: #ec4899;--radius: 18px;--radius-sm: 12px;--radius-lg: 26px;--shadow: 0 6px 24px rgba(16, 24, 40, .07);--shadow-lg: 0 16px 48px rgba(16, 24, 40, .12);--shadow-glow: 0 10px 40px rgba(16, 185, 129, .28);--font: "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;--accent: var(--green-600);--accent-soft: var(--green-50);--hero-from: var(--green-500);--hero-to: var(--teal-500);--base-size: 16px;--lift: -3px;--motion: 1}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-size:var(--base-size);font-family:var(--font);color:var(--ink);background:radial-gradient(1200px 600px at 100% -10%,var(--green-50),transparent),radial-gradient(900px 500px at -10% 110%,#e0f2fe,transparent),var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--green-700);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{margin:0 0 .4em;line-height:1.25;color:var(--ink)}p{line-height:1.6;color:var(--ink-soft)}.app{min-height:100%;overflow-x:clip}.app[data-role=STUDENT]{--accent: #0ea5e9;--accent-soft: #e0f2fe;--hero-from: #22c55e;--hero-to: #06b6d4;--radius: 22px;--radius-lg: 30px;--lift: -5px}.app[data-role=STUDENT] body,.app[data-role=STUDENT]{background:radial-gradient(900px 500px at 110% -10%,#fef9c3,transparent),radial-gradient(900px 500px at -10% 0%,#dcfce7,transparent),radial-gradient(700px 500px at 50% 120%,#cffafe,transparent),var(--bg)}.app[data-role=ADMIN]{--accent: #4338ca;--accent-soft: #eef2ff;--hero-from: #4f46e5;--hero-to: #0e7490}.app[data-role=ADMIN]{background:radial-gradient(1000px 600px at 100% -10%,#eef2ff,transparent),radial-gradient(900px 500px at -10% 110%,#ecfeff,transparent),var(--bg)}.app[data-role=TEACHER]{--accent: var(--green-700);--accent-soft: var(--green-50);--hero-from: var(--green-600);--hero-to: #0e7490}.app[data-role=PARENT]{--accent: #b45309;--accent-soft: #fff7ed;--hero-from: #f59e0b;--hero-to: #f97316;--base-size: 17px}.app[data-role=PARENT]{background:radial-gradient(1000px 600px at 100% -10%,#fff7ed,transparent),radial-gradient(900px 500px at -10% 110%,#ecfdf5,transparent),var(--bg)}.container{max-width:1120px;margin:0 auto;padding:24px 20px 64px}.page-title{font-size:1.65rem;display:flex;align-items:center;gap:10px;font-weight:800}.page-sub{color:var(--muted);margin-top:-4px;margin-bottom:22px}.row{display:flex;gap:14px;flex-wrap:wrap}.row.between{justify-content:space-between;align-items:center}.spacer{flex:1}.stack{display:flex;flex-direction:column;gap:14px}.grid{display:grid;gap:18px}.grid.cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.grid.two{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid.stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.topbar{position:sticky;top:0;z-index:30;background:#ffffffd1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.topbar-inner{max-width:1120px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:16px}.brand{font-weight:800;font-size:1.25rem;display:flex;align-items:center;gap:8px;background:linear-gradient(120deg,var(--green-700),var(--teal-500));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.brand:hover{text-decoration:none}.brand .leaf{-webkit-text-fill-color:initial;display:inline-block;animation:sway 4s ease-in-out infinite;transform-origin:bottom center}.role-tag{font-size:.72rem;font-weight:800;letter-spacing:.4px;text-transform:uppercase;padding:3px 9px;border-radius:999px;background:var(--accent-soft);color:var(--accent)}.topnav{display:flex;gap:4px;flex-wrap:wrap}.topnav a{padding:8px 14px;border-radius:999px;color:var(--ink-soft);font-weight:600;font-size:.92rem;transition:background .15s ease,color .15s ease}.topnav a:hover{background:var(--accent-soft);text-decoration:none}.topnav a.active{background:var(--accent);color:#fff}.user-chip{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--ink-soft);font-size:.92rem;border:0;background:transparent;cursor:pointer;padding:0;font-family:inherit}.user-chip:hover{color:var(--ink)}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;font-size:.95rem;background:linear-gradient(135deg,var(--hero-from),var(--hero-to));box-shadow:0 2px 8px #10b98159}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;border:1px solid rgba(16,24,40,.05);transition:transform .18s ease,box-shadow .18s ease}.card.pad-lg{padding:28px}.card.accent-top{position:relative;overflow:hidden}.card.accent-top:before{content:"";position:absolute;left:0;top:0;right:0;height:5px;background:linear-gradient(90deg,var(--hero-from),var(--hero-to))}.card-link{transition:transform .18s ease,box-shadow .18s ease;display:block;color:inherit}.card-link:hover{transform:translateY(var(--lift));box-shadow:var(--shadow-lg);text-decoration:none}.class-card .class-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.class-card .class-name{font-size:1.15rem;font-weight:800}.class-emoji{font-size:1.9rem}.app[data-role=STUDENT] .class-card:hover .class-emoji,.card-link:hover .class-emoji{animation:pop .5s ease}.stat{background:var(--green-50);border-radius:var(--radius-sm);padding:14px 16px;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden}.stat .val{font-size:1.6rem;font-weight:800;color:var(--green-700);font-variant-numeric:tabular-nums}.stat .lbl{font-size:.82rem;color:var(--muted);font-weight:600}.stat.warn{background:#fef3c7}.stat.warn .val{color:#b45309}.stat.sky{background:#e0f2fe}.stat.sky .val{color:#0369a1}.stat.violet{background:#ede9fe}.stat.violet .val{color:#6d28d9}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:.95rem;padding:11px 18px;border-radius:999px;transition:filter .15s ease,transform .06s ease,box-shadow .15s ease;background:linear-gradient(120deg,var(--green-600),var(--green-500));color:#fff;box-shadow:0 4px 14px #10b98140}.btn:hover{filter:brightness(1.05);box-shadow:0 6px 18px #10b98152}.btn:active{transform:translateY(1px) scale(.99)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;filter:grayscale(.2)}.btn.secondary{background:#fff;color:var(--green-700);border:1.5px solid var(--green-200);box-shadow:none}.btn.ghost{background:transparent;color:var(--ink-soft);box-shadow:none}.btn.ghost:hover{background:var(--accent-soft)}.btn.danger{background:linear-gradient(120deg,#ef4444,#f87171);box-shadow:0 4px 14px #ef444440}.btn.sky{background:linear-gradient(120deg,#0ea5e9,#38bdf8);box-shadow:0 4px 14px #0ea5e940}.btn.amber{background:linear-gradient(120deg,#f59e0b,#fbbf24);box-shadow:0 4px 14px #f59e0b40}.btn.block{width:100%}.btn.sm{padding:7px 12px;font-size:.85rem}.btn.lg{padding:14px 26px;font-size:1.05rem}label.field{display:flex;flex-direction:column;gap:6px;font-weight:600;color:var(--ink-soft);font-size:.9rem}.input,.select,.textarea{font-family:inherit;font-size:1rem;color:var(--ink);padding:11px 14px;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:#fff;width:100%;transition:border-color .15s ease,box-shadow .15s ease}.input::placeholder,.textarea::placeholder{color:transparent}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--green-400);box-shadow:0 0 0 3px var(--green-100)}.textarea{resize:vertical;min-height:110px}.help{font-size:.82rem;color:var(--muted);font-weight:500}.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.switch input{display:none}.switch .track{width:46px;height:26px;border-radius:999px;background:#d1d5db;position:relative;transition:background .2s}.switch .track:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 3px #0003}.switch input:checked+.track{background:var(--green-500)}.switch input:checked+.track:after{transform:translate(20px)}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:700;background:var(--green-100);color:var(--green-700)}.pill.gray{background:#f1f5f9;color:var(--muted)}.pill.amber{background:#fef3c7;color:#b45309}.pill.rose{background:#fee2e2;color:#b91c1c}.pill.sky{background:#e0f2fe;color:#0369a1}.pill.violet{background:#ede9fe;color:#6d28d9}.tabs{display:flex;gap:6px;border-bottom:2px solid var(--line);margin-bottom:22px;flex-wrap:wrap}.tab{padding:10px 16px;border:none;background:none;cursor:pointer;font-family:inherit;font-weight:700;color:var(--muted);border-bottom:3px solid transparent;margin-bottom:-2px;font-size:.95rem;transition:color .15s ease}.tab:hover{color:var(--ink-soft)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;margin-left:6px;padding:0 5px;font-size:.7rem;font-weight:800;color:#fff;background:#ef4444;border-radius:999px;line-height:1;vertical-align:middle}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow);-webkit-overflow-scrolling:touch;background:linear-gradient(to right,#fff 30%,#fff0) left center,linear-gradient(to left,#fff 30%,#fff0) right center,radial-gradient(farthest-side at 0 50%,#10182824,#10182800) left center,radial-gradient(farthest-side at 100% 50%,#10182824,#10182800) right center;background-repeat:no-repeat;background-size:44px 100%,44px 100%,16px 100%,16px 100%;background-attachment:local,local,scroll,scroll;background-color:#fff}table.tbl{width:100%;border-collapse:collapse;min-width:560px}.tbl th,.tbl td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);font-size:.92rem}.tbl th{background:var(--green-50);color:var(--green-700);font-weight:700;white-space:nowrap;position:sticky;top:0}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr{transition:background .12s ease}.tbl tbody tr:hover td{background:#f3fbf7}.rank-medal{font-size:1.15rem}.game-hero{background:linear-gradient(160deg,var(--hero-from),var(--hero-to));border-radius:var(--radius-lg);color:#fff;padding:32px 30px;text-align:center;box-shadow:var(--shadow-glow);position:relative;overflow:hidden}.game-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(420px 220px at 50% 0%,rgba(255,255,255,.28),transparent);pointer-events:none}.game-hero .sparkle{position:absolute;font-size:1.1rem;opacity:.85;pointer-events:none;animation:floaty calc(5s * var(--motion) + 1ms) ease-in-out infinite}.game-stage-wrap{position:relative;display:inline-block}.game-emoji{font-size:6.4rem;line-height:1;filter:drop-shadow(0 10px 18px rgba(0,0,0,.2));display:inline-block;animation:bob calc(3s / var(--motion)) ease-in-out infinite;cursor:pointer;transition:transform .15s ease}.game-emoji:hover{transform:scale(1.06) rotate(-2deg)}.game-emoji.grow{animation:grow-in .7s cubic-bezier(.34,1.56,.64,1)}.game-emoji.wilt-1{filter:saturate(.75) drop-shadow(0 10px 18px rgba(0,0,0,.18))}.game-emoji.wilt-2{filter:grayscale(.45) saturate(.6) drop-shadow(0 8px 16px rgba(0,0,0,.18));opacity:.92;transform:rotate(-5deg);animation:none}.game-emoji.wilt-3{filter:grayscale(.8) brightness(.96) drop-shadow(0 6px 14px rgba(0,0,0,.18));opacity:.8;transform:rotate(-9deg) translateY(4px);animation:none}.game-emoji.wilted{filter:grayscale(.65) drop-shadow(0 8px 16px rgba(0,0,0,.18));animation:none;opacity:.82}.game-glow{position:absolute;top:-10%;right:-10%;bottom:10%;left:-10%;border-radius:50%;z-index:-1;background:radial-gradient(circle,rgba(255,255,255,.35),transparent 65%);animation:pulse 2.6s ease-in-out infinite}.game-stage{font-size:1.45rem;font-weight:800;margin-top:8px}.game-hint{opacity:.95;margin:4px 0 0;color:#fff}.water-btn{margin-top:14px;background:#ffffff38;border:1.5px solid rgba(255,255,255,.5);color:#fff;font-weight:700;padding:8px 18px;border-radius:999px;cursor:pointer;font-family:inherit;transition:background .15s ease,transform .06s ease}.water-btn:hover{background:#ffffff52}.water-btn:active{transform:scale(.96)}.bar{height:12px;border-radius:999px;background:#ffffff4d;overflow:hidden}.bar>span{display:block;height:100%;border-radius:999px;transition:width .7s cubic-bezier(.22,1,.36,1)}.bar.light{background:var(--line)}.metric-row{display:flex;justify-content:center;gap:26px;margin-top:24px;flex-wrap:wrap}.metric{text-align:center}.metric .m-val{font-size:1.6rem;font-weight:800;font-variant-numeric:tabular-nums}.metric .m-lbl{font-size:.8rem;opacity:.92}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}.badge-item{text-align:center;padding:18px 10px;border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow);border:1.5px solid var(--green-100);transition:transform .18s ease,box-shadow .18s ease;position:relative}.badge-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.badge-item .b-icon{font-size:2.8rem;display:inline-block}.app[data-role=STUDENT] .badge-item:not(.locked):hover .b-icon{animation:pop .5s ease}.badge-item .b-name{font-weight:700;margin-top:6px;font-size:.9rem}.badge-item .b-date{font-size:.75rem;color:var(--muted);margin-top:2px}.badge-item.locked{filter:grayscale(1);opacity:.4}.badge-item.unlocked{animation:badge-pop .7s cubic-bezier(.34,1.56,.64,1)}.badge-item .shine{position:absolute;top:8px;right:10px;font-size:.9rem;animation:twinkle 2s ease-in-out infinite}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:460px}.auth-logo{font-size:2.4rem;font-weight:800;text-align:center;display:flex;gap:10px;align-items:center;justify-content:center;background:linear-gradient(120deg,var(--green-700),var(--teal-500));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.auth-card>.card.pad-lg>h3.center+p.center.muted{display:none}.auth-card>.card.pad-lg>h3.center+p.center.muted+.role-grid{margin-top:18px!important}.role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.role-btn{min-height:112px;border:2px solid var(--green-100);background:#fff;border-radius:var(--radius);padding:20px 10px;cursor:pointer;font-family:inherit;text-align:center;transition:all .18s ease}.role-btn:hover{border-color:var(--green-400);transform:translateY(-4px);box-shadow:var(--shadow)}.role-btn:hover .r-emoji{animation:pop .5s ease}.role-btn .r-emoji{font-size:2.4rem;display:block}.role-btn .r-name{font-weight:700;margin-top:6px;color:var(--ink)}.note{background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--radius-sm);padding:12px 14px;font-size:.88rem;color:var(--green-700);display:flex;gap:8px}.note.amber{background:#fffbeb;border-color:#fde68a;color:#92400e}.note.rose{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.note.sky{background:#f0f9ff;border-color:#bae6fd;color:#075985}.muted{color:var(--muted)}.center{text-align:center}.empty{text-align:center;padding:48px 20px;color:var(--muted)}.empty .e-emoji{font-size:3.2rem;display:inline-block;animation:bob 3s ease-in-out infinite}.divider{height:1px;background:var(--line);margin:16px 0;border:none}.spinner{width:38px;height:38px;border:4px solid var(--green-100);border-top-color:var(--green-500);border-radius:50%;animation:spin .8s linear infinite;margin:40px auto}.thumb-grid{display:flex;gap:10px;flex-wrap:wrap}.thumb{width:110px;height:110px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--line);transition:transform .15s ease}.thumb:hover{transform:scale(1.04)}.health-pet-mood{display:inline-flex;align-items:center;gap:6px}.skel{background:linear-gradient(90deg,#eef2f0 25%,#f7faf9 37%,#eef2f0 63%);background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:10px}.skel.line{height:14px;margin:8px 0}.skel.title{height:24px;width:50%}.skel.card{height:120px;border-radius:var(--radius)}.toast-stack{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:100;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none;width:min(440px,92vw)}.toast{pointer-events:auto;width:100%;background:#fff;border-radius:14px;padding:12px 16px;box-shadow:var(--shadow-lg);display:flex;gap:10px;align-items:center;font-weight:600;color:var(--ink);border-left:5px solid var(--green-500);animation:toast-in .35s cubic-bezier(.34,1.56,.64,1)}.toast.exit{animation:toast-out .3s ease forwards}.toast .t-emoji{font-size:1.4rem}.toast.success{border-left-color:var(--green-500)}.toast.celebrate{border-left-color:var(--amber);background:linear-gradient(120deg,#fffbeb,#fff)}.toast.error{border-left-color:var(--rose)}.toast.info{border-left-color:var(--sky)}.confetti-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:90;overflow:hidden}.confetti-piece{position:absolute;top:-16px;width:10px;height:14px;border-radius:2px;animation:confetti-fall linear forwards}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182780;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50;animation:fade-in .2s ease}.modal{width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modal-in .28s cubic-bezier(.34,1.56,.64,1)}.icon-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:8px;max-height:180px;overflow-y:auto;padding:6px;border:1.5px solid var(--line);border-radius:var(--radius-sm)}.icon-opt{font-size:1.5rem;line-height:1;padding:6px;border-radius:10px;cursor:pointer;background:#fff;border:2px solid transparent;transition:transform .1s ease,border-color .1s ease,background .1s ease}.icon-opt:hover{background:var(--accent-soft);transform:scale(1.1)}.icon-opt.sel{border-color:var(--accent);background:var(--accent-soft)}.reveal{opacity:0;transform:translateY(14px);animation:reveal-up .5s ease forwards;animation-delay:calc(var(--i, 0) * 70ms)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes sway{0%,to{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}@keyframes pulse{0%,to{transform:scale(.95);opacity:.6}50%{transform:scale(1.08);opacity:1}}@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.25)}to{transform:scale(1)}}@keyframes grow-in{0%{transform:scale(.2);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes badge-pop{0%{transform:scale(.3) rotate(-12deg);opacity:0}60%{transform:scale(1.12) rotate(4deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes twinkle{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes floaty{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(10deg)}}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@keyframes reveal-up{to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-in{0%{opacity:0;transform:translateY(-16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{to{opacity:0;transform:translateY(-12px) scale(.96)}}@keyframes confetti-fall{to{transform:translateY(105vh) rotate(720deg);opacity:.9}}@media(max-width:640px){.container{padding:16px 14px 56px}.page-title{font-size:1.35rem}.page-sub{font-size:.9rem}.topbar-inner{padding:9px 12px;gap:8px;flex-wrap:wrap}.brand{font-size:1.08rem}.role-tag{display:none}.topnav{order:10;flex-basis:100%;width:100%;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px;padding-bottom:2px}.topnav::-webkit-scrollbar{height:0}.topnav a{white-space:nowrap;flex:0 0 auto}.game-hero{padding:22px 16px}.game-emoji{font-size:4.8rem}.game-stage{font-size:1.25rem}.metric-row{gap:16px}.role-grid{grid-template-columns:1fr}.auth-card .role-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.card.pad-lg{padding:18px}.modal-backdrop{padding:20px 12px 12px;align-items:flex-start}.btn.lg{width:100%}.btn.sm{padding:9px 13px}.hide-sm{display:none}}@media(max-width:380px){.game-emoji{font-size:4rem}.metric-row{gap:10px}.metric .m-val{font-size:1.35rem}.stat .val{font-size:1.4rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}.mute-btn{position:absolute;top:12px;right:12px;z-index:2;width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.5);background:#ffffff38;color:#fff;font-size:1.05rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,background .15s ease}.mute-btn:hover{transform:scale(1.08);background:#ffffff59}.mute-btn:active{transform:scale(.94)}.game-petname{font-size:1.15rem;font-weight:800;color:#fff;margin:2px 0;letter-spacing:.2px;text-shadow:0 1px 6px rgba(0,0,0,.18)}.theme-pick{flex:1}.lb-list{display:flex;flex-direction:column;gap:10px;margin-top:6px}.lb-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .15s ease}.lb-row:hover{transform:translate(2px)}.lb-row.top{border-color:#fcd34d;background:linear-gradient(90deg,#fffbeb,var(--card))}.lb-row.me{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft),var(--shadow)}.lb-rank{min-width:44px;text-align:center;font-size:1.4rem;font-weight:800;color:var(--accent)}.lb-avatar{font-size:1.6rem;line-height:1}.lb-main{flex:1;min-width:0}.lb-name{font-weight:700;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lb-mepill{font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:999px;background:var(--accent);color:#fff;animation:badge-pop .5s ease both}.lb-pet{font-size:.82rem;color:var(--muted, #6b7280);margin-top:2px}.lb-stats{display:flex;gap:12px;font-weight:700;font-size:.92rem;white-space:nowrap}.lb-stat{display:inline-flex;align-items:center;gap:2px}@media(max-width:640px){.lb-stats{flex-direction:column;gap:2px;align-items:flex-end;font-size:.85rem}.lb-rank{min-width:36px;font-size:1.2rem}}.bell-wrap{position:relative;display:inline-flex}.bell{position:relative;width:40px;height:40px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;cursor:pointer;background:var(--card);border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease}.bell:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.bell-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:800;color:#fff;background:#ef4444;border:2px solid var(--card);border-radius:999px;line-height:1}.noti-panel{position:absolute;top:calc(100% + 10px);right:0;z-index:60;width:min(360px,calc(100vw - 24px));background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;animation:noti-pop .16s ease both}@keyframes noti-pop{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.noti-head{padding:12px 14px;border-bottom:1px solid var(--line);background:var(--accent-soft)}.noti-list{max-height:min(420px,70vh);overflow-y:auto}.noti-item{display:flex;gap:10px;align-items:flex-start;width:100%;padding:12px 14px;text-align:left;cursor:pointer;background:transparent;border:none;border-bottom:1px solid var(--line);transition:background .12s ease}.noti-item:last-child{border-bottom:none}.noti-item:hover{background:var(--accent-soft)}.noti-item.unread{background:color-mix(in srgb,var(--accent-soft) 70%,var(--card))}.noti-emoji{font-size:1.25rem;line-height:1.3;flex:0 0 auto}.noti-body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.noti-title{font-weight:600;color:var(--text, #111827)}.noti-item.unread .noti-title{font-weight:800}.noti-text{font-size:.85rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.noti-date{font-size:.72rem;color:var(--muted);margin-top:2px}.noti-dot{flex:0 0 auto;width:9px;height:9px;margin-top:6px;border-radius:999px;background:var(--accent)}
