*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Helvetica Neue,sans-serif;font-size:15px;line-height:1.6}a{color:inherit;text-decoration:none}ol,ul{list-style:none}img{display:block;max-width:100%}button,input,select,textarea{font-family:inherit;font-size:inherit}input,select,textarea{background:#fff;color:#333}h1{font-size:1.75rem}h1,h2{font-weight:700;line-height:1.3}h2{font-size:1.35rem}h3{font-size:1.15rem;font-weight:600;line-height:1.4}p{font-size:.95rem;line-height:1.7}@media (max-width:768px){body{font-size:14px}h1{font-size:1.45rem}h2{font-size:1.2rem}h3{font-size:1.05rem}}@media (max-width:480px){body{font-size:13px}h1{font-size:1.3rem}h2{font-size:1.1rem}h3{font-size:1rem}}:focus-visible{outline:2px solid #6366f1;outline-offset:2px}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}*{scrollbar-color:#ccc #0000;scrollbar-width:thin}.container{margin:0 auto;max-width:1200px;padding:0 24px}@media (max-width:480px){.container{padding:0 12px}}.recharge-modal{animation:rechargeIn .3s cubic-bezier(.22,.61,.36,1);background:#fff;border-radius:20px;box-shadow:0 24px 80px #00000040;max-width:780px;overflow:hidden;width:100%}@keyframes rechargeIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.recharge-header{align-items:center;display:flex;justify-content:space-between;padding:28px 40px 20px}.recharge-header h3{color:#1a1a1a;font-size:1.2rem;font-weight:700}.recharge-close{align-items:center;background:#f0f0f0;border:none;border-radius:50%;color:#888;cursor:pointer;display:flex;font-size:.9rem;height:32px;justify-content:center;transition:all .2s;width:32px}.recharge-close:hover{background:#e0e0e0;color:#333}.recharge-body{padding:0 40px 36px}.recharge-balance-row{align-items:baseline;background:linear-gradient(135deg,#f5f0ff,#ede0ff);border-radius:14px;display:flex;gap:10px;justify-content:center;margin-bottom:28px;padding:14px 24px}.recharge-balance-label{color:#8b6fc0;font-size:.85rem}.recharge-balance-value{color:#6b3fb0;font-size:1.8rem;font-weight:800;line-height:1}.recharge-balance-unit{color:#8b6fc0;font-size:.85rem}.recharge-pkg-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.recharge-pkg-card{align-items:center;background:#fff;border:2px solid #e8ecf1;border-radius:16px;cursor:pointer;display:flex;flex-direction:column;gap:8px;overflow:hidden;padding:20px 14px 18px;position:relative;text-align:center;transition:all .25s}.recharge-pkg-card:hover{border-color:#667eea;box-shadow:0 12px 32px #667eea26;transform:translateY(-4px)}.recharge-pkg-top{align-items:center;display:flex;gap:6px}.recharge-pkg-icon{font-size:1.1rem}.recharge-pkg-name{color:#444;font-size:.82rem;font-weight:600}.recharge-pkg-credits{color:#1a1a1a;font-size:1.2rem;font-weight:700;line-height:1}.recharge-pkg-credits span{color:#888;font-size:.72rem;font-weight:400}.recharge-pkg-tag{background:#e53935;border-radius:10px;color:#fff;font-size:.7rem;font-weight:600;line-height:1.4;padding:2px 10px}.recharge-pkg-price{color:#e65100;font-size:1.3rem;font-weight:800;line-height:1}.recharge-pkg-original{color:#bbb;font-size:.75rem;margin-top:-4px;text-decoration:line-through}.recharge-pkg-btn{border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;margin-top:4px;padding:8px 0;transition:all .2s;width:100%}.recharge-pkg-btn:hover{opacity:.9;transform:scale(1.02)}.recharge-qr-body{align-items:stretch;display:flex;gap:40px}.recharge-qr-left{display:flex;flex:1 1;flex-direction:column;justify-content:center}.recharge-qr-order-title{color:#1a1a1a;font-size:1rem;font-weight:700;margin-bottom:16px}.recharge-qr-info-item{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:10px 0}.recharge-qr-info-label{color:#888;font-size:.88rem}.recharge-qr-info-value{color:#333;font-size:.9rem;font-weight:500}.recharge-qr-price{color:#e65100;font-size:1.3rem;font-weight:800}.recharge-qr-info-divider{background:#e0e0e0;height:1px;margin:16px 0}.recharge-qr-mock-hint{color:#666;display:flex;flex-direction:column;font-size:.85rem;gap:4px;margin-bottom:16px}.recharge-qr-mock-btn{background:#43a047;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px;transition:all .2s;width:100%}.recharge-qr-mock-btn:hover{background:#388e3c}.recharge-qr-mock-btn:disabled{cursor:not-allowed;opacity:.5}.recharge-qr-right{align-items:center;display:flex;flex-direction:column;justify-content:center}.recharge-qr-frame{background:#fff;border:2px solid #e8ecf1;border-radius:16px;box-shadow:0 4px 20px #0000000d;margin-bottom:12px;padding:18px}.recharge-qr-frame,.recharge-qr-inner{line-height:0;position:relative}.recharge-qr-scanning{animation:qrScan 2s ease-in-out infinite;background:linear-gradient(180deg,#0000 0,#667eea0f 50%,#0000);border-radius:4px;inset:0;position:absolute}@keyframes qrScan{0%,to{transform:translateY(-100%)}50%{transform:translateY(100%)}}.recharge-qr-hint{color:#666;font-size:.85rem;margin-bottom:4px}.recharge-qr-status{color:#aaa;font-size:.78rem;margin-bottom:12px}.recharge-qr-back-link{background:none;border:none;color:#888;cursor:pointer;font-size:.82rem;transition:color .2s}.recharge-qr-back-link:hover{color:#667eea}.recharge-success-body{align-items:center;display:flex;gap:28px;padding:16px 40px 40px}.recharge-success-left{flex-shrink:0}.recharge-success-right{flex:1 1}.recharge-success-title{color:#2e7d32;font-size:1.2rem;font-weight:700;margin-bottom:6px}.recharge-success-detail{color:#666;font-size:.9rem;margin-bottom:6px}.recharge-success-balance{color:#666;font-size:.88rem;margin-bottom:18px}.recharge-success-balance strong{color:#6b3fb0;font-size:1rem}.recharge-success-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 40px;transition:all .2s}.recharge-success-btn:hover{opacity:.9}.recharge-spinner{animation:spin .7s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#667eea;height:32px;margin:0 auto;width:32px}@media (max-width:640px){.recharge-modal{border-radius:0;max-width:100%}.recharge-header{padding:20px 20px 12px}.recharge-body{padding:0 20px 24px}.recharge-pkg-row{grid-template-columns:1fr 1fr}.recharge-qr-body{flex-direction:column;gap:20px}.recharge-success-body{flex-direction:column;text-align:center}}.navbar{background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 1px 4px #0000000a;position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:100}.navbar-container{align-items:center;display:flex;height:60px;justify-content:space-between;margin:0 auto;padding:0 32px;width:100%}.navbar-brand{align-items:center;color:#1a73e8;display:flex;font-size:1.2rem;font-weight:700;gap:8px;text-decoration:none;white-space:nowrap}.navbar-logo-icon{font-size:1.4rem;line-height:1}.navbar-logo-img{border-radius:6px;height:32px;width:auto}.navbar-links{align-items:center;display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-end}.nav-link{border-radius:6px;color:#555;font-size:.95rem;padding:6px 12px;text-decoration:none;transition:all .2s;white-space:nowrap}.nav-link:hover{background:#f5f5f5;color:#1a73e8}.nav-link.active{background:#e8f0fe;color:#1a73e8;font-weight:600}.admin-link{color:#e65100;font-weight:500}.admin-link.active,.admin-link:hover{background:#fff3e0;color:#e65100}.admin-link.active{font-weight:600}.nav-user-info{align-items:center;display:flex;gap:8px}.nav-username{color:#333;font-size:.9rem;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-badge{border-radius:10px;display:inline-block;font-size:.7rem;font-weight:600;margin-left:6px;padding:2px 8px}.nav-badge.admin{background:#fff3e0;color:#e65100}.nav-badge.user{background:#e8f0fe;color:#1a73e8}.nav-btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 18px;transition:all .2s;white-space:nowrap}.register-btn{background:#1a73e8;color:#fff;text-decoration:none}.register-btn.active,.register-btn:hover{background:#1557b0}.logout-btn{background:#f5f5f5;color:#666}.logout-btn:hover{background:#e0e0e0;color:#333}.nav-btn:focus-visible,.nav-link:focus-visible{outline:2px solid #1a73e8;outline-offset:2px}@media (max-width:768px){.navbar-container{height:52px;padding:0 16px}.navbar-brand{font-size:1rem}.navbar-links{gap:8px}.nav-link{font-size:.85rem;padding:4px 8px}.nav-btn{font-size:.8rem;padding:6px 12px}.nav-username{font-size:.8rem;max-width:80px}.nav-badge{font-size:.65rem;padding:1px 6px}}@media (max-width:480px){.navbar-container{height:48px;padding:0 10px}.navbar-brand{font-size:.9rem;gap:4px}.navbar-links{gap:4px}.nav-link{font-size:.78rem;padding:3px 6px}.nav-btn{font-size:.75rem;padding:5px 10px}.nav-username{display:none}.nav-badge{margin-left:0}}@media (max-width:380px){.navbar-container{padding:0 6px}.navbar-brand{font-size:.8rem}.navbar-links{gap:2px}.nav-link{font-size:.7rem;padding:3px 4px}.nav-btn{font-size:.7rem;padding:4px 8px}}.auth-page{align-items:center;background:radial-gradient(ellipse 70% 50% at 50% 0,#1a1020 0,#0a0a0f 70%);display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:40px 24px;position:relative}.auth-page:before{animation:spotlightPulse 6s ease-in-out infinite;background:radial-gradient(ellipse at 50% 0,#c8a45c1f 0,#c8a45c08 40%,#0000 70%);content:"";height:420px;left:50%;pointer-events:none;position:absolute;top:0;transform:translateX(-50%);width:600px}@keyframes spotlightPulse{0%,to{opacity:.6;transform:translateX(-50%) scaleX(1)}50%{opacity:1;transform:translateX(-50%) scaleX(1.15)}}.auth-page:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)' opacity='.5'/%3E%3C/svg%3E");background-size:200px 200px;content:"";inset:0;opacity:.03;pointer-events:none;position:absolute}.auth-brand{animation:brandSlideIn .8s cubic-bezier(.22,.61,.36,1) both;margin-bottom:40px;text-align:center;z-index:1}@keyframes brandSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.auth-brand-icon{display:block;filter:drop-shadow(0 0 20px rgba(200,164,92,.3));font-size:52px;margin-bottom:10px}.auth-brand h1{color:#f5ede0;font-family:Georgia,"Noto Serif SC",STSong,serif;font-size:2.4rem;font-weight:700;letter-spacing:8px;margin:0 0 14px;text-shadow:0 0 40px #c8a45c40}.auth-brand-divider{background:linear-gradient(90deg,#0000,#e8c97a 20%,#e8c97a 80%,#0000);height:2px;margin:0 auto 16px;width:80px}.auth-brand p{color:#c8a45ca6;font-size:.95rem;letter-spacing:3px}.auth-card{animation:cardDropIn .6s cubic-bezier(.22,.61,.36,1) .2s both;backdrop-filter:blur(24px) saturate(120%);-webkit-backdrop-filter:blur(24px) saturate(120%);background:#0f0a148c;border:1px solid #ffffff0f;border-radius:24px;box-shadow:0 20px 60px #00000080,inset 0 1px 0 #ffffff08;max-width:420px;padding:36px 36px 32px;position:relative;width:100%;z-index:1}@keyframes cardDropIn{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}.auth-tabs{border-bottom:1px solid #ffffff0f;display:flex;gap:0;margin-bottom:28px}.auth-tab{background:none;border:none;color:#fff6;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;padding:10px 0 12px;position:relative;transition:color .3s}.auth-tab:hover{color:#ffffffa6}.auth-tab.active{color:#e8c97a;text-shadow:0 0 12px #c8a45c4d}.auth-tab.active:after{background:#c8a45c;border-radius:1px;bottom:-1px;content:"";height:2px;left:20%;position:absolute;transition:left .3s ease;width:60%}.auth-error{align-items:center;animation:shake .5s ease;background:#c8503c1a;border:1px solid #c8503c26;border-radius:10px;color:#e09080;display:flex;font-size:.82rem;gap:8px;margin-bottom:16px;padding:10px 14px}.auth-error:before{content:"!";font-size:1rem;font-weight:700}.auth-info{background:#c8a45c14;border:1px solid #c8a45c1f;border-radius:10px;color:#c8a45c;font-size:.82rem;margin-bottom:16px;padding:10px 14px}@keyframes shake{0%,to{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}.auth-form .form-group{margin-bottom:16px}.auth-form label{color:#fff9;display:block;font-size:.82rem;font-weight:600;letter-spacing:.5px;margin-bottom:6px}.auth-form input{background:#ffffff0d;border:1px solid #ffffff1f;border-radius:12px;color:#fff;font-size:.95rem;outline:none;padding:13px 16px;transition:all .25s;width:100%}.auth-form input::placeholder{color:#ffffff40}.auth-form input:hover{background:#ffffff12;border-color:#fff3}.auth-form input:focus{background:#c8a45c0f;border-color:#c8a45c99;box-shadow:0 0 0 4px #c8a45c1a;color:#fff}.auth-form input.input-error{background:#c8503c08;border-color:#c8503c66}.auth-form .field-error{color:#e09080;font-size:.72rem;font-weight:500;margin-top:4px}.auth-form .password-wrapper{position:relative}.auth-form .password-wrapper input{padding-right:44px}.auth-form .password-toggle{background:none;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;opacity:.3;padding:6px 10px;position:absolute;right:4px;top:50%;transform:translateY(-50%);transition:opacity .2s}.auth-form .password-toggle:hover{background:#ffffff0a;opacity:.6}.auth-form .password-strength{margin-top:6px}.auth-form .strength-bar{background:#ffffff0d;border-radius:1px;height:2px;margin-bottom:4px;overflow:hidden;width:100%}.auth-form .strength-fill{border-radius:1px;height:100%;transition:width .4s}.auth-btn{background:linear-gradient(135deg,#c8a45c,#e8c97a 50%,#c8a45c);background-size:200% 100%;border:none;border-radius:12px;box-shadow:0 4px 20px #c8a45c40;color:#0a0a0f;cursor:pointer;font-size:1rem;font-weight:700;letter-spacing:2px;margin-top:10px;overflow:hidden;padding:14px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.auth-btn:hover{background-position:100% 0;box-shadow:0 8px 30px #c8a45c66;transform:translateY(-1px)}.auth-btn:active{transform:scale(.97);transition-duration:.08s}.auth-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.4;transform:none}.auth-form .btn-loading{align-items:center;display:flex;gap:8px;justify-content:center}.auth-form .spinner{animation:spin .7s linear infinite;border:2px solid #0a0a0f33;border-radius:50%;border-top-color:#0a0a0f;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.auth-switch{color:#fff6;font-size:.85rem;margin-top:20px;text-align:center}.auth-switch a{color:#c8a45c;font-weight:600;text-decoration:none;transition:color .2s}.auth-switch a:hover{color:#e8c97a}.auth-page-footer{animation:brandSlideIn .8s cubic-bezier(.22,.61,.36,1) .4s both;margin-top:48px;text-align:center;z-index:1}.auth-page-footer-line{background:linear-gradient(90deg,#0000,#c8a45c4d,#0000);height:1px;margin:0 auto 14px;width:140px}.auth-page-footer p{color:#ffffff80;font-size:.85rem;font-weight:500;letter-spacing:1px;margin:0 0 8px}.auth-page-footer-links{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.auth-page-footer-links a{color:#ffffff59;font-size:.75rem;text-decoration:none;transition:color .2s}.auth-page-footer-links a:hover{color:#e8c97a}.auth-modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:100}.auth-modal{animation:modalSlideUp .3s cubic-bezier(.22,.61,.36,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f0a14e6;border:1px solid #ffffff14;border-radius:20px;box-shadow:0 20px 60px #0009;display:flex;flex-direction:column;max-height:70vh;max-width:560px;width:100%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-modal-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;padding:24px 28px 16px}.auth-modal-header h2{color:#e8c97a;font-size:1.15rem;font-weight:700;letter-spacing:2px}.auth-modal-close{align-items:center;background:#ffffff0f;border:none;border-radius:50%;color:#ffffff80;cursor:pointer;display:flex;font-size:.9rem;height:32px;justify-content:center;transition:all .2s;width:32px}.auth-modal-close:hover{background:#ffffff1f;color:#fff}.auth-modal-body{flex:1 1;overflow-y:auto;padding:0 28px 28px}.auth-modal-content{color:#fff9;font-size:.88rem;line-height:1.9;white-space:pre-wrap;word-break:break-word}@media (max-width:480px){.auth-page{padding:24px 16px}.auth-brand h1{font-size:1.5rem;letter-spacing:3px}.auth-card{border-radius:20px;padding:28px 20px 24px}.auth-page:before{height:240px;width:300px}}.dashboard-page{background:#f5f7fa;min-height:calc(100vh - 60px);padding:32px 24px}.dashboard-container{margin:0 auto;max-width:1000px}.welcome-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;gap:24px;margin-bottom:28px;padding:32px}.welcome-avatar,.welcome-card{align-items:center;display:flex}.welcome-avatar{background:#ffffff40;border-radius:50%;flex-shrink:0;font-size:1.6rem;font-weight:700;height:64px;justify-content:center;width:64px}.welcome-info h1{font-size:1.5rem;margin-bottom:4px}.welcome-info p{font-size:.95rem;opacity:.9}.welcome-info .role-tag{background:#ffffff4d;border-radius:12px;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;margin-right:4px;padding:2px 10px}.dashboard-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(290px,1fr))}.info-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;padding:24px}.info-card .card-icon{font-size:2rem;margin-bottom:12px}.info-card h3{color:#1a1a1a;font-size:1.1rem;margin-bottom:14px}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.card-header h3{margin-bottom:0!important}.card-refresh{background:none;border:none;border-radius:8px;cursor:pointer;font-size:1rem;opacity:.5;padding:4px 8px;transition:all .2s}.card-refresh:hover{background:#0000000a;opacity:1}.info-list .info-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;flex-wrap:wrap;gap:4px;justify-content:space-between;padding:10px 0}.info-item:last-child{border-bottom:none}.info-label{color:#888;font-size:.9rem}.info-value{color:#333;font-size:.9rem;font-weight:500;word-break:break-all}.info-value .role-tag{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;padding:2px 10px}.info-value .role-tag.admin{background:#fff3e0;color:#e65100}.info-value .role-tag.user{background:#e8f0fe;color:#1a73e8}.status-tag{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;padding:2px 10px}.status-tag.active{background:#e8f5e9;color:#2e7d32}.status-tag.banned{background:#ffebee;color:#c62828}.quick-actions{display:flex;flex-direction:column;gap:10px}.action-btn{background:#fff;border:2px solid #e0e0e0;border-radius:10px;color:#555;cursor:pointer;display:block;font-family:inherit;font-size:.9rem;font-weight:500;padding:12px;text-align:center;text-decoration:none;transition:all .2s;width:100%}.action-btn:hover{background:#f8f9ff;border-color:#1a73e8;color:#1a73e8}.action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.action-btn.primary:hover{opacity:.9}.action-logout{border-color:#ffcdd2!important;color:#c62828!important}.action-logout:hover{background:#fff5f5!important;border-color:#ef9a9a!important;color:#b71c1c!important}.stats-mini{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-top:4px}.stat-mini{background:#f8f9fc;border-radius:12px;padding:16px 8px;text-align:center}.stat-num{color:#1a1a1c;display:block;font-size:1.6rem;font-weight:700;line-height:1.2}.stat-lbl{color:#999;display:block;font-size:.75rem;margin-top:4px}@media (max-width:768px){.dashboard-page{min-height:calc(100vh - 52px);padding:20px 16px}.welcome-card{gap:16px;padding:24px 20px}.welcome-avatar{font-size:1.3rem;height:52px;width:52px}.welcome-info h1{font-size:1.25rem}.dashboard-grid{gap:16px;grid-template-columns:1fr}.info-card{padding:18px}}@media (max-width:480px){.dashboard-page{min-height:calc(100vh - 48px);padding:14px 10px}.welcome-card{flex-wrap:wrap;gap:12px;justify-content:center;padding:20px 16px;text-align:center}.welcome-avatar{height:42px;width:42px}.welcome-avatar,.welcome-info h1{font-size:1.1rem}.welcome-info p{font-size:.85rem}.info-card{border-radius:12px;padding:14px}.info-card h3{font-size:1rem}.info-label,.info-value{font-size:.8rem}.stats-mini{gap:8px}.stat-mini{padding:12px 6px}.stat-num{font-size:1.3rem}.action-btn{font-size:.85rem;padding:10px}}.btn-create-sm{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 1px 6px #667eea40;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:8px 18px;transition:all .2s}.btn-create-sm:hover{box-shadow:0 3px 12px #667eea59;transform:translateY(-1px)}.admin-layout{background:#f5f7fa;display:flex}.admin-layout,.admin-sidebar{min-height:calc(100vh - 60px)}.admin-sidebar{align-self:flex-start;background:#1a1a2e;color:#fff;flex-shrink:0;overflow-y:auto;position:-webkit-sticky;position:sticky;top:60px;width:230px}.sidebar-header{border-bottom:1px solid #ffffff14;padding:24px 20px 20px}.sidebar-header h2{color:#e0e0e0;font-size:1rem;font-weight:600}.sidebar-nav{padding:12px 0}.sidebar-link{align-items:center;border-left:3px solid #0000;color:#a0a0b8;display:flex;font-size:.9rem;gap:10px;padding:12px 20px;text-decoration:none;transition:all .2s}.sidebar-link:hover{background:#ffffff0d;color:#e0e0e0}.sidebar-link.active{background:#667eea26;border-left-color:#667eea;color:#fff;font-weight:500}.sidebar-icon{font-size:1rem;text-align:center;width:22px}.sidebar-divider{background:#ffffff14;height:1px;margin:8px 16px}.admin-content{flex:1 1;min-width:0;overflow-y:auto;padding:28px 32px}.page-title{color:#1a1a1a;font-size:1.4rem;font-weight:700;margin-bottom:24px}.admin-loading{color:#888;display:flex;font-size:1rem;justify-content:center;padding:60px}.admin-error{align-items:center;background:#fff0f0;border:1px solid #ffcdd2;border-radius:8px;color:#d32f2f;display:flex;gap:8px}.admin-error,.admin-message{font-size:.9rem;margin-bottom:16px;padding:12px 16px}.admin-message{border-radius:8px}.admin-message.success{background:#e8f5e9;border:1px solid #c8e6c9;color:#2e7d32}.admin-message.error{background:#fff0f0;border:1px solid #ffcdd2;color:#d32f2f}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-bottom:28px}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:14px;padding:20px;transition:transform .2s}.stat-card:hover{transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:1.4rem;height:48px;justify-content:center;width:48px}.stat-info{display:flex;flex-direction:column;min-width:0}.stat-value{color:#1a1a1a;font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{color:#888;font-size:.8rem;margin-top:2px}.table-wrapper{-webkit-overflow-scrolling:touch;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow-x:auto}.data-table{border-collapse:collapse;min-width:600px;width:100%}.data-table thead{background:#f8f9fc;position:-webkit-sticky;position:sticky;top:0;z-index:1}.data-table th{border-bottom:2px solid #e0e0e0;color:#666;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:12px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td{border-bottom:1px solid #f0f0f0;color:#333;font-size:.9rem;padding:11px 14px}.data-table tbody tr:hover{background:#f8f9ff}.empty-row{color:#aaa!important;padding:32px!important;text-align:center!important}.detail-cell{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.username-cell{color:#1a73e8;font-weight:500}.badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;padding:3px 10px;white-space:nowrap}.role-admin{background:#fff3e0;color:#e65100}.role-user{background:#e8f0fe;color:#1a73e8}.status-active{background:#e8f5e9;color:#2e7d32}.status-banned{background:#ffebee;color:#c62828}.action-badge{background:#f3e5f5;color:#7b1fa2}.toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.search-form{display:flex;flex:1 1;gap:8px;max-width:400px;min-width:0}.search-form input{background:#fff;border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:.9rem;min-width:120px;outline:none;padding:10px 14px;transition:border-color .2s}.search-form input:focus{border-color:#1a73e8}.search-form button{background:#1a73e8;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:background .2s;white-space:nowrap}.search-form button:hover{background:#1557b0}.filter-select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:.9rem;outline:none;padding:10px 14px}.filter-select:focus{border-color:#1a73e8}.refresh-btn{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.9rem;padding:10px 18px;transition:all .2s;white-space:nowrap}.refresh-btn:hover{border-color:#1a73e8;color:#1a73e8}.action-cell{display:flex;flex-wrap:wrap;gap:6px}.btn-sm{border:none;border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:500;padding:4px 10px;transition:all .2s;white-space:nowrap}.btn-sm:disabled{cursor:not-allowed;opacity:.4}.btn-warn{background:#fff3e0;color:#e65100}.btn-warn:hover:not(:disabled){background:#ffe0b2}.btn-success{background:#e8f5e9;color:#2e7d32}.btn-success:hover:not(:disabled){background:#c8e6c9}.btn-primary{background:#e8f0fe;color:#1a73e8}.btn-primary:hover:not(:disabled){background:#d2e3fc}.btn-outline{background:#f5f5f5;color:#666}.btn-outline:hover:not(:disabled){background:#e0e0e0}.btn-danger{background:#ffebee;color:#c62828}.btn-danger:hover:not(:disabled){background:#ffcdd2}.pagination{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:20px}.pagination button{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.9rem;padding:8px 18px;transition:all .2s}.pagination button:hover:not(:disabled){border-color:#1a73e8;color:#1a73e8}.pagination button:disabled{cursor:not-allowed;opacity:.4}.page-info{color:#888;font-size:.85rem}.action-toast{animation:fadeInOut 3s ease;background:#323232;border-radius:8px;color:#fff;font-size:.9rem;padding:12px 24px;pointer-events:none;position:fixed;right:24px;top:80px;z-index:1000}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-10px)}10%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.overview-bottom{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(380px,1fr))}.overview-panel{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;min-width:0;padding:20px}.overview-panel h3{color:#1a1a1a;font-size:1.05rem;font-weight:600;margin-bottom:14px}.settings-page{max-width:100%}.settings-page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.settings-page-header .page-title{margin-bottom:4px}.settings-cards{display:flex;flex-direction:column;gap:20px}.setting-card{background:#fff;border:1px solid #f0f0f0;border-radius:16px;box-shadow:0 2px 12px #0000000d;overflow:hidden}.setting-card-header{align-items:center;background:#fafbfd;border-bottom:1px solid #f0f0f0;display:flex;gap:14px;padding:18px 24px}.setting-card-icon{font-size:1.5rem;line-height:1}.setting-card-header h3{color:#1a1a1a;font-size:1rem;font-weight:700;margin:0}.setting-card-header p{color:#999;font-size:.8rem;margin:2px 0 0}.setting-card-body{grid-gap:16px 24px;display:grid;gap:16px 24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));padding:20px 24px}.setting-field{display:flex;flex-direction:column;gap:5px}.setting-field label{color:#444;font-size:.85rem;font-weight:600}.setting-field input,.setting-field select,.setting-field textarea{background:#fff;border:2px solid #e8ecf1;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:.88rem;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s;width:100%}.setting-field input:focus,.setting-field select:focus,.setting-field textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea14}.setting-field textarea{line-height:1.6;resize:vertical}.upload-row{gap:8px}.upload-preview,.upload-row{align-items:center;display:flex}.upload-preview{background:#f8f9fc;border:1px solid #e8ecf1;border-radius:8px;flex-shrink:0;padding:3px}.upload-btn{background:#fff;border:2px solid #667eea;border-radius:10px;color:#667eea;cursor:pointer;flex-shrink:0;font-size:.82rem;font-weight:600;padding:9px 14px;transition:all .15s;white-space:nowrap}.upload-btn:hover{background:#667eea;color:#fff}.upload-btn:disabled{cursor:not-allowed;opacity:.5}.upload-row input[type=text]{flex:1 1;min-width:0}.ai-cards{display:flex;flex-direction:column;gap:20px}.ai-card{background:#fff;border:1px solid #f0f0f0;border-radius:16px;box-shadow:0 2px 12px #0000000d;overflow:hidden}.ai-card-header{align-items:center;background:#fafbfd;border-bottom:1px solid #f0f0f0;border-left:4px solid #667eea;display:flex;gap:14px;padding:18px 24px}.ai-card-icon{font-size:1.6rem;line-height:1}.ai-card-title{flex:1 1;min-width:0}.ai-card-title h3{color:#1a1a1a;font-size:1rem;font-weight:700;margin:0}.ai-card-subtitle{color:#888;font-weight:400}.ai-card-title p{color:#999;font-size:.8rem;margin:2px 0 0}.ai-status-dot{align-items:center;background:#f5f5f5;border-radius:20px;color:#888;display:flex;font-size:.78rem;font-weight:600;gap:6px;padding:5px 12px;white-space:nowrap}.ai-status-dot.configured{background:#e8f5e9;color:#2e7d32}.ai-status-dot.unconfigured{background:#f5f5f5;color:#999}.ai-status-pulse{border-radius:50%;display:inline-block;height:8px;width:8px}.ai-status-dot.configured .ai-status-pulse{animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{box-shadow:0 0 0 0 #43a04766}50%{box-shadow:0 0 0 6px #43a04700}}.ai-card-body{grid-gap:16px 24px;display:grid;gap:16px 24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:20px 24px}.ai-field{display:flex;flex-direction:column;gap:5px}.ai-field label{color:#444;font-size:.85rem;font-weight:600}.ai-field input{background:#fff;border:2px solid #e8ecf1;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:.88rem;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s;width:100%}.ai-field input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea14}.ai-password-wrap{position:relative}.ai-password-wrap input{padding-right:32px}.ai-filled-dot{background:#43a047;border-radius:50%;height:8px;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:8px}@media (max-width:640px){.ai-card-body,.setting-card-body{grid-template-columns:1fr}.settings-page-header{flex-direction:column}.ai-card-header{flex-wrap:wrap}}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 28px;transition:opacity .2s;white-space:nowrap}.save-btn:hover{opacity:.9}.save-btn:disabled{cursor:not-allowed;opacity:.5}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000073;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:999}.modal-card{animation:modalIn .25s cubic-bezier(.22,.61,.36,1);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-width:1000px;padding:28px 32px 24px;width:100%}@keyframes modalIn{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-card h3{color:#1a1a1a;font-size:1.1rem;margin-bottom:16px}.modal-body{margin-bottom:20px}.modal-body .form-group{margin-bottom:14px}.modal-body .form-group label{color:#444;display:block;font-size:.85rem;font-weight:600;margin-bottom:5px}.modal-body .form-group input{background:#fff;border:2px solid #e0e0e0;border-radius:10px;font-size:.9rem;outline:none;padding:10px 14px;transition:border-color .2s;width:100%}.modal-body .form-group input:focus{border-color:#1a73e8}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.btn-cancel{background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;font-size:.9rem;padding:10px 20px;transition:all .2s}.btn-cancel:hover{background:#f5f5f5}.btn-save{background:#1a73e8;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 24px;transition:all .2s}.btn-save:hover{background:#1557b0}.btn-save:disabled{cursor:not-allowed;opacity:.5}.btn-edit{background:#e8f5e9;color:#2e7d32}.btn-edit:hover{background:#c8e6c9}.btn-pwd{background:#f3e5f5;color:#7b1fa2}.btn-pwd:hover{background:#e1bee7}@media (max-width:900px){.overview-bottom{grid-template-columns:1fr}}@media (max-width:768px){.admin-layout{flex-direction:column;min-height:calc(100vh - 52px)}.admin-sidebar{min-height:auto;position:relative;top:0;width:100%}.sidebar-nav{display:flex;flex-wrap:wrap;padding:8px}.sidebar-link{border-bottom:2px solid #0000;border-left:none;flex:1 1 auto;font-size:.8rem;justify-content:center;min-width:70px;padding:10px 14px}.sidebar-link.active{border-bottom-color:#667eea;border-left-color:#0000}.admin-content{padding:20px 16px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media (max-width:480px){.admin-layout{min-height:calc(100vh - 48px)}.admin-content{padding:14px 10px}.page-title{font-size:1.15rem;margin-bottom:14px}.stats-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.stat-card{gap:8px;padding:12px}.stat-icon{border-radius:8px;font-size:1.1rem;height:36px;width:36px}.stat-value{font-size:1.2rem}.toolbar{flex-direction:column;gap:8px}.search-form{max-width:100%}.data-table{min-width:480px}.data-table td,.data-table th{font-size:.78rem;padding:8px 10px}.btn-sm{font-size:.7rem;padding:3px 7px}.action-toast{left:12px;right:12px;text-align:center}.pagination{gap:8px}.pagination button{font-size:.8rem;padding:6px 12px}.sidebar-header{padding:14px 16px}.sidebar-header h2{font-size:.9rem}.overview-bottom{gap:12px}.overview-panel{padding:14px}}.credit-tabs{background:#f0f2f5;border-radius:12px;display:flex;gap:4px;margin-bottom:24px;padding:4px}.credit-tab{background:#0000;border:none;border-radius:10px;color:#666;cursor:pointer;flex:1 1;font-size:.88rem;font-weight:500;padding:10px 16px;transition:all .2s;white-space:nowrap}.credit-tab:hover{color:#333}.credit-tab.active{background:#fff;box-shadow:0 2px 8px #00000014;color:#667eea;font-weight:600}.credit-tab-content{min-height:200px}.pricing-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.pricing-card{align-items:center;background:#fff;border:2px solid #e8ecf1;border-radius:14px;display:flex;justify-content:space-between;padding:18px 20px;transition:border-color .2s}.pricing-card:hover{border-color:#667eea}.pricing-card-header{display:flex;flex-direction:column;gap:3px}.pricing-card-label{color:#333;font-size:.9rem;font-weight:600}.pricing-card-desc{color:#999;font-size:.75rem}.pricing-card-input{align-items:center;display:flex;flex-shrink:0;gap:6px}.pricing-card-input input{border:2px solid #e0e0e0;border-radius:8px;color:#667eea;font-size:1rem;font-weight:700;outline:none;padding:8px 10px;text-align:center;transition:border-color .2s;width:72px}.pricing-card-input input:focus{border-color:#667eea}.pricing-card-unit{color:#888;font-size:.78rem;white-space:nowrap}.wechat-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.wechat-span-full{grid-column:1/-1}.wechat-grid .settings-group{margin-bottom:0}.wechat-grid .settings-group label{color:#333;display:block;font-size:.9rem;font-weight:600;margin-bottom:6px}.wechat-grid .settings-group input,.wechat-grid .settings-group select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;outline:none;padding:10px 14px;transition:border-color .2s;width:100%}.wechat-grid .settings-group input:focus,.wechat-grid .settings-group select:focus{border-color:#667eea}.wechat-grid .settings-group textarea{background:#fff;border:2px solid #e0e0e0;border-radius:10px;font-family:monospace;font-size:.82rem;outline:none;padding:10px 14px;resize:vertical;transition:border-color .2s;width:100%}.wechat-grid .settings-group textarea:focus{border-color:#667eea}.branding-upload-row{align-items:center;display:flex;gap:10px}.branding-preview{align-items:center;background:#f8f9fc;border:1px solid #e8ecf1;border-radius:8px;display:flex;flex-shrink:0;padding:4px}.branding-upload-row input[type=text]{flex:1 1;min-width:0}.notfound-page{align-items:center;background:radial-gradient(ellipse 60% 50% at 50% 40%,#2d1b3d 0,#1a1028 50%,#0d0a14 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:32px;position:relative}.notfound-page:before{animation:halftoneDrift 20s linear infinite;background-image:radial-gradient(circle,#fff 1px,#0000 0);background-size:24px 24px;content:"";inset:0;opacity:.06;pointer-events:none;position:absolute;z-index:0}@keyframes halftoneDrift{0%{background-position:0 0}to{background-position:24px 24px}}.notfound-page .auth-blobs{inset:0;overflow:hidden;pointer-events:none;position:absolute;z-index:0}.notfound-page .blob{animation:blobFloat 20s ease-in-out infinite;border-radius:50%;filter:blur(90px);opacity:.14;position:absolute}.notfound-page .blob-1{background:#ff6b6b;height:450px;left:-80px;top:-100px;width:450px}.notfound-page .blob-2{animation-delay:-6s;background:#8a4fff;bottom:-60px;height:320px;right:-60px;width:320px}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-25px) scale(1.08)}}.notfound-card{animation:cardReveal .6s cubic-bezier(.22,.61,.36,1) both;backdrop-filter:blur(28px) saturate(140%);-webkit-backdrop-filter:blur(28px) saturate(140%);background:#140a238c;border:1.5px solid #ffffff14;border-radius:28px;box-shadow:0 8px 40px #00000080,0 0 0 1px #ff6b6b0f;max-width:460px;padding:56px 48px 48px;position:relative;text-align:center;width:100%;z-index:1}@keyframes cardReveal{0%{opacity:0;transform:translateY(32px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.notfound-code{display:flex;gap:4px;justify-content:center;margin-bottom:16px}.notfound-code .digit{-webkit-text-fill-color:#0000;animation:digitFloat 3.5s ease-in-out infinite;background:linear-gradient(180deg,#ffffffb3,#ffffff26);-webkit-background-clip:text;background-clip:text;font-size:100px;font-weight:900;letter-spacing:-4px;line-height:1}.notfound-code .digit:first-child{animation-delay:0s}.notfound-code .digit:nth-child(3){animation-delay:.3s}@keyframes digitFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.notfound-title{color:#f0e6ff;font-size:22px;font-weight:700;margin-bottom:8px}.notfound-path{color:#ffffff4d;font-size:14px;margin-bottom:4px}.notfound-path code{background:#ffffff0d;border-radius:5px;color:#ffffff80;font-family:SF Mono,monospace;font-size:13px;padding:2px 8px}.notfound-desc{color:#ffffff4d;font-size:14px;margin-bottom:32px}.notfound-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.nf-btn{align-items:center;border-radius:14px;display:inline-flex;font-size:15px;font-weight:600;gap:6px;padding:13px 28px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.nf-btn-primary{background:linear-gradient(135deg,#ff6b6b,#8a4fff);box-shadow:0 4px 20px #8a4fff4d;color:#fff}.nf-btn-primary:hover{box-shadow:0 8px 32px #8a4fff73;transform:translateY(-2px)}.nf-btn-primary:active{transform:scale(.97)}.nf-btn-ghost{background:#0000;border:1.5px solid #ffffff1a;color:#ffffff73}.nf-btn-ghost:hover{background:#ffffff0a;border-color:#ffffff40;color:#fff}@media (max-width:480px){.notfound-card{border-radius:24px;padding:40px 24px 36px}.notfound-code .digit{font-size:72px}.notfound-actions{flex-direction:column}.nf-btn{justify-content:center}.notfound-page .blob-1{height:250px;width:250px}.notfound-page .blob-2{height:180px;width:180px}}.btn-create-project{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 24px;transition:all .2s}.btn-create-project:hover{box-shadow:0 4px 16px #667eea66;transform:translateY(-1px)}.project-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.project-card{background:#fff;border-radius:14px;border-top:4px solid #667eea;box-shadow:0 2px 12px #0000000f;overflow:hidden;position:relative;transition:all .2s}.project-card:hover{box-shadow:0 6px 24px #0000001a;transform:translateY(-3px)}.project-card-link{color:inherit;display:block;text-decoration:none}.project-cover{align-items:center;display:flex;height:100px;justify-content:center}.project-cover-icon{font-size:2.5rem;opacity:.5}.project-info{padding:16px 18px}.project-name{color:#1a1a1a;font-size:1.1rem;font-weight:700;margin-bottom:4px}.project-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#888;display:-webkit-box;font-size:.85rem;margin-bottom:10px;overflow:hidden}.project-meta{color:#aaa;display:flex;font-size:.78rem;justify-content:space-between}.project-delete-btn{background:#fffc;border:none;border-radius:6px;cursor:pointer;font-size:14px;opacity:0;padding:4px 8px;position:absolute;right:8px;top:8px;transition:opacity .2s}.project-card:hover .project-delete-btn{opacity:1}.project-delete-btn:hover{background:#fff}@media (max-width:480px){.project-grid{gap:12px;grid-template-columns:1fr}}.script-list{display:flex;flex-direction:column;gap:10px}.script-item{background:#fff;border-radius:12px;box-shadow:0 1px 6px #0000000a;cursor:pointer;padding:16px 18px;position:relative;transition:all .15s}.script-item:hover{box-shadow:0 3px 12px #00000014;transform:translateY(-1px)}.script-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.script-item-title{color:#1a1a1a;font-size:.95rem;font-weight:600}.script-item-idea{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#888;display:-webkit-box;font-size:.85rem;margin-bottom:8px;overflow:hidden}.script-item-meta{color:#bbb;display:flex;font-size:.75rem;gap:16px}.script-item-actions{display:flex;gap:6px;opacity:0;position:absolute;right:12px;top:12px;transition:opacity .15s}.script-item:hover .script-item-actions{opacity:1}.script-delete-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:14px;opacity:0;padding:4px 8px;position:absolute;right:12px;top:12px;transition:opacity .15s}.script-item:hover .script-delete-btn{opacity:.6}.script-delete-btn:hover{background:#0000000d;opacity:1!important}.script-content{background:#fafafa;border:1px solid #eee;border-radius:10px;padding:20px}.gen-panel{background:#fff;border:2px solid #e8e0f0;border-radius:14px;box-shadow:0 2px 12px #0000000f;padding:20px 24px}.gen-idea-input{background:#fff;border:2px solid #e0e0e0;border-radius:12px;flex:1 1;font-family:inherit;font-size:.9rem;min-width:280px;outline:none;padding:12px 16px;resize:vertical;transition:border-color .2s}.gen-idea-input:focus{border-color:#8a4fff;box-shadow:0 0 0 3px #8a4fff14}.gen-controls{display:flex;flex-direction:column;gap:10px;min-width:200px}.gen-controls .form-group{margin-bottom:0}.gen-controls label{color:#666;display:block;font-size:.8rem;font-weight:600;margin-bottom:4px}.gen-controls select{background:#fff;border:2px solid #e0e0e0;border-radius:10px;color:#333;font-size:.85rem;outline:none;padding:10px 12px;width:100%}.btn-generate{background:linear-gradient(135deg,#8a4fff,#667eea);border:none;border-radius:12px;box-shadow:0 3px 12px #8a4fff4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:700;padding:12px 24px;transition:all .2s;white-space:nowrap}.btn-generate:hover{box-shadow:0 5px 20px #8a4fff66;transform:translateY(-1px)}.btn-generate:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:480px){.script-item{padding:12px 14px}.gen-panel{padding:14px 16px}.gen-controls,.gen-idea-input{min-width:100%}}.modify-dialog-overlay{align-items:center;animation:fadeIn .15s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modify-dialog{animation:slideUp .2s ease;background:#fff;border-radius:16px;box-shadow:0 12px 40px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:1000px;width:100%}.modify-dialog-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:18px 24px}.modify-dialog-header h3{font-size:1.1rem;font-weight:700;margin:0}.modify-dialog-body{flex:1 1;overflow-y:auto;padding:20px 24px}.modify-section{margin-bottom:18px}.modify-section label{color:#333;display:block;font-size:.9rem;font-weight:600;margin-bottom:8px}.modify-original{background:#f7f7f8;border:1px solid #e5e5e5;border-radius:10px;max-height:260px;overflow-y:auto;padding:14px 16px}.modify-original pre{color:#444;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem;line-height:1.5;margin:0;white-space:pre-wrap;word-break:break-word}.modify-instruction{border:2px solid #e0e0e0;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:.9rem;min-height:100px;outline:none;padding:12px 16px;resize:vertical;transition:border-color .2s;width:100%}.modify-instruction:focus{border-color:#8a4fff;box-shadow:0 0 0 3px #8a4fff14}.modify-actions{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.modify-identity-section{margin-bottom:16px}.modify-identity-header{align-items:center;background:#f7f3ff;border:1px solid #e8e0f0;border-radius:10px;color:#6b4fbf;cursor:pointer;display:flex;font-size:.85rem;justify-content:space-between;padding:10px 14px;transition:background .15s;-webkit-user-select:none;user-select:none}.modify-identity-header:hover{background:#efe6ff}.modify-identity-toggle{color:#999;font-size:.8rem}.modify-identity-input{background:#fff;border:2px solid #e0e0e0;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:.85rem;margin-top:8px;min-height:70px;outline:none;padding:10px 14px;resize:vertical;transition:border-color .2s;width:100%}.modify-identity-input:focus{border-color:#8a4fff;box-shadow:0 0 0 3px #8a4fff14}.modify-preview{background:#f9f9fb;border:1px solid #e5e5e5;border-radius:10px;max-height:50vh;overflow-y:auto;padding:16px 20px}.modify-preview .markdown-body{font-size:.85rem}.modify-warning{color:#e67e22;font-size:.82rem;margin:12px 0 0;text-align:center}.modify-preview-grid{display:flex;gap:18px}.modify-preview-left{display:flex;flex:0 0 280px;flex-direction:column;gap:12px;min-width:220px}.modify-preview-right{flex:1 1;min-width:0}.modify-preview-right>label{color:#333;display:block;font-size:.9rem;font-weight:600;margin-bottom:8px}.modify-preview-right .modify-preview{max-height:60vh}@media (max-width:640px){.modify-preview-grid{flex-direction:column}.modify-preview-left{flex:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn-generate-storyboard{background:linear-gradient(135deg,#e67e22,#f39c12)!important;border:none!important;color:#fff!important;font-weight:600}.storyboard-dialog{animation:slideUp .2s ease;background:#1a1a2e;border-radius:16px;box-shadow:0 12px 40px #0006;color:#e0e0e0;display:flex;flex-direction:column;max-height:92vh;max-width:1300px;width:95vw}.storyboard-dialog .modify-dialog-header{border-bottom-color:#2a2a4a}.storyboard-dialog .modify-dialog-header h3{color:#fff}.storyboard-checklist{background:#16213e;border:1px solid #2a2a4a;border-radius:10px;margin-bottom:12px;padding:14px 18px}.storyboard-checklist-item{color:#b0b8c8;font-size:.85rem;padding:5px 0}.storyboard-style-grid{display:flex;flex-wrap:wrap;gap:12px}.storyboard-style-card{background:#16213e;border:2px solid #2a2a4a;border-radius:12px;cursor:pointer;flex:1 1;min-width:150px;padding:16px;text-align:center;transition:all .2s}.storyboard-style-card:hover{border-color:#e67e22}.storyboard-style-card.active{background:#1a2744;border-color:#e67e22;box-shadow:0 0 20px #e67e2233}.storyboard-style-label{color:#fff;font-size:1rem;font-weight:700;margin-bottom:4px}.storyboard-style-desc{color:#888;font-size:.75rem}.btn-generate-storyboard-lg{background:linear-gradient(135deg,#e67e22,#f39c12);border:none;border-radius:12px;box-shadow:0 4px 16px #e67e2266;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:12px 28px;transition:all .2s}.btn-generate-storyboard-lg:hover{box-shadow:0 6px 24px #e67e2280;transform:translateY(-1px)}.storyboard-history{display:flex;gap:10px;overflow-x:auto;padding:4px 0}.storyboard-history-item{border:2px solid #2a2a4a;border-radius:8px;cursor:pointer;flex:0 0 80px;height:56px;overflow:hidden;position:relative;transition:all .2s}.storyboard-history-item:hover{border-color:#e67e22}.storyboard-history-item.active{border-color:#e67e22;box-shadow:0 0 10px #e67e224d}.storyboard-history-item img{height:100%;object-fit:cover;width:100%}.storyboard-history-item span{background:#000000b3;bottom:0;color:#ccc;font-size:.6rem;left:0;padding:2px 4px;position:absolute;right:0;text-align:center}.storyboard-history-placeholder{align-items:center;background:#16213e;display:flex;font-size:1.5rem;height:100%;justify-content:center;width:100%}.storyboard-monitor{padding:20px 0}.storyboard-monitor-frame{display:flex;justify-content:center;padding:0 20px}.storyboard-monitor-bezel{background:#111;border:3px solid #333;border-radius:16px;box-shadow:inset 0 0 30px #00000080,0 0 30px #e67e221a;max-width:600px;padding:20px;width:100%}.storyboard-monitor-screen{background:#0a0a14;border:1px solid #222;border-radius:8px;overflow:hidden;padding:30px 24px;position:relative}.storyboard-monitor-screen:before{background:repeating-linear-gradient(0deg,#0000,#0000 2px,hsla(0,0%,100%,.015) 0,hsla(0,0%,100%,.015) 4px);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.storyboard-monitor-content{position:relative;text-align:center;z-index:1}.storyboard-monitor-rec{align-items:center;color:#f44;display:flex;font-size:.9rem;font-weight:700;gap:8px;justify-content:center;margin-bottom:16px}.storyboard-rec-dot{animation:recBlink 1s infinite;background:#f44;border-radius:50%;height:10px;width:10px}@keyframes recBlink{0%,to{opacity:1}50%{opacity:.3}}.storyboard-monitor-tc{color:#e67e22;font-family:SF Mono,Consolas,monospace;font-size:1.8rem;letter-spacing:2px;margin-bottom:20px}.storyboard-monitor-phase{animation:phasePulse 2s ease-in-out infinite;color:#ccc;font-size:1rem;margin-bottom:20px;min-height:28px}@keyframes phasePulse{0%,to{opacity:.8}50%{opacity:1}}.storyboard-monitor-progress{margin-bottom:16px}.storyboard-progress-track{background:#222;border-radius:2px;height:4px;overflow:hidden}.storyboard-progress-fill{background:linear-gradient(90deg,#e67e22,#f39c12);border-radius:2px;height:100%;transition:width .5s ease}.storyboard-monitor-info{color:#666;font-size:.75rem}.storyboard-viewer-container{background:#0a0a14;border:1px solid #222;border-radius:8px;flex:1 1;margin:4px 0;min-height:55vh;overflow:hidden;position:relative}.storyboard-viewer-canvas{left:0;position:absolute;top:0;will-change:transform}.storyboard-viewer-image{box-shadow:0 8px 40px #00000080;display:block;max-width:none}.storyboard-viewer-toolbar{align-items:center;background:#16213e;border-radius:0 0 8px 8px;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:8px 16px}.storyboard-viewer-toolbar-left,.storyboard-viewer-toolbar-right{align-items:center;display:flex;gap:6px}.storyboard-viewer-toolbar button{background:#1a1a2e;border:1px solid #3a3a5a;border-radius:6px;color:#ccc;cursor:pointer;font-size:.8rem;padding:4px 10px;transition:all .15s}.storyboard-viewer-toolbar button:hover{background:#2a2a4a;color:#fff}.storyboard-zoom-label{color:#e67e22;font-family:monospace;font-size:.8rem;min-width:40px;text-align:center}.storyboard-minimap{border:2px solid #3a3a5a;border-radius:6px;bottom:12px;height:78px;opacity:.7;overflow:hidden;position:absolute;right:12px;transition:opacity .2s;width:140px;z-index:5}.storyboard-minimap:hover{opacity:1}.storyboard-minimap img{height:100%;object-fit:cover;width:100%}.storyboard-minimap-viewport{background:#e67e221a;border:2px solid #e67e22;position:absolute}.storyboard-version-bar{background:#111827;border-top:1px solid #222;display:flex;gap:8px;overflow-x:auto;padding:8px 16px}.storyboard-version-thumb{border:2px solid #2a2a4a;border-radius:4px;cursor:pointer;flex:0 0 56px;height:36px;overflow:hidden;position:relative;transition:all .15s}.storyboard-version-thumb.active,.storyboard-version-thumb:hover{border-color:#e67e22}.storyboard-version-thumb img{height:100%;object-fit:cover;width:100%}.storyboard-version-thumb span{background:#000000b3;bottom:0;color:#aaa;font-size:.5rem;left:0;padding:1px 3px;position:absolute;right:0;text-align:center}.storyboard-current-badge{background:#e67e22;border-radius:0 0 0 4px;color:#fff;font-size:.5rem;padding:1px 4px;position:absolute;right:0;top:0}.storyboard-history-delete,.storyboard-version-delete{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.6rem;height:18px;justify-content:center;line-height:1;opacity:0;padding:0;position:absolute;right:2px;top:2px;transition:all .15s;width:18px}.storyboard-history-item:hover .storyboard-history-delete,.storyboard-version-thumb:hover .storyboard-version-delete{opacity:1}.storyboard-history-delete:hover,.storyboard-version-delete:hover{background:#e74c3c;transform:scale(1.1)}.storyboard-director-checks{margin-bottom:16px}.storyboard-director-checks>label{color:#ccc;display:block;font-size:.85rem;font-weight:600;margin-bottom:8px}.storyboard-check-grid{display:flex;flex-wrap:wrap;gap:8px}.storyboard-check-item{align-items:center;background:#16213e;border:1px solid #2a2a4a;border-radius:8px;color:#b0b8c8;cursor:pointer;display:flex;font-size:.8rem;gap:6px;padding:6px 12px;transition:all .15s}.storyboard-check-item:hover{border-color:#e67e22}.storyboard-check-item input[type=checkbox]{accent-color:#e67e22}.storyboard-dialog .modify-dialog-body{color:#e0e0e0}.storyboard-dialog .modify-dialog-body label{color:#ccc}@media (max-width:640px){.storyboard-dialog{border-radius:0;max-height:100vh;max-width:100%}.storyboard-style-grid{flex-direction:column}.storyboard-viewer-container{aspect-ratio:16/9;min-height:200px}.storyboard-monitor-tc{font-size:1.3rem}.storyboard-viewer-layout{flex-direction:column}.storyboard-chat-panel{border-left:none;border-top:1px solid #2a2a4a;max-height:300px}}.storyboard-viewer-layout{display:flex;flex:1 1;min-height:0;overflow:hidden}.storyboard-viewer-main{display:flex;flex:1 1;flex-direction:column;min-width:0}.storyboard-viewer-main .storyboard-viewer-container{flex:1 1;max-height:none;min-height:50vh}.storyboard-chat-panel{background:#0d1117;border-left:1px solid #2a2a4a;display:flex;flex-direction:column;min-width:240px;width:280px}.storyboard-chat-header{align-items:baseline;border-bottom:1px solid #2a2a4a;display:flex;justify-content:space-between;padding:10px 14px}.storyboard-chat-header span:first-child{color:#e0e0e0;font-size:.85rem;font-weight:700}.storyboard-chat-hint{color:#666;font-size:.7rem}.storyboard-chat-messages{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto;padding:10px}.storyboard-chat-empty{color:#666;font-size:.78rem;padding:20px 10px;text-align:center}.storyboard-chat-empty ul{margin:8px 0 0;padding-left:16px;text-align:left}.storyboard-chat-empty li{color:#555;margin-bottom:4px}.storyboard-chat-msg{display:flex;gap:6px}.storyboard-chat-msg.user{flex-direction:row-reverse}.storyboard-chat-role{flex-shrink:0;font-size:.9rem;margin-top:4px}.storyboard-chat-bubble{background:#16213e;border-radius:10px;color:#ccc;font-size:.78rem;line-height:1.4;max-width:85%;padding:8px 10px}.storyboard-chat-msg.user .storyboard-chat-bubble{background:#1a3a5c;color:#d0d8e8}.storyboard-chat-time{color:#555;font-size:.6rem;margin-top:3px}.storyboard-chat-dots{animation:blink 1.2s infinite}@keyframes blink{0%,to{opacity:.3}50%{opacity:1}}.storyboard-chat-result{background:#1a2744;border:1px dashed #e67e22;border-radius:6px;color:#e67e22;cursor:pointer;font-size:.75rem;margin-top:6px;padding:6px 8px;text-align:center;transition:all .15s}.storyboard-chat-result:hover{background:#2a3a5a}.storyboard-chat-input-area{border-top:1px solid #2a2a4a;display:flex;gap:6px;padding:8px 10px}.storyboard-chat-input{background:#0a0a14;border:1px solid #2a2a4a;border-radius:8px;color:#e0e0e0;flex:1 1;font-family:inherit;font-size:.78rem;outline:none;padding:8px 10px;resize:none}.storyboard-chat-input:focus{border-color:#e67e22}.storyboard-chat-input::placeholder{color:#444}.storyboard-chat-send{align-items:center;background:#e67e22;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:36px;justify-content:center;transition:all .15s;width:36px}.storyboard-chat-send:hover{background:#f39c12}.storyboard-chat-send:disabled{cursor:not-allowed;opacity:.4}.script-viewer-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:999}.script-viewer-card{animation:modalIn .25s cubic-bezier(.22,.61,.36,1);background:#fff;border-radius:18px;box-shadow:0 24px 80px #0003;display:flex;flex-direction:column;max-height:92vh;max-width:1100px;width:100%}.script-viewer-header{align-items:flex-start;border-bottom:1px solid #f0f0f0;display:flex;flex-shrink:0;justify-content:space-between;padding:22px 28px 16px}.script-viewer-title{color:#1a1a1a;font-size:1.2rem;font-weight:700;line-height:1.4;padding-right:12px}.script-viewer-meta{color:#aaa;display:flex;flex-wrap:wrap;font-size:.78rem;gap:16px;margin-top:4px}.script-viewer-close{background:none;border:none;border-radius:8px;color:#999;cursor:pointer;flex-shrink:0;font-size:1.2rem;line-height:1;padding:4px 8px}.script-viewer-close:hover{background:#f0f0f0;color:#333}.script-viewer-idea{background:linear-gradient(135deg,#f8f4ff,#f0f4ff);border-left:4px solid #8a4fff;border-radius:10px;color:#555;flex-shrink:0;font-size:.88rem;margin:14px 28px 0;padding:12px 16px}.script-viewer-body{flex:1 1;overflow-y:auto;padding:16px 28px 24px}.markdown-body h1{border-bottom:2px solid #f0f0f0;color:#1a1a2e;font-size:1.5rem;font-weight:800;margin:24px 0 12px;padding-bottom:8px}.markdown-body h2{border-bottom:1px solid #f5f5f5;color:#2d2d44;font-size:1.25rem;font-weight:700;margin:20px 0 10px;padding-bottom:6px}.markdown-body h3{color:#3d3d5c;font-size:1.1rem;font-weight:700;margin:16px 0 8px}.markdown-body h4{color:#555;font-size:1rem;font-weight:600;margin:12px 0 6px}.markdown-body p{color:#333;font-size:.92rem;line-height:1.8;margin:8px 0}.markdown-body strong{color:#1a1a2e;font-weight:700}.markdown-body em{color:#8a4fff;font-style:italic}.markdown-body table{border-collapse:collapse;border-radius:8px;box-shadow:0 1px 4px #0000000f;font-size:.85rem;margin:14px 0;overflow:hidden;width:100%}.markdown-body th{background:#f5f4f8;color:#555;font-size:.8rem;font-weight:700;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase}.markdown-body td{border-top:1px solid #f0f0f0;color:#444;padding:9px 14px}.markdown-body tr:nth-child(2n) td{background:#fafafc}.markdown-body ol,.markdown-body ul{margin:8px 0;padding-left:24px}.markdown-body li{color:#444;line-height:1.7;margin:4px 0}.markdown-body li::marker{color:#8a4fff}.markdown-body hr{background:linear-gradient(90deg,#0000,#8a4fff,#0000);border:none;height:2px;margin:24px 0}.markdown-body blockquote{background:#f8f4ff;border-left:4px solid #8a4fff;border-radius:0 8px 8px 0;color:#666;font-style:italic;margin:12px 0;padding:12px 16px}.markdown-body code{background:#f5f4f8;border-radius:4px;color:#e65100;font-size:.85em;padding:2px 6px}.markdown-body pre{background:#1a1a2e;border-radius:10px;color:#e0e0e0;margin:12px 0;overflow-x:auto;padding:16px 20px}.markdown-body pre code{background:none;color:inherit;padding:0}.script-viewer-footer{border-top:1px solid #f0f0f0;display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;justify-content:center;padding:14px 28px 18px}.script-viewer-footer .btn-sm{font-size:.85rem;padding:8px 18px}.script-editor{border:2px solid #e0e0e0;border-radius:10px;box-sizing:border-box;font-family:SF Mono,Consolas,Fira Code,monospace;font-size:.85rem;line-height:1.6;min-height:55vh;outline:none;padding:20px;resize:vertical;width:100%}.script-editor:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e814}@media (max-width:480px){.script-viewer-card{border-radius:0;max-height:100vh}.script-viewer-header{padding:14px 16px 12px}.script-viewer-body{padding:12px 16px 20px}.script-viewer-idea{margin:10px 16px 0}.script-viewer-footer{padding:10px 16px 14px}}
/*# sourceMappingURL=main.01ddd94d.css.map*/