.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--success-color: #22c55e;--warning-color: #f59e0b;--error-color: #ef4444;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9}.ant-btn{font-weight:500;border-radius:10px;transition:all .25s ease}.ant-btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);border:none;box-shadow:0 4px 14px #3b82f64d}.ant-btn-primary:hover{background:linear-gradient(135deg,#60a5fa 0%,var(--primary-color) 100%);transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.ant-btn-primary:active{transform:translateY(0)}.ant-btn-default:hover{color:var(--primary-color);border-color:var(--primary-color)}.ant-btn-link{font-weight:500}.ant-btn-link:hover{color:var(--primary-hover)}.ant-input,.ant-input-number,.ant-select-selector,.ant-picker{border-radius:10px!important;border:2px solid var(--border-color)!important;transition:all .25s ease!important}.ant-input:hover,.ant-input-number:hover,.ant-select-selector:hover,.ant-picker:hover{border-color:#cbd5e1!important}.ant-input:focus,.ant-input-focused,.ant-input-number:focus,.ant-input-number-focused,.ant-select-focused .ant-select-selector,.ant-picker-focused{border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #3b82f61a!important}.ant-input-affix-wrapper{border-radius:10px!important;border:2px solid var(--border-color)!important}.ant-input-affix-wrapper:hover{border-color:#cbd5e1!important}.ant-input-affix-wrapper-focused{border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #3b82f61a!important}.ant-form-item-label>label{color:#374151;font-weight:500}.ant-card{border-radius:16px;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000a;transition:all .3s ease}.ant-card:hover{box-shadow:0 4px 12px #00000014}.ant-card-head{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-bottom:1px solid var(--border-color)}.ant-card-head-title{font-weight:600;color:var(--text-primary)}.ant-table{border-radius:16px;overflow:hidden}.ant-table-thead>tr>th{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);color:var(--text-secondary);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;transition:background .2s ease}.ant-table-tbody>tr:hover>td{background:var(--bg-secondary)}.ant-tag{border-radius:6px;padding:4px 10px;font-weight:500;border:none;font-size:12px}.ant-modal-content{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.ant-modal-header{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-bottom:1px solid var(--border-color);padding:20px 24px}.ant-modal-title{font-weight:600;color:var(--text-primary);font-size:18px}.ant-modal-body{padding:24px}.ant-modal-footer{border-top:1px solid #f1f5f9;padding:16px 24px;background:var(--bg-secondary)}.ant-pagination-item{border-radius:8px;border:1px solid var(--border-color);transition:all .2s ease}.ant-pagination-item:hover{border-color:var(--primary-color)}.ant-pagination-item a{color:var(--text-secondary)}.ant-pagination-item:hover a{color:var(--primary-color)}.ant-pagination-item-active{background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 2px 8px #3b82f64d}.ant-pagination-item-active a{color:#fff}.ant-switch{background:var(--border-color)}.ant-switch-checked{background:linear-gradient(135deg,var(--success-color) 0%,#16a34a 100%)}.ant-select-dropdown{border-radius:12px;box-shadow:0 10px 40px #00000026;padding:8px}.ant-select-item{border-radius:8px;transition:all .2s ease}.ant-select-item-option-selected{background:linear-gradient(135deg,#eff6ff,#dbeafe);font-weight:500}.ant-select-item-option-active{background:var(--bg-secondary)}.ant-message-notice-content{border-radius:12px;box-shadow:0 10px 40px #00000026;padding:12px 20px}.ant-notification-notice{border-radius:12px;box-shadow:0 10px 40px #00000026}.ant-progress-bg{border-radius:4px}.ant-statistic-title{color:var(--text-secondary);font-size:13px;font-weight:500;margin-bottom:8px}.ant-statistic-content{color:var(--text-primary);font-weight:700}.ant-tabs-tab{font-weight:500;padding:12px 16px;transition:all .25s ease}.ant-tabs-tab:hover{color:var(--primary-color)}.ant-tabs-tab-active .ant-tabs-tab-btn{color:var(--primary-color);font-weight:600}.ant-tabs-ink-bar{background:var(--primary-color)}.ant-badge-status-success{background-color:var(--success-color)}.ant-badge-status-processing{background-color:var(--primary-color)}.ant-badge-status-error{background-color:var(--error-color)}.ant-badge-status-warning{background-color:var(--warning-color)}.ant-drawer-content{border-radius:16px 0 0 16px}.ant-drawer-header{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-bottom:1px solid var(--border-color)}.ant-drawer-title{font-weight:600;color:var(--text-primary)}.ant-divider{border-color:#f1f5f9}.ant-breadcrumb a{color:var(--text-secondary);transition:color .2s ease}.ant-breadcrumb a:hover{color:var(--primary-color)}.ant-empty-description{color:var(--text-muted)}.ant-spin-dot-item{background-color:var(--primary-color)}.ant-skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 37%,var(--bg-secondary) 63%);background-size:400% 100%;animation:skeleton-loading 1.4s ease infinite}@keyframes skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}*{transition-timing-function:cubic-bezier(.4,0,.2,1)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::selection{background:#3b82f633;color:var(--text-primary)}@media (max-width: 768px){.ant-modal{max-width:calc(100vw - 32px);margin:16px auto}.ant-card,.ant-table{border-radius:12px}}.install-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;position:relative;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.install-background{position:absolute;inset:0;overflow:hidden;pointer-events:none}.bg-shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3}.bg-shape-1{width:600px;height:600px;background:linear-gradient(135deg,#667eea,#764ba2);top:-200px;right:-100px;animation:float 20s ease-in-out infinite}.bg-shape-2{width:400px;height:400px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:-100px;left:-100px;animation:float 15s ease-in-out infinite reverse}.bg-shape-3{width:300px;height:300px;background:linear-gradient(135deg,#4facfe,#00f2fe);top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse 10s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(30px,-30px) rotate(5deg)}50%{transform:translate(-20px,20px) rotate(-5deg)}75%{transform:translate(20px,30px) rotate(3deg)}}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.3}50%{transform:translate(-50%,-50%) scale(1.1);opacity:.2}}.install-container{background:#fffffffa;border-radius:24px;box-shadow:0 25px 80px #0006,0 10px 30px #0003,inset 0 1px #fffc;max-width:900px;width:100%;overflow:hidden;position:relative;z-index:1;backdrop-filter:blur(20px)}.install-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:32px 40px;display:flex;justify-content:space-between;align-items:center;position:relative;overflow:hidden}.install-header:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.brand{display:flex;align-items:center;gap:16px;position:relative;z-index:1}.brand-logo{width:56px;height:56px;background:#fff3;border-radius:16px;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.brand-logo .icon{width:28px;height:28px;color:#fff}.brand-text h1{margin:0;font-size:24px;font-weight:700;color:#fff;letter-spacing:-.5px}.brand-text p{margin:4px 0 0;font-size:14px;color:#fffc;font-weight:400}.version-badge{background:#fff3;color:#fff;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);position:relative;z-index:1}.step-indicator{display:flex;align-items:flex-start;padding:28px 40px;background:linear-gradient(180deg,#f8f9fc,#fff);border-bottom:1px solid #eef1f5;overflow-x:auto}.step-wrapper{display:flex;align-items:flex-start;flex:1;min-width:0}.step-item{display:flex;align-items:flex-start;gap:12px;opacity:.5;transition:all .4s cubic-bezier(.4,0,.2,1)}.step-item.active{opacity:1}.step-item.completed{opacity:.7}.step-icon{width:44px;height:44px;border-radius:12px;background:#eef1f5;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .4s cubic-bezier(.4,0,.2,1);border:2px solid transparent}.step-icon .icon{width:20px;height:20px;color:#8892a6}.step-icon svg{width:20px;height:20px;color:#8892a6}.step-item.active .step-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;box-shadow:0 4px 15px #667eea66}.step-item.active .step-icon .icon,.step-item.active .step-icon svg{color:#fff}.step-item.completed .step-icon{background:linear-gradient(135deg,#52c41a,#389e0d);border-color:transparent}.step-item.completed .step-icon svg{color:#fff}.step-info{display:flex;flex-direction:column;gap:2px;padding-top:2px}.step-title{font-size:14px;font-weight:600;color:#1a1a2e;white-space:nowrap}.step-desc{font-size:12px;color:#8892a6;white-space:nowrap}.step-connector{flex:1;height:2px;background:#eef1f5;margin:20px 16px 0;border-radius:1px;transition:all .4s ease;min-width:20px}.step-connector.completed{background:linear-gradient(90deg,#52c41a,#389e0d)}.install-content{padding:40px;min-height:420px}.step-content{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}.content-header{margin-bottom:32px}.content-header h2{margin:0 0 8px;font-size:26px;font-weight:700;color:#1a1a2e;letter-spacing:-.5px}.content-header p{margin:0;font-size:15px;color:#6b7280}.check-list{display:flex;flex-direction:column;gap:16px}.check-item{display:flex;align-items:center;gap:16px;padding:20px 24px;border-radius:16px;background:#f8f9fc;border:1px solid #eef1f5;transition:all .3s ease}.check-item.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.check-item.error{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fecaca}.check-item.info{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#bfdbfe}.check-item.loading{background:linear-gradient(135deg,#fefce8,#fef9c3);border-color:#fef08a}.check-icon-wrapper{width:48px;height:48px;border-radius:12px;background:#fffc;display:flex;align-items:center;justify-content:center;flex-shrink:0}.check-icon-wrapper .icon{width:24px;height:24px}.check-item.success .check-icon-wrapper .icon{color:#22c55e}.check-item.error .check-icon-wrapper .icon{color:#ef4444}.check-item.info .check-icon-wrapper .icon{color:#3b82f6}.check-item.loading .check-icon-wrapper .icon{color:#eab308}.check-info{flex:1;display:flex;flex-direction:column;gap:4px}.check-name{font-size:15px;font-weight:600;color:#1a1a2e}.check-desc{font-size:13px;color:#6b7280}.check-status{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600}.check-status.success{background:#dcfce7;color:#16a34a}.check-status.error{background:#fee2e2;color:#dc2626}.check-status.info{background:#dbeafe;color:#2563eb}.check-status.loading{background:#fef9c3;color:#ca8a04}.config-section{margin-bottom:28px;padding:24px;background:#f8f9fc;border-radius:16px;border:1px solid #eef1f5}.env-tip{display:flex;align-items:flex-start;gap:12px;padding:16px;border-radius:12px;margin-bottom:16px;font-size:14px}.env-tip .icon{width:20px;height:20px;flex-shrink:0;margin-top:2px}.env-tip-content{display:flex;flex-direction:column;gap:8px}.env-tip-title{font-weight:600}.env-tip-detail{font-size:13px;opacity:.9;line-height:1.6}.env-tip-detail code{background:#0000001a;padding:2px 6px;border-radius:4px;font-family:monospace;font-weight:500}.env-tip.docker{background:linear-gradient(135deg,#e6f4ff,#d6e8ff);color:#0052cc;border:1px solid #b3d4ff}.env-tip.local{background:linear-gradient(135deg,#f0f9eb,#e1f3d8);color:#52c41a;border:1px solid #d3f0be}.mode-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.mode-option{display:flex;align-items:flex-start;gap:16px;padding:20px;background:#fff;border:2px solid #e5e7eb;border-radius:14px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.mode-option:hover{border-color:#667eea;background:#667eea05}.mode-option.active{border-color:#667eea;background:linear-gradient(135deg,#667eea14,#764ba214);box-shadow:0 4px 15px #667eea26}.mode-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}.mode-option.active .mode-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.mode-icon .icon{width:24px;height:24px;color:#6b7280;transition:color .3s ease}.mode-option.active .mode-icon .icon{color:#fff}.mode-info{display:flex;flex-direction:column;gap:4px}.mode-title{font-size:15px;font-weight:600;color:#1a1a2e}.mode-desc{font-size:13px;color:#6b7280;line-height:1.4}.section-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.section-header .icon{width:20px;height:20px;color:#667eea}.section-header span{font-size:15px;font-weight:600;color:#374151}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group.full-width{grid-column:1 / -1}.form-label{font-size:13px;font-weight:600;color:#374151}.form-input{padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;color:#1a1a2e;background:#fff;transition:all .3s ease}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.form-input::placeholder{color:#9ca3af}.form-hint{font-size:12px;color:#9ca3af}.password-input-wrapper{position:relative}.password-input-wrapper .form-input{padding-right:48px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#9ca3af;transition:color .2s}.password-toggle:hover{color:#667eea}.password-toggle .icon{width:20px;height:20px}.input-prefix{display:flex;align-items:center;border:2px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden;transition:all .3s ease}.input-prefix:focus-within{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.input-prefix .prefix{padding:14px 16px;background:#f3f4f6;color:#6b7280;font-size:15px;border-right:2px solid #e5e7eb}.input-prefix .form-input{border:none;border-radius:0}.input-prefix .form-input:focus{box-shadow:none}.input-with-action{display:flex;gap:12px}.input-with-action .form-input{flex:1}.test-section{display:flex;align-items:center;gap:16px;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.test-result{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;font-size:14px;font-weight:500}.test-result .icon{width:18px;height:18px}.test-result.success{background:#dcfce7;color:#16a34a}.test-result.error{background:#fee2e2;color:#dc2626}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.btn .icon{width:18px;height:18px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.btn-outline{background:#fff;color:#374151;border:2px solid #e5e7eb}.btn-outline:hover:not(:disabled){border-color:#667eea;color:#667eea;background:#667eea0d}.btn-test{background:#fff;color:#667eea;border:2px solid #667eea}.btn-test:hover:not(:disabled){background:#667eea1a}.btn-test.success{background:#dcfce7;color:#16a34a;border-color:#22c55e}.btn-test.error{background:#fee2e2;color:#dc2626;border-color:#ef4444}.btn-large{padding:18px 40px;font-size:17px}.btn-large .icon{width:20px;height:20px}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.alert{display:flex;gap:14px;padding:18px 20px;border-radius:12px;margin-top:24px}.alert .icon{width:22px;height:22px;flex-shrink:0;margin-top:2px}.alert-content{flex:1}.alert-content strong{display:block;font-size:14px;font-weight:600;margin-bottom:4px}.alert-content p{margin:0;font-size:13px;line-height:1.5}.alert-info{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe}.alert-info .icon{color:#3b82f6}.alert-info strong{color:#1e40af}.alert-info p{color:#3730a3}.alert-warning{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a}.alert-warning .icon{color:#f59e0b}.alert-warning strong{color:#b45309}.alert-warning p{color:#92400e}.alert-error{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca}.alert-error .icon{color:#ef4444}.alert-error strong{color:#b91c1c}.alert-error p{color:#991b1b}.install-mode-selector{display:flex;flex-direction:column;gap:16px}.install-mode-option{display:flex;gap:16px;padding:20px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease}.install-mode-option:hover{border-color:#d1d5db;background:#fafafa}.install-mode-option.active{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#fff)}.mode-radio{width:22px;height:22px;border:2px solid #d1d5db;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;transition:all .2s ease}.install-mode-option.active .mode-radio{border-color:#3b82f6}.radio-dot{width:12px;height:12px;border-radius:50%;background:transparent;transition:all .2s ease}.install-mode-option.active .radio-dot{background:#3b82f6}.mode-content{flex:1}.mode-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.mode-title{font-size:16px;font-weight:600;color:#1f2937}.mode-badge{font-size:11px;font-weight:500;padding:3px 8px;border-radius:4px}.mode-badge.recommended{background:#dcfce7;color:#166534}.mode-badge.demo{background:#fef3c7;color:#92400e}.mode-desc{font-size:13px;color:#6b7280;margin:0 0 12px;line-height:1.5}.mode-features{margin:0;padding-left:18px;font-size:12px;color:#9ca3af;line-height:1.8}.mode-features li{position:relative}.mode-features li::marker{color:#d1d5db}.install-mode-option.active .mode-features{color:#6b7280}.install-mode-option.active .mode-features li::marker{color:#3b82f6}.success-container{text-align:center;padding:20px 0}.success-animation{margin-bottom:24px}.success-checkmark{width:100px;height:100px;margin:0 auto;background:linear-gradient(135deg,#52c41a,#389e0d);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px #52c41a66;animation:scaleIn .5s cubic-bezier(.4,0,.2,1)}@keyframes scaleIn{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-checkmark .check-icon{width:50px;height:50px;color:#fff}.success-checkmark svg{width:50px;height:50px;color:#fff}.success-container h2{margin:0 0 8px;font-size:28px;font-weight:700;color:#1a1a2e}.success-desc{margin:0 0 32px;font-size:16px;color:#6b7280}.result-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.result-card{display:flex;align-items:center;gap:14px;padding:20px;background:#f8f9fc;border-radius:16px;border:1px solid #eef1f5;text-align:left}.result-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0}.result-icon .icon{width:20px;height:20px;color:#fff}.result-info{display:flex;flex-direction:column;gap:4px;overflow:hidden}.result-label{font-size:12px;color:#6b7280;white-space:nowrap}.result-value{font-size:14px;font-weight:600;color:#1a1a2e;word-break:break-all}.install-footer{display:flex;justify-content:space-between;align-items:center;padding:24px 40px;background:#f8f9fc;border-top:1px solid #eef1f5}.footer-info{font-size:14px;color:#6b7280}.footer-actions{display:flex;gap:12px}.install-footer-brand{margin-top:24px;text-align:center}.install-footer-brand p{margin:0;font-size:13px;color:#ffffff80}@media (max-width: 768px){.install-page{padding:20px 16px}.install-header{padding:24px;flex-direction:column;gap:16px;text-align:center}.brand{flex-direction:column}.step-indicator{padding:20px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.step-wrapper{flex:none;min-width:auto}.step-item{flex-direction:column;align-items:center;text-align:center;gap:8px}.step-info{align-items:center;padding-top:0}.step-connector{display:none}.install-content{padding:24px}.form-grid,.mode-selector,.result-cards{grid-template-columns:1fr}.install-footer{flex-direction:column;gap:16px;padding:20px 24px}.footer-actions{width:100%;flex-direction:column}.footer-actions .btn{width:100%}}.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fffffffa;box-shadow:0 1px #0000000f;transition:all .3s ease}.header.scrolled{background:#fff;box-shadow:0 2px 12px #00000014}.header-container{max-width:1200px;margin:0 auto;padding:0 24px;height:80px;display:flex;align-items:center;justify-content:space-between}.header-logo{display:flex;align-items:center;gap:12px}.logo-img{width:44px;height:44px;object-fit:contain}.logo-text{display:flex;flex-direction:column}.logo-company{font-size:18px;font-weight:600;color:var(--color-text);letter-spacing:1px}.header-nav{display:flex;align-items:center;gap:8px}.nav-item{padding:10px 20px;font-size:15px;color:var(--color-text-light);background:transparent;border-radius:6px;transition:all .3s ease;position:relative}.nav-item:hover{color:var(--color-primary);background:#e539350d}.nav-item.active{color:var(--color-primary);font-weight:500}.nav-item.active:after{content:"";position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:20px;height:3px;background:var(--color-primary);border-radius:2px}.mobile-menu-btn{display:none;flex-direction:column;justify-content:space-between;width:24px;height:18px;background:transparent;padding:0}.mobile-menu-btn span{display:block;height:2px;background:var(--color-text);border-radius:1px;transition:all .3s ease}.mobile-nav{display:none;position:absolute;top:80px;left:0;right:0;background:#fffffffa;box-shadow:0 4px 12px #0000001a;flex-direction:column;padding:16px;gap:8px;z-index:999}.mobile-nav.open{display:flex}.mobile-nav-item{padding:14px 20px;font-size:16px;color:var(--color-text);background:transparent;border-radius:8px;text-align:left;transition:all .3s ease;border:none;cursor:pointer}.mobile-nav-item:hover{background:#e539350d;color:var(--color-primary)}.mobile-nav-item.active{background:#e539351a;color:var(--color-primary);font-weight:500}.mobile-menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}@media (max-width: 768px){.header-container{height:64px;padding:0 16px}.header-nav{display:none}.mobile-menu-btn{display:flex}.mobile-nav{top:64px}.logo-img{width:36px;height:36px}.logo-company{font-size:14px}}.hero-section{min-height:100vh;padding-top:80px;background:linear-gradient(180deg,#fff,#fff8e1);position:relative;overflow:hidden}.hero-bg-shapes{position:absolute;inset:0;pointer-events:none}.shape{position:absolute;border-radius:50%;opacity:.5}.shape-1{width:400px;height:400px;background:radial-gradient(circle,rgba(229,57,53,.08) 0%,transparent 70%);top:-100px;right:-100px}.shape-2{width:300px;height:300px;background:radial-gradient(circle,rgba(255,179,0,.1) 0%,transparent 70%);bottom:10%;left:-50px}.shape-3{width:200px;height:200px;background:radial-gradient(circle,rgba(229,57,53,.06) 0%,transparent 70%);top:40%;right:20%}.hero-content{display:flex;align-items:center;justify-content:space-between;min-height:calc(100vh - 80px);padding:60px 24px;gap:60px}.hero-text{flex:1;max-width:600px}.hero-title{font-size:48px;font-weight:700;line-height:1.3;color:var(--color-text);margin-bottom:24px}.hero-title .highlight{color:var(--color-primary);position:relative}.hero-subtitle{font-size:18px;color:var(--color-text-light);line-height:1.8;margin-bottom:40px}.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}.hero-btn{padding:16px 32px;font-size:16px;display:flex;align-items:center;gap:8px}.btn-icon{font-size:20px}.hero-illustration{flex:1;display:flex;justify-content:center;align-items:center;position:relative;perspective:1000px}.phone-wrapper{position:relative;transform-style:preserve-3d}.phone-mockup{width:280px;height:560px;background:linear-gradient(145deg,#2a2a2a,#1a1a1a);border-radius:44px;padding:10px;box-shadow:0 50px 100px #00000040,0 30px 60px #e539351a,inset 0 1px #ffffff1a;position:relative;transform:perspective(1000px) rotateY(0) rotateX(0);transition:transform .6s ease,box-shadow .6s ease;animation:phoneFloat 6s ease-in-out infinite}.phone-mockup:hover{transform:perspective(1000px) rotateY(0) rotateX(0) translateY(-10px);box-shadow:0 60px 120px #0000004d,0 40px 80px #e5393526,inset 0 1px #ffffff26}.phone-mockup:before{content:"";position:absolute;top:20px;left:50%;transform:translate(-50%);width:80px;height:24px;background:linear-gradient(180deg,#444,#222);border-radius:12px;box-shadow:inset 0 1px 1px #ffffff1a}.phone-mockup:after{content:"";position:absolute;inset:0;border-radius:44px;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 50%);pointer-events:none}.phone-mockup .phone-button-left,.phone-mockup .phone-button-right{position:absolute;background:linear-gradient(180deg,#333,#222);border-radius:2px}.phone-mockup .phone-button-left{width:3px;height:60px;left:-2px;top:120px}.phone-mockup .phone-button-right{width:3px;height:80px;right:-2px;top:140px}@keyframes phoneFloat{0%,to{transform:perspective(1000px) rotateY(0) rotateX(0) translateY(0)}50%{transform:perspective(1000px) rotateY(0) rotateX(0) translateY(-20px)}}.phone-screen{width:100%;height:100%;background:#fff;border-radius:36px;overflow:hidden;position:relative;box-shadow:inset 0 0 20px #0000001a}.screen-image{width:100%;height:100%;object-fit:cover;object-position:top}.banner-dots{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);display:flex;gap:8px;z-index:10}.banner-dots .dot{width:8px;height:8px;border-radius:50%;background:#e539354d;cursor:pointer;transition:all .3s}.banner-dots .dot.active{background:var(--color-primary);width:24px;border-radius:4px}.floating-badge{position:absolute;background:#fff;border-radius:12px;padding:12px 16px;box-shadow:0 10px 40px #00000026;display:flex;align-items:center;gap:10px;animation:badgeFloat 4s ease-in-out infinite;z-index:10}.floating-badge.badge-1{top:-20px;right:-40px;animation-delay:0s}.floating-badge.badge-2{bottom:120px;right:-60px;animation-delay:2s}.floating-badge.badge-3{bottom:-20px;left:-60px;animation-delay:1s}@keyframes badgeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.badge-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}.badge-icon.red{background:linear-gradient(135deg,#e53935,#ff6659)}.badge-icon.yellow{background:linear-gradient(135deg,#ffb300,#ffd54f)}.badge-text{display:flex;flex-direction:column}.badge-title{font-size:14px;font-weight:600;color:#333}.badge-desc{font-size:11px;color:#999}.phone-reflection{position:absolute;bottom:-60px;left:50%;transform:translate(-50%) scaleY(-1);width:260px;height:120px;background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);border-radius:0 0 36px 36px;opacity:.15;filter:blur(2px);pointer-events:none}.phone-glow{position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(229,57,53,.15) 0%,transparent 70%);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1;animation:glowPulse 4s ease-in-out infinite}@keyframes glowPulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.1)}}@media (max-width: 1200px){.floating-badge{display:none}}@media (max-width: 992px){.hero-content{flex-direction:column;text-align:center;gap:40px}.hero-text{max-width:100%}.hero-buttons{justify-content:center}.hero-illustration{width:100%}.phone-mockup{width:240px;height:480px;transform:rotateY(0) rotateX(5deg)}.phone-reflection,.floating-badge{display:none}}@media (max-width: 768px){.hero-section{padding-top:64px;min-height:auto}.hero-content{padding:40px 16px;min-height:auto}.hero-title{font-size:32px}.hero-subtitle{font-size:16px}.hero-buttons{flex-direction:column;width:100%}.hero-btn{width:100%;justify-content:center}.phone-mockup{width:200px;height:400px;animation:phoneFloatMobile 6s ease-in-out infinite}@keyframes phoneFloatMobile{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.phone-glow{width:300px;height:300px}}.about-section{padding:100px 0;background:var(--color-bg)}.about-content{max-width:900px;margin:0 auto}.about-card{background:var(--color-bg-gray);border-radius:var(--radius-lg);padding:48px;position:relative;border-left:4px solid var(--color-primary)}.about-card-content{margin-bottom:40px}.about-text{font-size:16px;line-height:1.8;color:var(--color-text-light);margin-bottom:20px}.about-text:last-child{margin-bottom:0}.about-text strong{color:var(--color-primary);font-weight:600}.about-text-first .company-name{color:#e53935;font-weight:600}.about-stats{display:flex;justify-content:space-around;padding-top:32px;border-top:1px solid var(--color-border)}.stat-item{text-align:center}.stat-number{display:block;font-size:36px;font-weight:700;color:var(--color-primary);line-height:1;margin-bottom:8px}.stat-label{font-size:14px;color:var(--color-text-muted)}@media (max-width: 768px){.about-section{padding:60px 0}.about-card{padding:24px}.about-text{font-size:15px}.about-stats{flex-direction:column;gap:24px}.stat-number{font-size:28px}}.business-section{padding:100px 0;background:var(--color-bg-warm)}.business-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:48px}.business-card{background:#fff;border-radius:var(--radius-lg);padding:32px 24px;text-align:center;box-shadow:var(--shadow-sm);transition:all .3s ease;animation:fadeInUp .6s ease forwards;opacity:0}.business-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.business-icon{width:72px;height:72px;margin:0 auto 20px;background:var(--color-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px}.business-name{font-size:18px;font-weight:600;color:var(--color-primary);margin-bottom:12px}.business-desc{font-size:14px;color:var(--color-text-muted);line-height:1.6}.business-notice{text-align:center;padding:24px;background:#e539350d;border-radius:var(--radius-md);color:var(--color-text-light)}.business-notice strong{color:var(--color-primary)}@media (max-width: 992px){.business-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 576px){.business-section{padding:60px 0}.business-grid{grid-template-columns:1fr;gap:16px}.business-card{padding:24px 16px}.business-icon{width:60px;height:60px;font-size:28px}.business-name{font-size:16px}}.product-section{padding:100px 0;background:var(--color-bg)}.products-container{max-width:1000px;margin:0 auto}.product-item{display:flex;align-items:center;gap:80px;margin-bottom:80px;padding-bottom:80px;border-bottom:1px solid var(--color-border)}.product-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.product-item.reverse{flex-direction:row-reverse}.product-mockup{flex-shrink:0}.mockup-phone{width:260px;height:520px;background:#1a1a1a;border-radius:36px;padding:12px;box-shadow:0 30px 60px #00000026}.mockup-phone.wechat{background:#07c160}.mockup-screen{width:100%;height:100%;background:#fff;border-radius:28px;overflow:hidden}.app-preview{height:100%;display:flex;flex-direction:column}.app-header{padding:40px 16px 16px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;display:flex;align-items:center;gap:8px}.app-logo{font-size:20px}.app-title{font-size:16px;font-weight:600}.app-nav{display:flex;justify-content:space-around;padding:12px;background:#f5f5f5;font-size:12px;color:var(--color-text-muted)}.nav-item-active{color:var(--color-primary);font-weight:500}.app-content{flex:1;padding:12px;display:flex;flex-direction:column;gap:8px}.job-card{padding:12px;background:#f9f9f9;border-radius:8px}.job-title{font-size:13px;color:var(--color-text);margin-bottom:4px}.job-salary{font-size:12px;color:var(--color-primary);font-weight:500}.miniapp-preview{height:100%;display:flex;flex-direction:column}.mini-header{padding:40px 16px 16px;background:#07c160;color:#fff;font-size:16px;font-weight:600;text-align:center}.mini-content{padding:20px 12px}.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.mini-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:#f5f5f5;border-radius:8px;font-size:12px}.mini-icon{font-size:24px}.qrcode-placeholder{flex:1;display:flex;align-items:center;justify-content:center;padding:16px}.qrcode-box{width:100px;height:100px;background:#f5f5f5;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--color-text-muted)}.product-info{flex:1}.product-badge{display:inline-block;padding:6px 16px;background:var(--color-primary);color:#fff;font-size:12px;font-weight:500;border-radius:20px;margin-bottom:16px}.wechat-badge{background:#07c160}.product-name{font-size:28px;font-weight:700;color:var(--color-text);margin-bottom:16px}.product-desc{font-size:15px;color:var(--color-text-light);line-height:1.8;margin-bottom:24px}.product-features{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}.feature-tag{padding:6px 14px;background:var(--color-bg-warm);color:var(--color-text-light);font-size:13px;border-radius:20px}.product-btn{padding:14px 40px}.wechat-tip{display:flex;align-items:center;gap:8px;color:var(--color-text-muted);font-size:14px}.wechat-icon{font-size:18px}@media (max-width: 992px){.product-item,.product-item.reverse{flex-direction:column;gap:40px}.mockup-phone{width:220px;height:440px}}@media (max-width: 576px){.product-section{padding:60px 0}.product-item{margin-bottom:60px;padding-bottom:60px}.mockup-phone{width:180px;height:360px}.product-name{font-size:22px}.product-desc{font-size:14px}.product-features{gap:6px}.feature-tag{padding:4px 10px;font-size:12px}}.qr-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.qr-modal{background:#fff;border-radius:12px;padding:40px;text-align:center;position:relative;max-width:360px}.qr-modal-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:28px;cursor:pointer;color:#999;line-height:1}.qr-modal-close:hover{color:#333}.qr-modal h3{margin:0 0 20px;font-size:18px;color:#333}.qr-modal-img{width:240px;height:240px;object-fit:contain;border:1px solid #eee;border-radius:8px}.qr-modal p{margin:16px 0 0;color:#999;font-size:14px}.contact-section{padding:100px 0;background:var(--color-bg-gray)}.contact-content{display:flex;gap:60px;max-width:900px;margin:0 auto}.contact-info{flex:1}.info-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}.info-item:last-child{margin-bottom:0}.info-icon{width:48px;height:48px;background:var(--color-bg-warm);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.info-content h4{font-size:14px;color:var(--color-text-muted);font-weight:400;margin-bottom:4px}.info-content p{font-size:16px;color:var(--color-text);font-weight:500}.contact-qrcode{flex-shrink:0}.qrcode-card{background:#fff;border-radius:var(--radius-lg);padding:24px;text-align:center;box-shadow:var(--shadow-sm)}.qrcode-placeholder{width:160px;height:160px;background:var(--color-bg-gray);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:12px}.qrcode-icon{font-size:48px;margin-bottom:8px}.qrcode-placeholder p{font-size:12px;color:var(--color-text-muted)}.qrcode-image-wrapper{width:160px;height:160px;background:var(--color-bg-gray);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:12px;overflow:hidden}.qrcode-image{width:100%;height:100%;object-fit:contain;padding:8px}.qrcode-tip{font-size:13px;color:var(--color-text-light)}@media (max-width: 768px){.contact-section{padding:60px 0}.contact-content{flex-direction:column;gap:40px}.contact-qrcode{display:flex;justify-content:center}}.footer{background:#1a1a1a;padding:40px 24px;color:#ffffffb3;text-align:center}.footer-links{margin-bottom:24px;display:flex;justify-content:center;align-items:center;gap:16px}.footer-link{color:#fffc;font-size:14px;background:transparent;transition:color .3s}.footer-link:hover{color:var(--color-secondary)}.link-divider{color:#ffffff4d}.footer-license{display:flex;flex-direction:column;gap:8px}.license-text{font-size:13px;line-height:1.6}@media (max-width: 576px){.footer{padding:32px 16px}.license-text{font-size:12px}}.modal-overlay{position:fixed;inset:0;background:#0009;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .3s ease}.modal-content{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:720px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-border)}.modal-header h3{font-size:18px;font-weight:600;color:var(--color-text)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--color-text-muted);background:transparent;border-radius:50%;transition:all .3s}.modal-close:hover{background:var(--color-bg-gray);color:var(--color-text)}.modal-body{padding:24px;overflow-y:auto;flex:1}.agreement-content{font-size:14px;line-height:1.8;color:var(--color-text-light)}.agreement-content h4{font-size:16px;font-weight:600;color:var(--color-text);margin:24px 0 12px}.agreement-content h4:first-child{margin-top:0}.agreement-content p{margin-bottom:12px}.agreement-content ul{margin:12px 0;padding-left:24px}.agreement-content li{margin-bottom:8px}.loading-text{text-align:center;padding:40px 0;color:var(--color-text-muted);font-size:14px}.update-time{margin-top:32px;padding-top:16px;border-top:1px solid var(--color-border);color:var(--color-text-muted);font-size:13px}@media (max-width: 576px){.modal-overlay{padding:16px}.modal-content{max-height:90vh}.modal-header{padding:16px 20px}.modal-body{padding:20px}.agreement-content{font-size:13px}}.admin-layout{display:flex;min-height:100vh;background:#f5f7fa}.admin-layout.sidebar-collapsed .admin-sidebar{width:80px}.admin-layout.sidebar-collapsed .sidebar-header{padding:20px 12px}.admin-layout.sidebar-collapsed .sidebar-header-text{display:none}.admin-layout.sidebar-collapsed .sidebar-logo-img{margin:0 auto}.admin-layout.sidebar-collapsed .menu-text,.admin-layout.sidebar-collapsed .menu-arrow{display:none}.admin-layout.sidebar-collapsed .menu-item,.admin-layout.sidebar-collapsed .menu-group-title{justify-content:center;padding:14px}.admin-layout.sidebar-collapsed .menu-icon{margin-right:0}.admin-layout.sidebar-collapsed .sidebar-footer{padding:16px 8px}.admin-layout.sidebar-collapsed .user-info{display:none}.admin-layout.sidebar-collapsed .logout-btn{padding:10px;font-size:12px}.admin-layout.sidebar-collapsed .admin-main{margin-left:80px}.admin-sidebar{width:260px;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:1000;box-shadow:4px 0 24px #00000026;transition:width .3s ease}.sidebar-header{padding:28px 24px;border-bottom:1px solid rgba(255,255,255,.08);text-align:center;background:linear-gradient(180deg,rgba(59,130,246,.15) 0%,transparent 100%)}.sidebar-logo-img{width:56px;height:56px;object-fit:contain;margin:0 auto 16px;border-radius:14px;box-shadow:0 4px 12px #0000004d;transition:transform .3s ease}.sidebar-logo-img:hover{transform:scale(1.05)}.sidebar-header h1{font-size:20px;margin-bottom:6px;font-weight:600;letter-spacing:1px;background:linear-gradient(135deg,#fff,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-header p{font-size:13px;opacity:.6;font-weight:400}.sidebar-menu{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-menu::-webkit-scrollbar{width:4px}.sidebar-menu::-webkit-scrollbar-track{background:transparent}.sidebar-menu::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.menu-item{display:flex;align-items:center;padding:14px 18px;color:#ffffffa6;transition:all .25s ease;border-radius:10px;margin-bottom:4px;font-weight:450}.menu-item:hover{background:#ffffff14;color:#fff;transform:translate(4px)}.menu-item.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f666}.menu-item.active:hover{transform:translate(0)}.menu-icon{font-size:20px;margin-right:14px;width:24px;text-align:center;display:flex;align-items:center;justify-content:center}.menu-text{font-size:15px;flex:1}.menu-group{margin-bottom:6px}.menu-group-title{display:flex;align-items:center;padding:14px 18px;color:#ffffffa6;font-size:15px;font-weight:450;border-radius:10px}.menu-group-title.clickable{cursor:pointer;transition:all .25s ease}.menu-group-title.clickable:hover{background:#ffffff14;color:#fff}.menu-group-title.clickable.active{color:#fff;background:linear-gradient(135deg,#3b82f64d,#2563eb33)}.menu-group-title .menu-icon{font-size:20px;margin-right:14px;width:24px;text-align:center}.menu-arrow{margin-left:auto;font-size:10px;transition:transform .3s ease;opacity:.5}.menu-arrow.expanded{transform:rotate(180deg);opacity:1}.menu-group-children{background:#0003;border-radius:10px;margin-top:4px;padding:8px 0}.menu-item.sub-menu{padding:12px 18px 12px 56px;margin-bottom:2px;border-radius:8px}.menu-item.sub-menu .menu-icon{font-size:16px;margin-right:12px;width:20px}.menu-item.sub-menu .menu-text{font-size:14px}.sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.2) 100%)}.user-info{padding:14px 16px;margin-bottom:14px;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.08)}.user-name{display:block;font-size:15px;color:#fff;margin-bottom:4px;font-weight:500}.user-role{font-size:12px;color:#ffffff80;display:flex;align-items:center}.user-role:before{content:"";width:6px;height:6px;background:#22c55e;border-radius:50%;margin-right:6px;box-shadow:0 0 8px #22c55e80}.sidebar-actions{display:flex;gap:10px}.sidebar-action-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#3b82f626;color:#93c5fd;border-radius:10px;font-size:20px;transition:all .25s ease;border:1px solid rgba(59,130,246,.2);text-decoration:none;cursor:pointer}.sidebar-action-btn:hover{background:#3b82f640;color:#fff;transform:translateY(-1px)}.logout-btn{flex:1;padding:12px;background:#ef444426;color:#fca5a5;border-radius:10px;font-size:14px;font-weight:500;transition:all .25s ease;border:1px solid rgba(239,68,68,.2)}.logout-btn:hover{background:#ef444440;color:#fff;transform:translateY(-1px)}.sidebar-toggle{position:absolute;right:-14px;top:50%;transform:translateY(-50%);width:28px;height:28px;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #3b82f666;transition:all .25s ease;z-index:10}.sidebar-toggle:hover{transform:translateY(-50%) scale(1.1);box-shadow:0 4px 12px #3b82f680}.toggle-icon{color:#fff;font-size:10px;line-height:1}.admin-main{flex:1;margin-left:260px;background:linear-gradient(135deg,#f5f7fa,#e4e8ed);min-height:100vh;transition:margin-left .3s ease}.admin-content{padding:28px}.admin-page{background:#fff;border-radius:16px;padding:28px;box-shadow:0 1px 3px #0000000d,0 4px 12px #0000000a;border:1px solid rgba(0,0,0,.04)}.admin-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #f0f2f5}.admin-page-title{font-size:22px;font-weight:600;color:#1e293b;letter-spacing:-.5px}.admin-page-actions{display:flex;gap:12px}.search-bar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.search-input{width:260px;height:42px;padding:0 18px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;transition:all .25s ease;background:#f8fafc}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fff}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:16px 18px;background:#f8fafc;font-size:13px;font-weight:600;color:#64748b;text-align:left;border-bottom:1px solid #e2e8f0;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:16px 18px;font-size:14px;color:#475569;border-bottom:1px solid #f1f5f9}.data-table tr:hover{background:#f8fafc}.table-actions{display:flex;gap:8px}.table-btn{padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;transition:all .2s ease}.table-btn-edit{background:#eff6ff;color:#3b82f6;border:1px solid #bfdbfe}.table-btn-edit:hover{background:#3b82f6;color:#fff;border-color:#3b82f6}.table-btn-delete{background:#fef2f2;color:#ef4444;border:1px solid #fecaca}.table-btn-delete:hover{background:#ef4444;color:#fff;border-color:#ef4444}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px}.page-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#64748b;background:#fff;transition:all .2s ease}.page-btn:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.page-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff;box-shadow:0 2px 8px #3b82f64d}.admin-modal-overlay{position:fixed;inset:0;background:#0f172a99;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-modal{width:90%;max-width:600px;background:#fff;border-radius:16px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid #f1f5f9}.admin-modal-title{font-size:18px;font-weight:600;color:#1e293b}.modal-close-btn{font-size:24px;color:#94a3b8;background:none;padding:0;transition:color .2s ease}.modal-close-btn:hover{color:#475569}.admin-modal-body{padding:28px}.admin-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 28px;border-top:1px solid #f1f5f9;background:#f8fafc;border-radius:0 0 16px 16px}.loading{text-align:center;padding:80px 20px;color:#64748b;font-size:15px;display:flex;flex-direction:column;align-items:center;gap:12px}.loading:before{content:"";width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1200px){.admin-sidebar{width:240px}.admin-main{margin-left:240px}}@media (max-width: 992px){.admin-sidebar{width:220px}.admin-main{margin-left:220px}.admin-content{padding:20px}}@media (max-width: 768px){.admin-sidebar{transform:translate(-100%);transition:transform .3s ease}.admin-sidebar.open{transform:translate(0)}.admin-main{margin-left:0}.admin-content{padding:16px}.admin-page{padding:20px;border-radius:12px}}.admin-login-page{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.admin-login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 30%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(139,92,246,.08) 0%,transparent 50%);animation:bgMove 20s ease-in-out infinite}@keyframes bgMove{0%,to{transform:translate(0)}50%{transform:translate(-5%,-5%)}}.admin-login-box{width:100%;max-width:420px;background:#fffffffa;border-radius:20px;padding:48px 36px;box-shadow:0 25px 50px -12px #0006,0 0 0 1px #ffffff1a;position:relative;z-index:1;backdrop-filter:blur(20px);animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.login-logo-img{width:72px;height:72px;object-fit:contain;margin:0 auto 20px;border-radius:18px;box-shadow:0 8px 24px #00000026;transition:transform .3s ease}.login-logo-img:hover{transform:scale(1.05) rotate(-2deg)}.logo{font-size:48px;margin-bottom:16px}.login-header h1{font-size:24px;color:#0f172a;margin-bottom:8px;font-weight:700;letter-spacing:-.5px}.login-header p{font-size:14px;color:#64748b;font-weight:400}.error-message{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;color:#dc2626;padding:14px 18px;border-radius:12px;margin-bottom:24px;font-size:14px;display:flex;align-items:center;gap:10px;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-message:before{content:"⚠️";font-size:16px}.error-message.locked{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fcd34d;color:#b45309}.remaining-hint{font-size:12px;opacity:.8;margin-left:auto}.input-group,.captcha-group{margin-bottom:22px}.captcha-wrapper{display:flex;gap:12px;align-items:center}.captcha-input{flex:1;min-width:0}.captcha-image{width:120px;height:48px;border-radius:10px;cursor:pointer;overflow:hidden;background:#f0f0f0;border:2px solid #e5e7eb;transition:all .25s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.captcha-image:hover{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.captcha-image svg{width:100%;height:100%}.input-label{display:block;margin-bottom:10px;font-size:14px;color:#374151;font-weight:600;letter-spacing:.3px}.input-field{width:100%;padding:14px 18px;font-size:15px;border:2px solid #e5e7eb;border-radius:12px;background:#f9fafb;transition:all .25s ease;box-sizing:border-box}.input-field:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a;background:#fff}.input-field:hover:not(:focus){border-color:#d1d5db}.input-field:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.7}.input-field::placeholder{color:#9ca3af}.submit-btn{width:100%;margin-top:28px;padding:16px;font-size:16px;font-weight:600;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 14px #3b82f666;transition:all .25s ease;letter-spacing:.5px}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b82f680}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-tips{margin-top:28px;padding:18px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;font-size:13px;color:#64748b;text-align:center;border:1px solid #e2e8f0}.login-tips p{margin-bottom:6px}.login-tips .warning{color:#dc2626;margin-top:10px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px}.back-link{margin-top:24px;text-align:center}.back-link a{color:#3b82f6;font-size:14px;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:4px}.back-link a:hover{color:#2563eb;gap:8px}@media (max-width: 480px){.admin-login-box{padding:36px 24px;border-radius:16px}.login-logo-img{width:60px;height:60px}.login-header h1{font-size:22px}}.admin-banners{padding:0;background:transparent;border-radius:0}.admin-banners .ant-table{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-banners .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:16px 18px}.admin-banners .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:16px 18px;color:#475569;font-size:14px;transition:background .2s ease}.admin-banners .ant-table-tbody>tr:hover>td{background:#f8fafc}.admin-banners .ant-table img{border-radius:8px;box-shadow:0 2px 8px #0000001a}.admin-banners .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.admin-banners .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.admin-banners .ant-modal-content{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.admin-banners .ant-modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:20px 24px}.admin-banners .ant-modal-title{font-weight:600;color:#0f172a;font-size:18px}.admin-banners .ant-modal-body{padding:24px}.admin-banners .ant-modal-footer{border-top:1px solid #f1f5f9;padding:16px 24px;background:#f8fafc}.admin-banners .ant-tag{border-radius:6px;padding:4px 10px;font-weight:500;border:none;font-size:12px}.admin-banners .ant-switch-checked{background:linear-gradient(135deg,#22c55e,#16a34a)}@media (max-width: 768px){.admin-banners{padding:0}.page-header{flex-direction:column;gap:16px}}.admin-business{padding:0}.business-card{height:100%;border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a;transition:all .3s ease;overflow:hidden}.business-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.business-card .ant-card-head{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.business-card .ant-card-head-title{font-weight:600;color:#1e293b}.card-id{color:#94a3b8;font-size:12px;font-weight:500}.business-card .ant-card-body{padding:20px}.business-card .ant-form-item{margin-bottom:16px}.business-card .ant-form-item:last-child{margin-bottom:0}.business-card .ant-form-item-label>label{color:#374151;font-weight:500}.business-card .ant-input,.business-card .ant-input-number,.business-card .ant-select-selector{border-radius:10px;border:2px solid #e5e7eb;transition:all .25s ease}.business-card .ant-input:focus,.business-card .ant-input-focused,.business-card .ant-input-number:focus,.business-card .ant-select-focused .ant-select-selector{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.business-card .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;border-radius:10px;transition:all .25s ease}.business-card .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.business-card .ant-select-selection-item,.business-card .ant-select-dropdown .ant-select-item{text-align:left!important}.admin-business .ant-row{row-gap:20px}.admin-business .ant-switch-checked{background:linear-gradient(135deg,#22c55e,#16a34a)}@media (max-width: 768px){.admin-business{padding:0}}/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor ul,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"•"}.ql-editor ul[data-checked=true],.ql-editor ul[data-checked=false]{pointer-events:none}.ql-editor ul[data-checked=true]>li *,.ql-editor ul[data-checked=false]>li *{pointer-events:all}.ql-editor ul[data-checked=true]>li:before,.ql-editor ul[data-checked=false]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"☑"}.ql-editor ul[data-checked=false]>li:before{content:"☐"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;counter-increment:list-0}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media (pointer: coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{white-space:pre-wrap;margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0px}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0px;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.admin-company{padding:0;background:transparent;border-radius:0}.company-card{border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a;overflow:hidden}.company-card .ant-card-head{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.company-card .ant-card-head-title{font-weight:600;color:#1e293b;font-size:16px}.configs-list{padding:8px 0}.config-item{padding:20px 0;border-bottom:1px solid #f1f5f9}.config-item:last-child{border-bottom:none}.config-label{display:flex;align-items:center;margin-bottom:16px}.config-name{font-size:15px;font-weight:600;color:#1e293b;margin-right:12px}.config-type-tag{font-size:12px;color:#64748b;padding:4px 10px;background:#f1f5f9;border-radius:6px;font-weight:500}.config-item .ant-form-item{margin-bottom:16px}.config-item .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.config-item .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.config-item .ant-divider{margin:24px 0;border-color:#f1f5f9}.admin-company .quill{border:2px solid #e5e7eb;border-radius:12px;max-width:100%;transition:all .25s ease}.admin-company .quill:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.admin-company .ql-toolbar{border-bottom:1px solid #e5e7eb;border-radius:10px 10px 0 0;background:#f8fafc}.admin-company .ql-container{border:none;min-height:350px;font-size:14px}.admin-company .ql-editor{min-height:350px;padding:16px;line-height:1.6}.admin-company .ql-editor.ql-blank:before{font-style:normal;color:#9ca3af}.config-item .ant-input,.config-item .ant-input:focus,.config-item .ant-input-focused{border:2px solid #e5e7eb;border-radius:10px;transition:all .25s ease}.config-item .ant-input:hover{border-color:#d1d5db}.config-item .ant-input:focus,.config-item .ant-input-focused{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.logo-upload-wrapper{display:flex;align-items:flex-start;gap:20px}.logo-uploader{width:120px;height:120px}.logo-uploader .ant-upload{width:120px;height:120px;display:flex;align-items:center;justify-content:center;border:2px dashed #e5e7eb;border-radius:12px;background:#f9fafb;cursor:pointer;transition:all .25s ease}.logo-uploader .ant-upload:hover{border-color:#3b82f6;background:#eff6ff}.logo-uploader .ant-upload-select-picture-card{background:#f9fafb}.logo-actions{display:flex;flex-direction:column;gap:10px}@media (max-width: 768px){.admin-company{padding:0}.config-item{padding:16px 0}.admin-company .ql-editor{min-height:250px}.logo-upload-wrapper{flex-direction:column}}.admin-agreements{padding:0;background:transparent;border-radius:0}.admin-agreements .ant-tabs-content{padding:20px 0}.admin-agreements .ant-tabs-tab{font-weight:500;padding:12px 16px}.admin-agreements .ant-tabs-tab-active .ant-tabs-tab-btn{color:#3b82f6}.admin-agreements .ant-tabs-ink-bar{background:#3b82f6}.admin-agreements .ant-form-item{margin-bottom:20px}.admin-agreements .ant-form-item-label>label{color:#374151;font-weight:500}.admin-agreements .ant-card{border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-agreements .ant-card-head{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.admin-agreements .ant-card-head-title{font-weight:600;color:#1e293b}.admin-agreements .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.admin-agreements .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.admin-agreements .quill{border:2px solid #e5e7eb;border-radius:12px;transition:all .25s ease}.admin-agreements .quill:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.admin-agreements .ql-toolbar{border-bottom:1px solid #e5e7eb;border-radius:10px 10px 0 0;background:#f8fafc}.admin-agreements .ql-container{border:none;min-height:400px;font-size:14px}.admin-agreements .ql-editor{min-height:400px;padding:16px;line-height:1.6}.admin-agreements .ql-editor.ql-blank:before{font-style:normal;color:#9ca3af}.agreement-update-time{background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:14px 18px;border-radius:10px;margin-bottom:20px;color:#1e40af;font-size:14px;font-weight:500;border:1px solid #bfdbfe}.agreement-update-time .anticon{margin-right:8px;color:#3b82f6}@media (max-width: 768px){.admin-agreements{padding:0}.admin-agreements .ql-editor{min-height:300px}}.admin-certificates{padding:0;background:transparent;border-radius:0}.status-tag{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:500;border:none}.status-tag.approved{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.status-tag.pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309}.admin-certificates .ant-table{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-certificates .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:16px 18px}.admin-certificates .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:16px 18px;color:#475569;font-size:14px;transition:background .2s ease}.admin-certificates .ant-table-tbody>tr:hover>td{background:#f8fafc}.admin-certificates .ant-table img{border-radius:8px;box-shadow:0 2px 8px #0000001a}.admin-certificates .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.admin-certificates .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.admin-certificates .ant-modal-content{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.admin-certificates .ant-modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:20px 24px}.admin-certificates .ant-modal-title{font-weight:600;color:#0f172a;font-size:18px}.admin-certificates .ant-modal-body{padding:24px}.admin-certificates .ant-modal-footer{border-top:1px solid #f1f5f9;padding:16px 24px;background:#f8fafc}@media (max-width: 768px){.admin-certificates{padding:0}.page-header{flex-direction:column;gap:16px}}.admin-leads{padding:0;background:transparent;border-radius:0}.stats-cards{display:flex;gap:20px;margin-bottom:28px}.stat-card{flex:1;padding:20px;background:#fff;border-radius:16px;text-align:center;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a;transition:all .3s ease}.stat-label{font-size:13px;color:#64748b;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-value{font-size:32px;font-weight:700;color:#0f172a;letter-spacing:-1px}.stat-value.pending{color:#f59e0b}.stat-value.success{color:#22c55e}.filter-bar{margin-bottom:20px}.filter-bar .ant-input,.filter-bar .ant-select-selector{border-radius:10px;border:2px solid #e5e7eb;transition:all .25s ease}.filter-bar .ant-input:focus,.filter-bar .ant-select-focused .ant-select-selector{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.lead-detail{padding:20px 0}.detail-item{display:flex;margin-bottom:14px;line-height:1.6}.detail-item label{width:100px;color:#64748b;font-weight:500}.detail-item span{flex:1;color:#1e293b}.action-buttons{margin-top:24px;padding-top:20px;border-top:1px solid #f1f5f9;display:flex;gap:12px}.action-buttons .ant-btn{border-radius:10px;font-weight:500;padding:10px 20px;height:auto}.admin-leads .ant-table{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-leads .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:16px 18px}.admin-leads .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:16px 18px;color:#475569;font-size:14px;transition:background .2s ease}.admin-leads .ant-table-tbody>tr:hover>td{background:#f8fafc}.admin-leads .ant-tag{border-radius:6px;padding:4px 10px;font-weight:500;border:none;font-size:12px}.admin-leads .ant-modal-content{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.admin-leads .ant-modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:20px 24px}.admin-leads .ant-modal-title{font-weight:600;color:#0f172a;font-size:18px}.admin-leads .ant-modal-body{padding:24px}.admin-leads .ant-modal-footer{border-top:1px solid #f1f5f9;padding:16px 24px;background:#f8fafc}@media (max-width: 768px){.admin-leads{padding:0}.stats-cards{flex-direction:column;gap:12px}.stat-value{font-size:28px}}.admin-logs{padding:0;background:transparent;border-radius:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:28px}.stat-card{border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a;overflow:hidden;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.stat-label{font-size:13px;margin-bottom:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:32px;font-weight:700;letter-spacing:-1px}.stat-purple{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#bfdbfe}.stat-purple .stat-label{color:#3b82f6}.stat-purple .stat-value{color:#1d4ed8}.stat-green{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.stat-green .stat-label{color:#22c55e}.stat-green .stat-value{color:#15803d}.stat-red{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fecaca}.stat-red .stat-label{color:#ef4444}.stat-red .stat-value{color:#b91c1c}.tab-buttons{display:flex;gap:12px;margin-bottom:24px}.tab-buttons .ant-btn{border-radius:10px;font-weight:500;padding:10px 20px;height:auto;transition:all .25s ease}.tab-buttons .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d}.tab-buttons .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.admin-logs .ant-card{border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-logs .ant-table{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-logs .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:16px 18px}.admin-logs .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:16px 18px;color:#475569;font-size:14px;transition:background .2s ease}.admin-logs .ant-table-tbody>tr:hover>td{background:#f8fafc}.admin-logs .ant-tag{border-radius:6px;padding:4px 10px;font-weight:500;border:none;font-size:12px}.admin-logs .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.admin-logs .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}@media (max-width: 768px){.admin-logs{padding:0}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-value{font-size:28px}}.admin-products{padding:0;background:transparent;border-radius:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.page-header h2{margin:0;font-size:24px;font-weight:700;color:#0f172a;letter-spacing:-.5px}.page-desc{color:#64748b;font-size:14px;margin-top:8px}.admin-products .ant-table{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-products .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:16px 18px}.admin-products .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:16px 18px;color:#475569;font-size:14px;transition:background .2s ease}.admin-products .ant-table-tbody>tr:hover>td{background:#f8fafc}.admin-products .ant-table-tbody>tr:last-child>td{border-bottom:none}.admin-products .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.admin-products .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.admin-products .ant-btn-primary:disabled{transform:none;box-shadow:none}.admin-products .ant-btn-link{font-weight:500;padding:4px 8px;height:auto}.admin-products .ant-tag{border-radius:6px;padding:4px 10px;font-weight:500;border:none;font-size:12px}.admin-products .ant-switch{background:#e2e8f0}.admin-products .ant-switch-checked{background:linear-gradient(135deg,#22c55e,#16a34a)}.admin-products .ant-modal-content{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.admin-products .ant-modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:20px 24px}.admin-products .ant-modal-title{font-weight:600;color:#0f172a;font-size:18px}.admin-products .ant-modal-body{padding:24px}.admin-products .ant-modal-footer{border-top:1px solid #f1f5f9;padding:16px 24px;background:#f8fafc}.admin-products .ant-form-item-label>label{color:#374151;font-weight:500}.admin-products .ant-input,.admin-products .ant-input-number,.admin-products .ant-select-selector,.admin-products .ant-picker{border-radius:10px;border:2px solid #e5e7eb;transition:all .25s ease}.admin-products .ant-input:focus,.admin-products .ant-input-focused,.admin-products .ant-input-number:focus,.admin-products .ant-input-number-focused,.admin-products .ant-select-focused .ant-select-selector,.admin-products .ant-picker-focused{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.admin-products .ant-input:hover,.admin-products .ant-input-number:hover,.admin-products .ant-select-selector:hover,.admin-products .ant-picker:hover{border-color:#d1d5db}.admin-products .ant-btn{border-radius:10px;font-weight:500;transition:all .25s ease}.admin-products .ant-pagination{margin-top:24px}.admin-products .ant-pagination-item{border-radius:8px;border:1px solid #e2e8f0}.admin-products .ant-pagination-item-active{background:#3b82f6;border-color:#3b82f6}.admin-products .ant-pagination-item-active a{color:#fff}@media (max-width: 768px){.admin-products{padding:0}.page-header{flex-direction:column;gap:16px}.page-header .ant-btn-primary{width:100%}}.admin-statistics{padding:0}.page-header{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.page-header h2{margin:0 0 8px;font-size:24px;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:12px;letter-spacing:-.5px}.page-header h2 .anticon{color:#3b82f6}.page-desc{color:#64748b;margin:0;font-size:14px}.stat-card{margin-bottom:24px;border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a;overflow:hidden;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 12px #00000014}.stat-card .ant-card-head{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:16px 24px}.stat-card .ant-card-head-title{font-weight:600;color:#1e293b;font-size:16px;display:flex;align-items:center;gap:10px}.stat-card .ant-card-head-title .anticon{color:#3b82f6;font-size:18px}.stat-card .ant-card-body{padding:24px}.stat-card .ant-card.ant-card-bordered{border:1px solid #e2e8f0;border-radius:12px;transition:all .25s ease}.stat-card .ant-card.ant-card-bordered:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000f}.memory-detail,.stat-detail{font-size:12px;color:#94a3b8;margin-top:10px;display:flex;align-items:center;gap:6px}.stat-detail:before{content:"•";color:#3b82f6}.content-stat-card{transition:all .3s ease;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.content-stat-card:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-2px)}.content-stat-header{display:flex;align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid #f1f5f9}.content-stat-icon{font-size:26px;margin-right:14px;padding:10px;border-radius:10px;background:#3b82f61a}.content-stat-title{font-size:15px;font-weight:600;color:#334155}.content-stat-body{display:flex;justify-content:space-around;padding:8px 0}.content-stat-item{text-align:center;flex:1}.content-stat-item:first-child{border-right:1px solid #f1f5f9}.content-stat-label{display:block;font-size:12px;color:#94a3b8;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.content-stat-value{display:block;font-size:28px;font-weight:700;color:#0f172a;letter-spacing:-1px}.stat-card .ant-table{background:#fff;border-radius:12px;overflow:hidden}.stat-card .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:14px 16px}.stat-card .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:14px 16px;color:#475569;font-size:14px}.stat-card .ant-table-tbody>tr:hover>td{background:#f8fafc}.stat-card .ant-tag{font-size:13px;padding:4px 10px;border-radius:6px;font-weight:500;border:none}.stat-card .ant-progress-bg{border-radius:4px}.stat-card .ant-statistic-title{color:#64748b;font-size:13px;font-weight:500;margin-bottom:8px}.stat-card .ant-statistic-content{color:#0f172a;font-weight:700}.stat-card .ant-statistic-content-prefix{color:#64748b;margin-right:8px}.stat-card .ant-progress-text{color:#64748b;font-weight:500}.stat-card .ant-spin-nested-loading{min-height:auto}.stat-card .ant-spin-container{transition:opacity .3s ease}.stat-card .ant-spin-blur{opacity:.5}.admin-statistics .ant-row{row-gap:20px}.visitor-detail-modal{width:85%!important;max-width:1400px}.visitor-detail-modal .ant-modal-content{max-height:80vh}.visitor-detail-modal .ant-modal-body{max-height:calc(80vh - 110px);overflow:auto}.overseas-visitor-card .ant-card-body{height:843px!important;overflow:auto}.admin-statistics .ant-col{transition:all .3s ease}.admin-statistics .ant-col:hover .ant-card{box-shadow:0 4px 12px #00000014}@media (max-width: 992px){.page-header h2{font-size:20px}.content-stat-value{font-size:24px}}@media (max-width: 768px){.stat-card .ant-card-body{padding:16px}.content-stat-body{flex-direction:column;gap:16px}.content-stat-item:first-child{border-right:none;border-bottom:1px solid #f1f5f9;padding-bottom:16px}}.admin-roles{padding:0;background:transparent;border-radius:0}.admin-roles .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.admin-roles .page-header h2{margin:0;font-size:24px;font-weight:700;color:#0f172a;letter-spacing:-.5px}.admin-roles .page-desc{color:#64748b;font-size:14px;margin-top:8px}.admin-roles .ant-table{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-roles .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:16px 18px}.admin-roles .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:16px 18px;color:#475569;font-size:14px;transition:background .2s ease}.admin-roles .ant-table-tbody>tr:hover>td{background:#f8fafc}.admin-roles .status-tag{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:500;border:none}.admin-roles .status-tag.active{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.admin-roles .status-tag.disabled{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#b91c1c}.admin-roles .permission-header{margin-bottom:20px;padding:16px 20px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:12px;border:1px solid #bfdbfe;color:#1e40af;font-weight:500}.admin-roles .permission-card{height:100%;border-radius:12px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a;transition:all .3s ease}.admin-roles .permission-card:hover{box-shadow:0 4px 12px #00000014}.admin-roles .permission-card .ant-card-head{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:12px 16px;min-height:auto}.admin-roles .permission-card .ant-card-head-title{font-weight:600;color:#1e293b;font-size:14px}.admin-roles .permission-card .ant-card-body{padding:16px}.admin-roles .permission-card-header{padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid #f1f5f9}.admin-roles .permission-card-body .ant-checkbox-wrapper{margin-bottom:8px;color:#475569}.admin-roles .permission-item{margin-bottom:8px}.admin-roles .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.admin-roles .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.admin-roles .ant-modal-content{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.admin-roles .ant-modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:20px 24px}.admin-roles .ant-modal-title{font-weight:600;color:#0f172a;font-size:18px}.admin-roles .ant-modal-body{padding:24px}.admin-roles .ant-modal-footer{border-top:1px solid #f1f5f9;padding:16px 24px;background:#f8fafc}.admin-roles .ant-form-item-label>label{color:#374151;font-weight:500}.admin-roles .ant-input,.admin-roles .ant-select-selector{border-radius:10px;border:2px solid #e5e7eb;transition:all .25s ease}.admin-roles .ant-input:focus,.admin-roles .ant-select-focused .ant-select-selector{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@media (max-width: 768px){.admin-roles{padding:0}.admin-roles .permission-card{margin-bottom:12px}}.admin-admins{padding:0;background:transparent;border-radius:0}.admin-admins .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.admin-admins .page-header h2{margin:0;font-size:24px;font-weight:700;color:#0f172a;letter-spacing:-.5px}.admin-admins .page-desc{color:#64748b;font-size:14px;margin-top:8px}.admin-admins .ant-table{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a}.admin-admins .ant-table-thead>tr>th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:16px 18px}.admin-admins .ant-table-tbody>tr>td{border-bottom:1px solid #f1f5f9;padding:16px 18px;color:#475569;font-size:14px;transition:background .2s ease}.admin-admins .ant-table-tbody>tr:hover>td{background:#f8fafc}.admin-admins .status-tag{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:500;border:none}.admin-admins .status-tag.active{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.admin-admins .status-tag.disabled{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#b91c1c}.admin-admins .ant-space{gap:8px!important}.admin-admins .ant-space-item .ant-btn-link{padding:4px 8px;font-weight:500}.admin-admins .ant-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 4px 14px #3b82f64d;font-weight:500;padding:10px 20px;height:auto;border-radius:10px;transition:all .25s ease}.admin-admins .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.admin-admins .ant-modal-content{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.admin-admins .ant-modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;padding:20px 24px}.admin-admins .ant-modal-title{font-weight:600;color:#0f172a;font-size:18px}.admin-admins .ant-modal-body{padding:24px}.admin-admins .ant-modal-footer{border-top:1px solid #f1f5f9;padding:16px 24px;background:#f8fafc}.admin-admins .ant-form-item-label>label{color:#374151;font-weight:500}.admin-admins .ant-input,.admin-admins .ant-select-selector{border-radius:10px;border:2px solid #e5e7eb;transition:all .25s ease}.admin-admins .ant-input:focus,.admin-admins .ant-select-focused .ant-select-selector{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.admin-admins .ant-pagination{margin-top:24px}.admin-admins .ant-pagination-item{border-radius:8px;border:1px solid #e2e8f0}.admin-admins .ant-pagination-item-active{background:#3b82f6;border-color:#3b82f6}.admin-admins .ant-pagination-item-active a{color:#fff}@media (max-width: 768px){.admin-admins{padding:0}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;line-height:1.6;background:#fff}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}img{max-width:100%;display:block}:root{--color-primary: #E53935;--color-primary-light: #FF6659;--color-secondary: #FFB300;--color-secondary-light: #FFD54F;--color-bg: #FFFFFF;--color-bg-gray: #F9F9F9;--color-bg-warm: #FFF8E1;--color-text: #333333;--color-text-light: #666666;--color-text-muted: #999999;--color-border: #E0E0E0;--color-black: #1A1A1A;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px}.container{max-width:1200px;margin:0 auto;padding:0 24px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 32px;font-size:16px;font-weight:500;border-radius:var(--radius-md);transition:all .3s ease}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:#fff}.section-title{font-size:32px;font-weight:600;color:var(--color-text);text-align:center;margin-bottom:48px;position:relative}.section-title:after{content:"";display:block;width:60px;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));margin:16px auto 0;border-radius:2px}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s ease}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .6s ease forwards}@media (max-width: 768px){.container{padding:0 16px}.section-title{font-size:24px;margin-bottom:32px}}
