@import "https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;700;900&family=Outfit:wght@300;400;500;600;700;800&display=swap";
:root{--font-zh:"Noto Sans TC", sans-serif;--font-en:"Outfit", sans-serif;--font-heading:"Noto Sans TC", sans-serif;--primary:#7c3aed;--primary-light:#a78bfa;--primary-dark:#5b21b6;--accent:#f59e0b;--accent-light:#fbbf24;--accent-dark:#d97706;--success:#10b981;--danger:#ef4444;--info:#3b82f6;--bg-dark:#0f0b1a;--bg-card:#ffffff0f;--bg-card-hover:#ffffff1a;--glass:#ffffff14;--glass-border:#ffffff1f;--input-bg:#ffffff0f;--hero-bg:linear-gradient(180deg, #0f0b1a 0%, #1a0e2e 50%, #0f0b1a 100%);--hero-glow:radial-gradient(ellipse at 50% 0%, #7c3aed33 0%, transparent 70%);--modal-bg:linear-gradient(145deg, #1e1145, #2d1b69);--text:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--gradient-hero:linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-gold:linear-gradient(135deg, #f6d365 0%, #fda085 100%);--gradient-card:linear-gradient(145deg, #7c3aed26, #f59e0b14);--gradient-btn:linear-gradient(135deg, #7c3aed 0%, #ec4899 100%);--shadow-glow:0 0 30px #7c3aed4d;--shadow-card:0 8px 32px #0000004d;--radius:16px;--radius-sm:10px;--radius-full:9999px;--heading-scale:1;--body-size:16px;--spacing:1.25rem;--transition:all .3s cubic-bezier(.4, 0, .2, 1);--admin-bg:#0f172a;--admin-sidebar:#1e293b;--admin-card:#1e293b;--admin-border:#334155;--admin-hover:#334155}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-zh);font-size:var(--body-size);background:var(--bg-dark);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}h1,h2,h3,h4{font-family:var(--font-heading)}input,select,textarea{font:inherit;color:var(--text);background:var(--input-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);width:100%;transition:var(--transition);outline:none;padding:.7rem 1rem}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed33}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.font-en{font-family:var(--font-en)}.text-gradient{background:var(--gradient-hero);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.text-gold{background:var(--gradient-gold);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius);transition:var(--transition)}.glass-card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-glow);border-color:#7c3aed4d}.btn{border-radius:var(--radius-full);transition:var(--transition);justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";transition:var(--transition);background:#fff0;position:absolute;inset:0}.btn:hover:after{background:#ffffff1a}.btn:active{transform:scale(.96)}.btn-primary{background:var(--gradient-btn);color:#fff;box-shadow:0 4px 15px #7c3aed66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 25px #7c3aed80}.btn-gold{background:var(--gradient-gold);color:#1a1a2e;font-weight:700;box-shadow:0 4px 15px #f59e0b66}.btn-gold:hover{transform:translateY(-2px);box-shadow:0 6px 25px #f59e0b80}.btn-outline{border:1.5px solid var(--glass-border);color:var(--text);background:0 0}.btn-outline:hover{border-color:var(--primary);background:#7c3aed1a}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-lg{padding:1rem 2.5rem;font-size:1.1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.badge{border-radius:var(--radius-full);align-items:center;gap:.3rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{color:var(--primary-light);background:#7c3aed33}.badge-gold{color:var(--accent-light);background:#f59e0b33}.badge-success{color:var(--success);background:#10b98133}.badge-danger{color:var(--danger);background:#ef444433}.hero-bg{background:var(--hero-bg);position:relative;overflow:hidden}.hero-bg:before{content:"";background:var(--hero-glow);position:absolute;inset:0}.floating-orb{filter:blur(60px);opacity:.4;border-radius:50%;animation:8s ease-in-out infinite float;position:absolute}.banner-track{transition:transform .6s cubic-bezier(.25,.46,.45,.94);display:flex}.banner-slide{aspect-ratio:21/9;border-radius:var(--radius);min-width:100%;position:relative;overflow:hidden}.banner-slide img{object-fit:cover;width:100%;height:100%}.banner-dots{justify-content:center;gap:.5rem;margin-top:1rem;display:flex}.banner-dot{background:var(--glass-border);width:10px;height:10px;transition:var(--transition);cursor:pointer;border-radius:50%}.banner-dot.active{background:var(--primary);border-radius:5px;width:28px}.project-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.project-carousel{position:relative}.project-carousel-viewport{border-radius:var(--radius);overflow:hidden}.project-carousel-track{transition:transform .5s cubic-bezier(.25,.46,.45,.94);display:flex}.project-carousel-slide{box-sizing:border-box;flex:0 0 33.3333%;padding:0 .75rem}.project-carousel-nav{z-index:10;background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;width:44px;height:44px;transition:var(--transition);color:var(--text);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.project-carousel-nav:hover{background:var(--primary);border-color:var(--primary);box-shadow:var(--shadow-glow)}.project-carousel-nav.prev{left:-22px}.project-carousel-nav.next{right:-22px}.project-carousel-dots{justify-content:center;gap:.5rem;margin-top:1.25rem;display:flex}.project-carousel-dot{background:var(--glass-border);width:10px;height:10px;transition:var(--transition);cursor:pointer;border-radius:50%}.project-carousel-dot.active{background:var(--primary);border-radius:5px;width:28px}.project-carousel-counter{text-align:center;color:var(--text-muted);font-size:.8rem;font-family:var(--font-en);margin-top:.5rem}.project-carousel-toggle{justify-content:flex-end;gap:.5rem;margin-bottom:.5rem;display:flex}.project-carousel-toggle button{border-radius:var(--radius-sm);background:var(--glass);border:1px solid var(--glass-border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;display:flex}.project-carousel-toggle button.active{background:var(--primary);border-color:var(--primary);color:#fff}.project-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius);transition:var(--transition);position:relative;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-glow);border-color:#7c3aed66;transform:translateY(-8px)}.project-carousel-slide .project-card:hover{transform:translateY(-4px)}.project-card-img{aspect-ratio:4/3;object-fit:cover;background:var(--gradient-card);width:100%}.project-card-body{padding:1.25rem}.project-card-title{margin-bottom:.5rem;font-size:1.1rem;font-weight:700}.project-card-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:1rem;font-size:.85rem;line-height:1.5;display:-webkit-box;overflow:hidden}.vote-count{font-family:var(--font-en);background:var(--gradient-gold);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:800}.vote-label{color:var(--text-muted);margin-left:.3rem;font-size:.75rem}@media (max-width:1024px){.project-carousel-slide{flex:0 0 50%}}@media (max-width:640px){.project-carousel-slide{flex:0 0 100%}.project-carousel-nav.prev{left:-12px}.project-carousel-nav.next{right:-12px}.project-carousel-nav{width:36px;height:36px}}.game-container{flex-direction:column;justify-content:center;align-items:center;min-height:80vh;padding:2rem;display:flex}.game-title{text-align:center;margin-bottom:2rem;font-size:2rem;font-weight:900}.wheel-wrapper{width:340px;height:340px;position:relative}.wheel-canvas{width:100%;height:100%}.wheel-pointer{border-left:16px solid #0000;border-right:16px solid #0000;border-top:36px solid var(--accent);filter:drop-shadow(0 2px 4px #0006);z-index:10;width:0;height:0;position:absolute;top:-18px;left:50%;transform:translate(-50%)}.wheel-center{background:var(--gradient-gold);color:#1a1a2e;cursor:pointer;z-index:10;width:60px;height:60px;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:900;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 20px #f59e0b80}.wheel-center:hover{transform:translate(-50%,-50%)scale(1.1)}.scratch-container{border-radius:var(--radius);width:320px;height:200px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.scratch-result{background:var(--gradient-card);flex-direction:column;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex;position:absolute;inset:0}.scratch-canvas{cursor:crosshair;touch-action:none;position:absolute;inset:0}.slot-machine{background:var(--modal-bg);border:3px solid var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-glow);padding:2rem}.slot-reels{justify-content:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.slot-reel-window{border-radius:var(--radius-sm);border:2px solid var(--accent-dark);background:#0006;width:90px;height:90px;position:relative;overflow:hidden}.slot-reel-strip{flex-direction:column;align-items:center;transition:transform .1s linear;display:flex}.slot-symbol{justify-content:center;align-items:center;width:90px;height:90px;font-size:2.5rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--modal-bg);border:1px solid var(--glass-border);border-radius:var(--radius);text-align:center;width:90%;max-width:420px;padding:2.5rem;animation:.4s cubic-bezier(.175,.885,.32,1.275) scaleIn;position:relative;overflow:hidden}.modal-content.win{border-color:#f59e0b80;box-shadow:0 0 60px #f59e0b33}.claim-form{max-width:500px;margin:0 auto;padding:2rem}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.form-error{color:var(--danger);margin-top:.3rem;font-size:.8rem}@keyframes prizeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes prizeShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes prizePulseGlow{0%,to{box-shadow:0 4px 20px #ffb8001a}50%{box-shadow:0 8px 40px #ffb80040}}.prize-card-animated{transition:transform .3s,box-shadow .3s;animation:3s ease-in-out infinite prizeFloat,3s ease-in-out infinite prizePulseGlow;position:relative;overflow:hidden}.prize-card-animated:after{content:"";pointer-events:none;z-index:2;background:linear-gradient(105deg,#0000 40%,#ffffff1f 45%,#fff3 50%,#ffffff1f 55%,#0000 60%) 0 0/200% 100%;animation:4s ease-in-out infinite prizeShimmer;position:absolute;inset:0}.prize-card-animated:hover{transform:translateY(-8px)scale(1.03)!important;box-shadow:0 12px 40px #ffb8004d!important}.admin-layout{background:var(--admin-bg);color:#e2e8f0;--text:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--glass-border:#334155;--input-bg:#0f172a;min-height:100vh;display:flex}.admin-sidebar{background:var(--admin-sidebar);border-right:1px solid var(--admin-border);flex-direction:column;width:260px;height:100vh;padding:1.5rem 0;display:flex;position:fixed;overflow-y:auto}.admin-sidebar-logo{border-bottom:1px solid var(--admin-border);margin-bottom:1rem;padding:0 1.5rem 1.5rem}.admin-sidebar-logo h2{background:var(--gradient-hero);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:800}.admin-nav{flex:1;padding:.5rem}.admin-nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition);align-items:center;gap:.75rem;margin-bottom:2px;padding:.75rem 1rem;font-size:.9rem;display:flex}.admin-nav-item:hover{background:var(--admin-hover);color:var(--text)}.admin-nav-item.active{color:var(--primary-light);background:#7c3aed26;font-weight:600}.admin-main{flex:1;margin-left:260px;padding:2rem}.admin-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.admin-header h1{font-size:1.6rem;font-weight:800}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--admin-card);border:1px solid var(--admin-border);border-radius:var(--radius);transition:var(--transition);padding:1.5rem}.stat-card:hover{border-color:var(--primary);box-shadow:var(--shadow-glow)}.stat-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.8rem}.stat-card-value{font-family:var(--font-en);font-size:2rem;font-weight:800}.stat-card-trend{margin-top:.3rem;font-size:.8rem}.data-table{border-collapse:collapse;background:var(--admin-card);border-radius:var(--radius);border:1px solid var(--admin-border);width:100%;overflow:hidden}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--admin-border);padding:.85rem 1rem;font-size:.8rem;font-weight:600}.data-table td{border-bottom:1px solid #33415580;padding:.85rem 1rem;font-size:.9rem}.data-table tr:hover td{background:#7c3aed0d}.data-table tr:last-child td{border-bottom:none}.admin-panel{background:var(--admin-card);border:1px solid var(--admin-border);border-radius:var(--radius);padding:1.5rem}.admin-panel-title{border-bottom:1px solid var(--admin-border);margin-bottom:1.25rem;padding-bottom:.75rem;font-size:1.1rem;font-weight:700}.img-hint{color:var(--info);border-radius:var(--radius-full);background:#3b82f614;border:1px solid #3b82f633;align-items:center;gap:.35rem;margin-bottom:.75rem;padding:.3rem .85rem;font-size:.78rem;display:inline-flex}.img-hint strong{color:var(--accent-light);font-weight:600}.chart-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.25rem;margin-bottom:2rem;display:grid}.chart-card{background:var(--admin-card);border:1px solid var(--admin-border);border-radius:var(--radius);padding:1.5rem}.chart-card-title{color:var(--text-secondary);margin-bottom:1rem;font-size:.95rem;font-weight:700}.inventory-bar{background:#ffffff14;border-radius:4px;height:8px;overflow:hidden}.inventory-bar-fill{border-radius:4px;height:100%;transition:width .6s}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-30px)scale(1.05)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #7c3aed4d}50%{box-shadow:0 0 40px #7c3aed99}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.animate-fade-in{animation:.5s forwards fadeIn}.animate-slide-up{animation:.6s forwards slideUp}.animate-pulse-glow{animation:2s ease-in-out infinite pulse-glow}.stagger>:first-child{animation-delay:50ms}.stagger>:nth-child(2){animation-delay:.1s}.stagger>:nth-child(3){animation-delay:.15s}.stagger>:nth-child(4){animation-delay:.2s}.stagger>:nth-child(5){animation-delay:.25s}.stagger>:nth-child(6){animation-delay:.3s}.edit-with-preview{grid-template-columns:1fr 1fr;align-items:start;gap:1.5rem;display:grid}.edit-with-preview .edit-form-side{min-width:0}.preview-panel{background:var(--admin-card);border:2px dashed var(--primary);border-radius:var(--radius);padding:1rem;position:sticky;top:1rem}.preview-panel-header{color:var(--primary-light);border-bottom:1px solid var(--admin-border);align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;font-size:.8rem;font-weight:600;display:flex}.preview-panel-header:before{content:"";background:var(--success);width:8px;height:8px;box-shadow:0 0 6px var(--success);border-radius:50%;animation:2s infinite pulse-glow}.preview-viewport{background:var(--hero-bg);border-radius:var(--radius-sm);padding:1.25rem;position:relative;overflow:hidden}.preview-viewport:before{content:"";background:var(--hero-glow);pointer-events:none;position:absolute;inset:0}.preview-viewport>*{z-index:1;position:relative}.preview-scale-notice{text-align:center;color:var(--text-muted);margin-top:.75rem;font-size:.7rem;font-style:italic}@media (max-width:768px){.project-grid,.chart-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.admin-sidebar{display:none}.admin-main{margin-left:0}.wheel-wrapper{width:280px;height:280px}.game-title{font-size:1.5rem}.slot-reel-window{width:70px;height:70px}.slot-symbol{width:70px;height:70px;font-size:2rem}.edit-with-preview{grid-template-columns:1fr}}
