:root{--bg-primary: #0A0E1A;--bg-secondary: #111827;--bg-card: rgba(255, 255, 255, .04);--bg-card-hover: rgba(255, 255, 255, .08);--glass-border: rgba(255, 255, 255, .08);--glass-glow: rgba(251, 191, 36, .08);--color-gold: #F59E0B;--color-gold-light: #FCD34D;--color-cyan: #06B6D4;--color-cyan-light: #67E8F9;--color-green: #10B981;--color-green-light: #6EE7B7;--color-red: #EF4444;--color-purple: #8B5CF6;--color-purple-light: #A78BFA;--color-orange: #F97316;--color-primary: var(--color-gold);--color-accent: var(--color-cyan);--color-accent-dark: #0891B2;--color-danger: var(--color-red);--color-success: var(--color-green);--text-primary: #F1F5F9;--text-secondary: #94A3B8;--text-muted: #64748B;--text-inverse: #0A0E1A;--color-border: rgba(255, 255, 255, .06);--color-border-strong: rgba(255, 255, 255, .15);--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--shadow-card-hover: 0 8px 40px rgba(0, 0, 0, .5), 0 0 30px rgba(251, 191, 36, .06);--shadow-gold: 0 0 20px rgba(245, 158, 11, .15);--shadow-button: 0 4px 16px rgba(245, 158, 11, .25);--radius-card: 16px;--radius-button: 12px;--radius-badge: 999px;--radius-icon: 14px;--font-display: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-body: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden;background-image:radial-gradient(ellipse at 20% 20%,rgba(6,182,212,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(139,92,246,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(245,158,11,.03) 0%,transparent 70%)}#root{position:relative;z-index:1}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}::selection{background:#fbbf244d;color:var(--text-primary)}.card{background:var(--bg-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);border:1px solid var(--glass-border);padding:20px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.page{max-width:860px;margin:0 auto;padding:16px 16px 100px}.page-header{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--text-primary);margin-bottom:16px;letter-spacing:.02em;display:flex;align-items:center}.role-switcher{position:fixed;top:0;left:0;right:0;z-index:100;background:#0a0e1ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px}.role-switcher .logo{font-family:var(--font-display);font-weight:800;font-size:1rem;color:var(--color-gold);letter-spacing:.04em;display:flex;align-items:center;gap:6px;flex-shrink:0;text-shadow:0 0 20px rgba(245,158,11,.2)}.role-tabs{display:flex;background:#ffffff0a;border-radius:12px;padding:3px;gap:2px;border:1px solid var(--glass-border)}.role-tab{padding:6px 16px;border-radius:9px;border:none;background:transparent;font-family:var(--font-display);font-weight:600;font-size:.85rem;color:var(--text-muted);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;-webkit-tap-highlight-color:transparent}.role-tab.active{background:#f59e0b26;color:var(--color-gold);box-shadow:0 0 20px #f59e0b1a}.role-tab:not(.active):hover{color:var(--text-secondary)}.main-content{padding-top:64px}.points-hero{background:linear-gradient(145deg,#ffffff0d,#ffffff05);border-radius:24px;padding:32px 24px 24px;box-shadow:0 8px 32px #0006,inset 0 1px #ffffff0f;border:1px solid var(--glass-border);margin-bottom:24px;position:relative;overflow:hidden;text-align:center}.points-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-gold) 25%,var(--color-cyan) 50%,var(--color-purple) 75%,transparent 100%);opacity:.8}.hero-stars{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.hero-star{position:absolute;animation:star-twinkle 3s ease-in-out infinite}@keyframes star-twinkle{0%,to{opacity:.1;transform:scale(1) rotate(0)}50%{opacity:.4;transform:scale(1.2) rotate(15deg)}}.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:4px}.level-badge{width:80px;height:80px;border-radius:50%;background:linear-gradient(145deg,#f59e0b26,#f59e0b0d);border:2px solid rgba(245,158,11,.3);box-shadow:0 0 30px #f59e0b26,inset 0 0 20px #f59e0b0d;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;margin-bottom:4px}.level-badge-inner{font-family:var(--font-display);font-weight:900;font-size:1.8rem;color:var(--color-gold);line-height:1;text-shadow:0 0 20px rgba(245,158,11,.3)}.level-badge-label{font-family:var(--font-display);font-size:.55rem;font-weight:700;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase}.points-number{font-family:var(--font-display);font-size:2.8rem;font-weight:900;color:var(--color-gold);line-height:1;letter-spacing:-.02em;text-shadow:0 0 30px rgba(245,158,11,.2)}.level-name{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text-secondary);letter-spacing:.04em}.progress-wrapper{width:100%;max-width:320px;margin:12px auto 0}.progress-bar{height:8px;border-radius:999px;background:#ffffff0f;overflow:hidden;position:relative}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--color-gold),var(--color-orange));transition:width .8s cubic-bezier(.34,1.3,.64,1);position:relative;box-shadow:0 0 12px #f59e0b4d}.progress-fill:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--color-gold-light);box-shadow:0 0 10px #fcd34d99}.progress-label{font-size:.78rem;color:var(--text-muted);margin-top:8px;font-weight:500}.checkin-card{background:var(--bg-card);border-radius:var(--radius-card);padding:16px 18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .25s;border:1px solid var(--glass-border);box-shadow:var(--shadow-card);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.checkin-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 60%,rgba(6,182,212,.03));pointer-events:none}.checkin-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0006,0 0 20px #06b6d40a;border-color:#06b6d433}.checkin-card:active{transform:scale(.98);transition-duration:.08s}.checkin-card.checked{border-color:#10b98133;background:#10b9810a}.checkin-icon{width:48px;height:48px;border-radius:var(--radius-icon);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#ffffff0a;border:1px solid var(--glass-border);transition:all .2s}.checkin-icon svg{width:24px;height:24px}.checkin-card.checked .checkin-icon{background:linear-gradient(145deg,#10b98133,#10b9811a);border-color:#10b9814d}.checkin-card.checked .checkin-icon svg{color:var(--color-green-light)}.checkin-info{flex:1;min-width:0}.checkin-name{font-family:var(--font-display);font-weight:600;font-size:.95rem;color:var(--text-primary);line-height:1.3}.checkin-meta{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap}.checkin-points{font-size:.85rem;font-weight:700;color:var(--color-cyan)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-badge);font-size:.68rem;font-weight:600;font-family:var(--font-display);letter-spacing:.03em}.badge-blue{background:#06b6d41a;color:var(--color-cyan-light);border:1px solid rgba(6,182,212,.15)}.badge-green{background:#10b9811a;color:var(--color-green-light);border:1px solid rgba(16,185,129,.15)}.badge-gold{background:#f59e0b1f;color:var(--color-gold-light);border:1px solid rgba(245,158,11,.2)}.badge-red{background:#ef44441a;color:#fda4af;border:1px solid rgba(239,68,68,.15)}.checkin-checkmark{width:auto;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;gap:2px}.checkin-checkmark svg{width:16px;height:16px}.checkin-card.checked .checkin-checkmark svg{color:#fff}.checkin-badge{display:flex;align-items:center;gap:6px}.checkin-count-text{font-family:var(--font-display);font-weight:800;font-size:.78rem;color:var(--color-gold-light);letter-spacing:.02em;animation:pop-in .25s cubic-bezier(.34,1.4,.64,1)}@keyframes pop-in{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.checkin-addon{width:24px;height:24px;border-radius:50%;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;padding:0;line-height:1;flex-shrink:0;color:#fff}.checkin-addon-plus{background:linear-gradient(135deg,var(--color-green),#059669);box-shadow:0 2px 8px #10b9814d}.checkin-addon-plus:hover{background:linear-gradient(135deg,#34D399,var(--color-green));box-shadow:0 4px 14px #10b98173}.checkin-addon-minus{background:linear-gradient(135deg,var(--color-red),#DC2626);box-shadow:0 2px 8px #ef44444d}.checkin-addon-minus:hover{background:linear-gradient(135deg,#F87171,var(--color-red));box-shadow:0 4px 14px #ef444473}.checkin-addon:active{transform:scale(.85)}.tier-section{margin-bottom:36px}.tier-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-left:4px;border-left:3px solid}.tier-badge{display:inline-flex;align-items:center;padding:3px 12px;border-radius:6px;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.tier-bar{font-size:.7rem;letter-spacing:.12em;opacity:.5}.rewards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.reward-card{background:linear-gradient(160deg,#ffffff0a,#ffffff03);border-radius:var(--radius-card);padding:20px 14px 16px;text-align:center;transition:all .3s cubic-bezier(.34,1.2,.64,1);cursor:pointer;border:1px solid var(--glass-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.reward-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;opacity:0;transition:opacity .3s}.reward-card.can-afford{border-color:var(--glow-color, rgba(245, 158, 11, .2))}.reward-card.can-afford:before{opacity:1;background:var(--glow-color, rgba(245, 158, 11, .3))}.reward-card.can-afford:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px #00000080,0 0 40px var(--glow-color, rgba(245,158,11,.1))}.reward-card:active{transform:scale(.96)}.reward-card.cannot-afford{opacity:.3;filter:grayscale(.6);cursor:default}.reward-icon-wrap{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:2px;border:1px solid rgba(255,255,255,.08);transition:all .3s}.reward-card.can-afford .reward-icon-wrap{transform:scale(1)}.reward-card.can-afford:hover .reward-icon-wrap{transform:scale(1.1)}.reward-icon-wrap svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:filter .3s}.reward-card.can-afford:hover .reward-icon-wrap svg{filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}.reward-name{font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--text-primary);line-height:1.3}.reward-flavor{font-size:.68rem;color:var(--text-muted);line-height:1.4;padding:0 2px}.reward-cost{display:inline-flex;align-items:center;gap:4px;color:#fff;padding:5px 14px;border-radius:var(--radius-badge);font-family:var(--font-display);font-weight:700;font-size:.78rem;margin-top:2px;transition:all .2s}.reward-cost.locked{background:transparent;color:var(--text-muted);border:1px solid rgba(255,255,255,.08)}.reward-cost svg{width:12px;height:12px}.record-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--glass-border)}.record-item:last-child{border-bottom:none}.record-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.record-icon svg{width:16px;height:16px}.record-icon.positive{background:#10b9811a;color:var(--color-green-light)}.record-icon.negative{background:#ef444414;color:#fda4af}.record-points{font-family:var(--font-display);font-weight:800;font-size:1.05rem;min-width:48px;text-align:center}.record-points.positive{color:var(--color-green-light)}.record-points.negative{color:#fda4af}.record-info{flex:1;min-width:0}.record-name{font-weight:600;font-size:.9rem}.record-note{font-size:.75rem;color:var(--text-muted);margin-top:1px}.record-time{font-size:.7rem;color:var(--text-muted);text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:3px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;text-align:center}.empty-icon{width:64px;height:64px;border-radius:50%;background:#ffffff0a;display:flex;align-items:center;justify-content:center;border:1px solid var(--glass-border)}.empty-icon svg{width:28px;height:28px;color:var(--text-muted)}.empty-text{font-family:var(--font-display);font-weight:500;color:var(--text-muted);font-size:.9rem}.challenge-card{background:var(--bg-card);border-radius:var(--radius-card);padding:18px 20px;box-shadow:var(--shadow-card);border:1px solid var(--glass-border);margin-bottom:12px;border-left:3px solid var(--color-gold);transition:all .2s;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.challenge-card.completed{border-left-color:var(--color-green);opacity:.6}.challenge-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px}.challenge-name{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--text-primary);line-height:1.3}.challenge-desc{font-size:.82rem;color:var(--text-muted);margin-bottom:10px;line-height:1.5}.challenge-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.challenge-reward{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;font-weight:600;color:var(--color-gold-light)}.challenge-reward svg{color:var(--color-gold)}.challenge-deadline{display:inline-flex;align-items:center;gap:4px;font-size:.76rem;font-weight:500;color:var(--text-muted)}.challenge-deadline.overdue{color:#fda4af}.redemption-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--glass-border)}.redemption-item:last-child{border-bottom:none}.redemption-info{flex:1;min-width:0}.redemption-name{font-family:var(--font-display);font-weight:600;font-size:.88rem}.redemption-cost{font-size:.76rem;color:var(--text-muted);margin-top:2px}.redemption-actions{display:flex;gap:8px;flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-button);border:none;font-family:var(--font-display);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;min-height:48px}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(145deg,var(--color-cyan),var(--color-accent-dark));color:#fff;box-shadow:0 4px 16px #06b6d440}.btn-primary:hover{box-shadow:0 6px 24px #06b6d459;transform:translateY(-1px)}.btn-gold{background:linear-gradient(145deg,var(--color-gold),#D97706);color:#fff;box-shadow:0 4px 16px #f59e0b40}.btn-gold:hover{box-shadow:0 6px 24px #f59e0b59;transform:translateY(-1px)}.btn-success{background:linear-gradient(145deg,var(--color-green),#059669);color:#fff;box-shadow:0 4px 16px #10b98140}.btn-danger{background:linear-gradient(145deg,var(--color-red),#DC2626);color:#fff;box-shadow:0 4px 16px #ef444440}.btn-ghost{background:#ffffff0a;color:var(--text-secondary);border:1px solid var(--glass-border)}.btn-ghost:hover{border-color:#06b6d44d;color:var(--color-cyan-light);background:#06b6d40f}.btn-sm{padding:8px 16px;font-size:.82rem;min-height:40px}.btn-lg{padding:16px 32px;font-size:1rem;min-height:56px;border-radius:16px}.btn:disabled{opacity:.3;cursor:not-allowed;transform:none!important}.admin-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-family:var(--font-display);font-weight:600;font-size:.82rem;color:var(--text-secondary)}.form-input,.form-select{padding:12px 16px;border-radius:var(--radius-button);border:1px solid var(--glass-border);background:#ffffff0a;font-family:var(--font-body);font-size:.92rem;color:var(--text-primary);transition:border-color .2s,box-shadow .2s;min-height:48px}.form-input:focus,.form-select:focus{outline:none;border-color:#06b6d466;box-shadow:0 0 0 3px #06b6d414}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:linear-gradient(145deg,#1e293bf2,#0f172af2);border-radius:24px;padding:32px 28px;width:100%;max-width:400px;box-shadow:0 24px 64px #00000080;animation:modal-in .28s cubic-bezier(.34,1.4,.64,1);border:1px solid var(--glass-border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}@keyframes modal-in{0%{opacity:0;transform:scale(.88) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text-primary);margin-bottom:24px;text-align:center}.modal-icon{width:72px;height:72px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#f59e0b1f,#f59e0b0d);border:1px solid rgba(245,158,11,.2)}.modal-icon svg{width:34px;height:34px;color:var(--color-gold)}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-bottom:12px}.preset-btn{padding:10px 14px;border-radius:10px;border:1px solid var(--glass-border);background:#ffffff08;font-family:var(--font-display);font-weight:500;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .18s;text-align:left;line-height:1.4;display:flex;justify-content:space-between;align-items:center}.preset-btn:hover{border-color:#06b6d440;color:var(--color-cyan-light);background:#06b6d40a}.preset-points{font-weight:700;color:var(--color-cyan);flex-shrink:0;margin-left:8px}.preset-points.negative{color:#fda4af}.msg-toast{padding:12px 20px;border-radius:var(--radius-badge);font-family:var(--font-display);font-weight:600;font-size:.88rem;text-align:center;animation:toast-in .3s cubic-bezier(.34,1.3,.64,1)}.msg-toast.success{background:#10b9811a;color:var(--color-green-light);border:1px solid rgba(16,185,129,.15)}.msg-toast.error{background:#ef444414;color:#fda4af;border:1px solid rgba(239,68,68,.12)}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.section-gap{margin-bottom:28px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff0f,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:10px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#0a0e1ae0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);display:flex;padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:100}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;border:none;background:transparent;cursor:pointer;color:var(--text-muted);transition:color .2s;font-family:var(--font-display);position:relative}.nav-btn.active{color:var(--color-gold)}.nav-btn.active:before{content:"";position:absolute;top:-1px;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--color-gold);border-radius:1px;box-shadow:0 0 10px #f59e0b66}.nav-label{font-size:.65rem;font-weight:600;letter-spacing:.02em}@media (max-width: 640px){.rewards-grid{grid-template-columns:repeat(2,1fr);gap:10px}.admin-grid{grid-template-columns:1fr 1fr}.points-number{font-size:2.2rem}.level-badge{width:68px;height:68px}.level-badge-inner{font-size:1.5rem}.modal{padding:24px 20px;border-radius:20px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){:root{--color-border: rgba(255,255,255,.15);--text-secondary: #CBD5E1;--text-muted: #94A3B8}}
