:root{--color-bg: #FDF6EC;--color-bg-warm: #FAEBD7;--color-surface: #FFFFFF;--color-surface-tint: #FFF9F0;--color-primary: #E07A3A;--color-primary-dark: #C4612E;--color-primary-light: #F5A97A;--color-accent: #5B8C5A;--color-accent-dark: #3D6B3C;--color-accent-light: #A8D5A2;--color-gold: #D4A017;--color-gold-light: #F0C040;--color-danger: #C0392B;--color-success: #5B8C5A;--text-primary: #2C1810;--text-secondary: #6B4C3B;--text-muted: #A08070;--text-inverse: #FFF9F0;--color-border: rgba(139, 90, 60, .15);--color-border-strong: rgba(139, 90, 60, .3);--shadow-card: 0 2px 8px rgba(44, 24, 16, .08), 0 1px 2px rgba(44, 24, 16, .06);--shadow-card-hover: 0 8px 24px rgba(44, 24, 16, .14), 0 2px 6px rgba(44, 24, 16, .08);--shadow-stamp: 0 2px 6px rgba(44, 24, 16, .2);--shadow-button: 0 4px 12px rgba(224, 122, 58, .3);--radius-card: 16px;--radius-button: 12px;--radius-badge: 999px;--radius-icon: 12px;--font-display: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", "Nunito", sans-serif;--font-body: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", "Quicksand", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;background-image:radial-gradient(circle at 15% 20%,rgba(224,122,58,.04) 0%,transparent 40%),radial-gradient(circle at 85% 80%,rgba(91,140,90,.05) 0%,transparent 40%)}#root{position:relative;z-index:1}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-primary-light);border-radius:3px}::selection{background:var(--color-gold-light);color:var(--text-primary)}.card{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);border:1.5px solid var(--color-border);padding:20px}.page{max-width:860px;margin:0 auto;padding:16px 16px 100px}.page-header{font-family:var(--font-display);font-weight:900;font-size:1.25rem;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.01em}.role-switcher{position:fixed;top:0;left:0;right:0;z-index:100;background:#fdf6ece0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1.5px solid var(--color-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:900;font-size:1.1rem;color:var(--color-primary);letter-spacing:-.02em;display:flex;align-items:center;gap:6px;flex-shrink:0}.role-tabs{display:flex;background:#e07a3a14;border-radius:12px;padding:3px;gap:2px}.role-tab{padding:7px 18px;border-radius:9px;border:none;background:transparent;font-family:var(--font-display);font-weight:700;font-size:.875rem;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.34,1.2,.64,1);display:flex;align-items:center;gap:6px;-webkit-tap-highlight-color:transparent}.role-tab.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-card)}.role-tab:not(.active):hover{color:var(--color-primary)}.main-content{padding-top:68px}.points-hero{background:var(--color-surface);border-radius:24px;padding:28px 24px 24px;box-shadow:var(--shadow-card-hover);border:1.5px solid var(--color-border);margin-bottom:24px;position:relative;overflow:hidden;text-align:center}.points-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-gold) 33%,var(--color-accent) 66%,var(--color-primary) 100%)}.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:.15;transform:scale(1) rotate(0)}50%{opacity:.35;transform:scale(1.15) rotate(15deg)}}.hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:8px}.level-badge{width:88px;height:88px;border-radius:50%;background:linear-gradient(145deg,#fef3e2,#fde8c8);border:3px solid var(--color-gold);box-shadow:0 4px 16px #d4a01740,inset 0 1px #fffc;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:2rem;color:var(--color-gold);line-height:1;text-shadow:0 1px 0 rgba(255,255,255,.8)}.level-badge-label{font-family:var(--font-display);font-size:.6rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em}.points-number{font-family:var(--font-display);font-size:3rem;font-weight:900;color:var(--text-primary);line-height:1;letter-spacing:-.03em}.level-name{font-family:var(--font-display);font-size:1.1rem;font-weight:800;color:var(--color-primary)}.progress-wrapper{width:100%;max-width:320px;margin:8px auto 0}.progress-bar{height:10px;border-radius:999px;background:#e07a3a1f;overflow:hidden;position:relative}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--color-primary),var(--color-gold));transition:width .7s cubic-bezier(.34,1.3,.64,1);position:relative}.progress-fill:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--color-gold-light);box-shadow:0 0 6px #f0c04099}.progress-label{font-size:.8rem;color:var(--text-muted);margin-top:6px;font-weight:600}.checkin-card{background:var(--color-surface);border-radius:var(--radius-card);padding:16px 18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .22s cubic-bezier(.34,1.3,.64,1);border:1.5px solid var(--color-border);box-shadow:var(--shadow-card);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.checkin-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 60%,rgba(224,122,58,.03));pointer-events:none}.checkin-card:hover{transform:translateY(-3px) scale(1.01);box-shadow:var(--shadow-card-hover);border-color:var(--color-primary-light)}.checkin-card:active{transform:scale(.98);transition-duration:.1s}.checkin-card.checked{border-color:var(--color-accent-light);background:linear-gradient(135deg,var(--color-surface),rgba(168,213,162,.08))}.checkin-card.checked:after{content:"";position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:50%;background:var(--color-accent);display:flex;align-items:center;justify-content:center}.checkin-icon{width:52px;height:52px;border-radius:var(--radius-icon);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(145deg,#e07a3a1a,#e07a3a0d);border:1.5px solid rgba(224,122,58,.15);transition:all .2s;position:relative}.checkin-icon svg{width:26px;height:26px}.checkin-card.checked .checkin-icon{background:linear-gradient(145deg,var(--color-accent),var(--color-accent-dark));border-color:var(--color-accent)}.checkin-card.checked .checkin-icon svg{color:#fff}.checkin-info{flex:1;min-width:0}.checkin-name{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--text-primary);line-height:1.3}.checkin-meta{display:flex;align-items:center;gap:8px;margin-top:3px;flex-wrap:wrap}.checkin-points{font-size:.875rem;font-weight:800;color:var(--color-primary)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-badge);font-size:.7rem;font-weight:700;font-family:var(--font-display);letter-spacing:.02em}.badge-blue{background:#e07a3a1a;color:var(--color-primary);border:1px solid rgba(224,122,58,.15)}.badge-green{background:#5b8c5a1a;color:var(--color-accent-dark);border:1px solid rgba(91,140,90,.15)}.badge-gold{background:#d4a0171f;color:#9a7209;border:1px solid rgba(212,160,23,.2)}.badge-red{background:#c0392b1a;color:var(--color-danger);border:1px solid rgba(192,57,43,.15)}.checkin-checkmark{width:32px;height:32px;border-radius:50%;border:2px solid var(--color-border-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.checkin-checkmark svg{width:16px;height:16px}.checkin-card.checked .checkin-checkmark{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.tier-section{margin-bottom:32px}.tier-title{font-family:var(--font-display);font-weight:900;font-size:1.05rem;margin-bottom:14px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.tier-title-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center}.tier-title-icon svg{width:16px;height:16px}.tier-title基础 .tier-title-icon{background:#5b8c5a1f;color:var(--color-accent)}.tier-title中档 .tier-title-icon{background:#d4a0171f;color:var(--color-gold)}.tier-title高档 .tier-title-icon{background:#c0392b1a;color:var(--color-danger)}.tier-title基础{color:var(--color-accent-dark)}.tier-title中档{color:#9a7209}.tier-title高档{color:var(--color-danger)}.rewards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.reward-card{background:var(--color-surface);border-radius:var(--radius-card);padding:20px 16px 16px;text-align:center;transition:all .22s cubic-bezier(.34,1.3,.64,1);cursor:pointer;border:1.5px solid var(--color-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;overflow:hidden}.reward-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;opacity:0;transition:opacity .2s;pointer-events:none}.reward-card.can-afford{border-color:var(--color-gold)}.reward-card.can-afford:before{background:radial-gradient(circle at center,rgba(212,160,23,.06),transparent 70%);opacity:1}.reward-card.can-afford:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 28px #d4a01733,var(--shadow-card)}.reward-card:active{transform:scale(.97)}.reward-card.cannot-afford{opacity:.5;filter:grayscale(30%)}.reward-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:4px}.reward-icon svg{width:28px;height:28px}.reward-icon基础{background:linear-gradient(145deg,#e8f5e9,#c8e6c9);color:var(--color-accent)}.reward-icon中档{background:linear-gradient(145deg,#fff8e1,#ffecb3);color:var(--color-gold)}.reward-icon高档{background:linear-gradient(145deg,#fce4ec,#f8bbd9);color:var(--color-danger)}.reward-name{font-family:var(--font-display);font-weight:700;font-size:.9rem;color:var(--text-primary);line-height:1.3}.reward-cost{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,var(--color-gold),#C4910F);color:#fff;padding:4px 14px;border-radius:var(--radius-badge);font-family:var(--font-display);font-weight:800;font-size:.8rem;box-shadow:0 2px 8px #d4a0174d}.reward-cost svg{width:12px;height:12px}.record-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px dashed var(--color-border)}.record-item:last-child{border-bottom:none}.record-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.record-icon svg{width:18px;height:18px}.record-icon.positive{background:#5b8c5a1a;color:var(--color-accent)}.record-icon.negative{background:#c0392b14;color:var(--color-danger)}.record-points{font-family:var(--font-display);font-weight:900;font-size:1.125rem;min-width:52px;text-align:center}.record-points.positive{color:var(--color-accent-dark)}.record-points.negative{color:var(--color-danger)}.record-info{flex:1;min-width:0}.record-name{font-weight:700;font-size:.95rem}.record-note{font-size:.78rem;color:var(--text-muted);margin-top:1px}.record-time{font-size:.72rem;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:72px;height:72px;border-radius:50%;background:linear-gradient(145deg,#f5f0eb,#ede5da);display:flex;align-items:center;justify-content:center}.empty-icon svg{width:32px;height:32px;color:var(--text-muted)}.empty-text{font-family:var(--font-display);font-weight:600;color:var(--text-muted);font-size:.95rem}.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:700;font-size:.95rem;cursor:pointer;transition:all .2s cubic-bezier(.34,1.2,.64,1);-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-primary),var(--color-primary-dark));color:#fff;box-shadow:var(--shadow-button)}.btn-primary:hover{box-shadow:0 6px 20px #e07a3a66;transform:translateY(-2px)}.btn-gold{background:linear-gradient(145deg,var(--color-gold),#B88A0F);color:#fff;box-shadow:0 4px 12px #d4a0174d}.btn-gold:hover{box-shadow:0 6px 20px #d4a01766;transform:translateY(-2px)}.btn-success{background:linear-gradient(145deg,var(--color-accent),var(--color-accent-dark));color:#fff;box-shadow:0 4px 12px #5b8c5a4d}.btn-ghost{background:transparent;color:var(--text-secondary);border:1.5px solid var(--color-border-strong)}.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-sm{padding:8px 16px;font-size:.85rem;min-height:40px}.btn-lg{padding:16px 32px;font-size:1.05rem;min-height:56px;border-radius:16px}.btn:disabled{opacity:.5;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:700;font-size:.85rem;color:var(--text-secondary)}.form-input,.form-select{padding:12px 16px;border-radius:var(--radius-button);border:1.5px solid var(--color-border-strong);background:var(--color-surface);font-family:var(--font-body);font-size:.95rem;color:var(--text-primary);transition:border-color .2s,box-shadow .2s;min-height:48px}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #e07a3a1f}.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:#2c181066;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);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:var(--color-surface);border-radius:24px;padding:32px 28px;width:100%;max-width:400px;box-shadow:0 24px 60px #2c181040;animation:modal-in .28s cubic-bezier(.34,1.4,.64,1);border:1.5px solid var(--color-border)}@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:900;font-size:1.3rem;color:var(--text-primary);margin-bottom:24px;text-align:center}.modal-icon{width:80px;height:80px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#d4a0171f,#d4a0170d);border:2px solid rgba(212,160,23,.2)}.modal-icon svg{width:36px;height:36px;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:1.5px solid var(--color-border);background:var(--color-surface-tint);font-family:var(--font-display);font-weight:600;font-size:.82rem;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:var(--color-primary-light);color:var(--color-primary);background:#e07a3a0a}.preset-points{font-weight:800;color:var(--color-primary);flex-shrink:0;margin-left:8px}.preset-points.negative{color:var(--color-danger)}.msg-toast{padding:12px 20px;border-radius:var(--radius-badge);font-family:var(--font-display);font-weight:700;font-size:.9rem;text-align:center;animation:toast-in .3s cubic-bezier(.34,1.3,.64,1)}.msg-toast.success{background:#5b8c5a1f;color:var(--color-accent-dark);border:1px solid rgba(91,140,90,.2)}.msg-toast.error{background:#c0392b1a;color:var(--color-danger);border:1px solid rgba(192,57,43,.15)}@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 pulse-subtle{0%,to{opacity:1}50%{opacity:.6}}.loading-skeleton{background:linear-gradient(90deg,#f0ebe3 25%,#faf5ee,#f0ebe3 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:10px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@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.4rem}.level-badge{width:72px;height:72px}.level-badge-inner{font-size:1.6rem}.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(44,24,16,.3);--text-secondary: #3D2A1F;--text-muted: #5C3D2E}}
