.password-strength{margin-top:8px}.password-strength-bar{width:100%;height:4px;background:#e8e8e8;border-radius:2px;overflow:hidden;margin-bottom:8px}.password-strength-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:2px}.password-strength-info{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-bottom:4px}.password-strength-label{font-weight:600}.password-strength-warning{color:#e67e22;font-size:11px}.password-strength-suggestions{list-style:none;padding:0;margin:8px 0 0;font-size:11px;color:#666}.password-strength-suggestions li{padding:4px 0 4px 16px;position:relative}.password-strength-suggestions li:before{content:"•";position:absolute;left:4px;color:#999}.profile-page{min-height:100vh;background:#f5f5f5;padding:40px 20px}.profile-container{max-width:900px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;overflow:hidden}.profile-header{padding:30px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;align-items:center}.profile-header h1{margin:0;font-size:28px}.btn-back{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px}.btn-back:hover{background:#ffffff4d}.profile-tabs{display:flex;border-bottom:1px solid #e8e8e8;background:#fafafa}.tab{flex:1;padding:16px 24px;border:none;background:transparent;cursor:pointer;font-size:15px;font-weight:500;color:#666;transition:all .2s;position:relative}.tab:hover{color:#667eea;background:#667eea0d}.tab.active{color:#667eea;background:#fff}.tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#667eea,#764ba2)}.profile-content{padding:40px}.tab-content h2{margin:0 0 24px;font-size:22px;color:#333}.tab-content h3{margin:32px 0 16px;font-size:18px;color:#333}.avatar-section{display:flex;gap:32px;align-items:flex-start;margin-bottom:32px;padding:24px;background:#f9f9f9;border-radius:12px}.avatar-preview{width:120px;height:120px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:48px;color:#fff;font-weight:700}.avatar-actions{flex:1;display:flex;flex-direction:column;gap:12px}.avatar-upload{cursor:pointer}.btn-upload{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.btn-upload:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.upload-hint{margin:8px 0 0;font-size:12px;color:#999}.btn-delete-avatar{background:transparent;color:#e74c3c;border:1px solid #e74c3c;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s;align-self:flex-start}.btn-delete-avatar:hover{background:#e74c3c;color:#fff}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;transition:all .3s;font-family:inherit}.form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.form-group textarea{resize:vertical;min-height:100px}.verified-badge,.unverified-badge{display:inline-block;margin-left:8px;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.verified-badge{background:#d4edda;color:#155724}.unverified-badge{background:#fff3cd;color:#856404}.profile-info{background:#f9f9f9;padding:20px;border-radius:8px;margin:24px 0}.profile-info p{margin:8px 0;font-size:14px;color:#666}.profile-info strong{color:#333;margin-right:8px}.security-section{margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid #e8e8e8}.security-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.login-history{display:flex;flex-direction:column;gap:12px}.history-item{display:flex;align-items:center;gap:16px;padding:16px;background:#f9f9f9;border-radius:8px;border-left:4px solid #2ecc71}.history-item.failed{border-left-color:#e74c3c}.history-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;flex-shrink:0}.history-item.success .history-icon{background:#d4edda;color:#155724}.history-item.failed .history-icon{background:#f8d7da;color:#721c24}.history-info{flex:1}.history-status{margin:0 0 4px;font-weight:600;font-size:14px;color:#333}.history-details{margin:0;font-size:12px;color:#999}.sessions-actions{margin-bottom:24px}.btn-danger{background:#e74c3c;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.btn-danger:hover{background:#c0392b;transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c66}.sessions-list{display:flex;flex-direction:column;gap:16px}.session-card{display:flex;align-items:center;gap:20px;padding:20px;background:#f9f9f9;border-radius:12px;border:2px solid transparent;transition:all .2s}.session-card.current{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea}.session-icon{font-size:36px;flex-shrink:0}.session-info{flex:1}.session-info h4{margin:0 0 8px;font-size:16px;color:#333;display:flex;align-items:center;gap:12px}.current-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600}.session-info p{margin:4px 0;font-size:14px;color:#666}.session-time{font-size:12px!important;color:#999!important}.btn-delete-session{background:transparent;color:#e74c3c;border:1px solid #e74c3c;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s}.btn-delete-session:hover{background:#e74c3c;color:#fff}.empty-state,.loading{text-align:center;padding:40px;color:#999;font-size:14px}@media (max-width: 768px){.profile-page{padding:20px 10px}.profile-container{border-radius:0}.profile-header{padding:20px;flex-direction:column;gap:16px;text-align:center}.profile-content{padding:20px}.avatar-section{flex-direction:column;align-items:center;text-align:center}.avatar-actions,.btn-upload,.btn-delete-avatar{width:100%}.session-card{flex-direction:column;text-align:center}.btn-delete-session{width:100%}}.top-toolbar{height:60px;background:#fff;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;justify-content:space-between;padding:0 20px;box-shadow:0 2px 12px #0000000a;z-index:100}.toolbar-left{display:flex;align-items:center;min-width:160px}.logo{display:flex;align-items:center;gap:10px;cursor:pointer;transition:opacity .2s}.logo:hover{opacity:.8}.logo-icon-wrapper{display:flex;align-items:center;justify-content:center}.logo-text{font-size:18px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.toolbar-center{display:flex;gap:6px;align-items:center}.toolbar-group{display:flex;gap:4px;align-items:center;background:#f8f9fa;padding:4px;border-radius:10px}.toolbar-divider{width:1px;height:24px;background:#e8e8e8;margin:0 8px}.toolbar-btn{padding:8px 14px;border:none;background:transparent;color:#555;cursor:pointer;border-radius:8px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .2s;white-space:nowrap}.toolbar-btn:hover:not(:disabled){background:#fff;color:#333;box-shadow:0 2px 8px #00000014}.toolbar-btn.active{background:#667eea;color:#fff}.toolbar-btn.active:hover{background:#5a6fd6;color:#fff}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn.icon-only{padding:8px}.toolbar-btn.icon-only svg{width:18px;height:18px}.toolbar-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.toolbar-btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66;color:#fff}.toolbar-btn.primary.loading{opacity:.8;pointer-events:none}.help-btn{background:transparent!important;box-shadow:none!important}.help-btn:hover:not(:disabled){background:#f0f2ff!important;color:#667eea}.feedback-btn{background:linear-gradient(135deg,#ffecd2,#fcb69f)!important;color:#c0392b!important;font-weight:600}.feedback-btn:hover:not(:disabled){background:linear-gradient(135deg,#fcb69f,#ffecd2)!important;transform:translateY(-1px);box-shadow:0 4px 12px #fcb69f66!important}.feedback-btn svg{stroke:currentColor}.arrow{transition:transform .2s;opacity:.6}.arrow.open{transform:rotate(180deg)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;border:1px solid #e8e8e8;border-radius:12px;box-shadow:0 8px 32px #0000001f;min-width:220px;padding:8px;z-index:1000;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.dropdown-menu button{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .15s;text-align:left}.dropdown-menu button:hover{background:#f5f7ff}.format-icon{font-size:20px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:8px}.format-info{display:flex;flex-direction:column;gap:2px}.format-name{font-size:13px;font-weight:600;color:#333}.format-desc{font-size:11px;color:#999}.toolbar-right{display:flex;align-items:center;min-width:160px;justify-content:flex-end}.user-menu{position:relative}.user-avatar-btn{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 4px;border:none;background:#f8f9fa;border-radius:24px;cursor:pointer;transition:all .2s}.user-avatar-btn:hover,.user-avatar-btn.active{background:#f0f2ff}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.user-avatar.large{width:48px;height:48px;font-size:18px}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #e8e8e8;border-radius:12px;box-shadow:0 8px 32px #0000001f;min-width:240px;padding:8px;z-index:1000;animation:dropdownFadeIn .2s ease}.user-info{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f9fa;border-radius:10px;margin-bottom:4px}.user-details{display:flex;flex-direction:column;gap:2px;min-width:0}.user-name{font-size:14px;font-weight:600;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{font-size:12px;color:#999;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-divider{height:1px;background:#eee;margin:6px 0}.user-dropdown button{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .15s;font-size:13px;color:#555;text-align:left}.user-dropdown button:hover{background:#f5f7ff;color:#333}.user-dropdown button svg{opacity:.7}.logout-btn{color:#e74c3c!important}.logout-btn:hover{background:#fef5f5!important;color:#c0392b!important}.logout-btn svg{stroke:currentColor}@media (max-width: 900px){.toolbar-btn span{display:none}.toolbar-btn{padding:8px}.toolbar-btn.primary span{display:inline}.toolbar-divider{margin:0 4px}.toolbar-group{padding:2px}}@media (max-width: 600px){.top-toolbar{padding:0 12px}.logo-text{display:none}.toolbar-left,.toolbar-right{min-width:auto}}/*!
 * Cropper.js v1.6.2
 * https://fengyuanchen.github.io/cropperjs
 *
 * Copyright 2015-present Chen Fengyuan
 * Released under the MIT license
 *
 * Date: 2024-04-21T07:43:02.731Z
 */.cropper-container{direction:ltr;font-size:0;line-height:0;position:relative;-ms-touch-action:none;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.cropper-container img{backface-visibility:hidden;display:block;height:100%;image-orientation:0deg;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;width:100%}.cropper-wrap-box,.cropper-canvas,.cropper-drag-box,.cropper-crop-box,.cropper-modal{bottom:0;left:0;position:absolute;right:0;top:0}.cropper-wrap-box,.cropper-canvas{overflow:hidden}.cropper-drag-box{background-color:#fff;opacity:0}.cropper-modal{background-color:#000;opacity:.5}.cropper-view-box{display:block;height:100%;outline:1px solid #39f;outline-color:#3399ffbf;overflow:hidden;width:100%}.cropper-dashed{border:0 dashed #eee;display:block;opacity:.5;position:absolute}.cropper-dashed.dashed-h{border-bottom-width:1px;border-top-width:1px;height:calc(100% / 3);left:0;top:calc(100% / 3);width:100%}.cropper-dashed.dashed-v{border-left-width:1px;border-right-width:1px;height:100%;left:calc(100% / 3);top:0;width:calc(100% / 3)}.cropper-center{display:block;height:0;left:50%;opacity:.75;position:absolute;top:50%;width:0}.cropper-center:before,.cropper-center:after{background-color:#eee;content:" ";display:block;position:absolute}.cropper-center:before{height:1px;left:-3px;top:0;width:7px}.cropper-center:after{height:7px;left:0;top:-3px;width:1px}.cropper-face,.cropper-line,.cropper-point{display:block;height:100%;opacity:.1;position:absolute;width:100%}.cropper-face{background-color:#fff;left:0;top:0}.cropper-line{background-color:#39f}.cropper-line.line-e{cursor:ew-resize;right:-3px;top:0;width:5px}.cropper-line.line-n{cursor:ns-resize;height:5px;left:0;top:-3px}.cropper-line.line-w{cursor:ew-resize;left:-3px;top:0;width:5px}.cropper-line.line-s{bottom:-3px;cursor:ns-resize;height:5px;left:0}.cropper-point{background-color:#39f;height:5px;opacity:.75;width:5px}.cropper-point.point-e{cursor:ew-resize;margin-top:-3px;right:-3px;top:50%}.cropper-point.point-n{cursor:ns-resize;left:50%;margin-left:-3px;top:-3px}.cropper-point.point-w{cursor:ew-resize;left:-3px;margin-top:-3px;top:50%}.cropper-point.point-s{bottom:-3px;cursor:s-resize;left:50%;margin-left:-3px}.cropper-point.point-ne{cursor:nesw-resize;right:-3px;top:-3px}.cropper-point.point-nw{cursor:nwse-resize;left:-3px;top:-3px}.cropper-point.point-sw{bottom:-3px;cursor:nesw-resize;left:-3px}.cropper-point.point-se{bottom:-3px;cursor:nwse-resize;height:20px;opacity:1;right:-3px;width:20px}@media (min-width: 768px){.cropper-point.point-se{height:15px;width:15px}}@media (min-width: 992px){.cropper-point.point-se{height:10px;width:10px}}@media (min-width: 1200px){.cropper-point.point-se{height:5px;opacity:.75;width:5px}}.cropper-point.point-se:before{background-color:#39f;bottom:-50%;content:" ";display:block;height:200%;opacity:0;position:absolute;right:-50%;width:200%}.cropper-invisible{opacity:0}.cropper-bg{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAAA3NCSVQICAjb4U/gAAAABlBMVEXMzMz////TjRV2AAAACXBIWXMAAArrAAAK6wGCiw1aAAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAABFJREFUCJlj+M/AgBVhF/0PAH6/D/HkDxOGAAAAAElFTkSuQmCC)}.cropper-hide{display:block;height:0;position:absolute;width:0}.cropper-hidden{display:none!important}.cropper-move{cursor:move}.cropper-crop{cursor:crosshair}.cropper-disabled .cropper-drag-box,.cropper-disabled .cropper-face,.cropper-disabled .cropper-line,.cropper-disabled .cropper-point{cursor:not-allowed}.image-cropper-container{width:100%;height:100%;display:flex;flex-direction:column}.image-cropper-wrapper{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.image-cropper-wrapper img{max-width:100%;max-height:100%}.image-cropper-actions{padding:16px;display:flex;gap:12px;justify-content:flex-end;border-top:1px solid #e8e8e8}.image-cropper-actions button{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.btn-cancel{background:#f5f5f5;color:#666}.btn-cancel:hover{background:#e8e8e8}.btn-confirm{background:#667eea;color:#fff}.btn-confirm:hover{background:#5568d3}.image-upload{padding:0;width:100%}.upload-title{display:flex;align-items:center;gap:12px;margin:0 0 24px;padding-bottom:20px;border-bottom:2px solid #f0f0f0;font-size:20px;font-weight:700;color:#333}.upload-title svg{color:#667eea}.upload-area{border:2px dashed #e0e0e0;border-radius:16px;padding:48px 32px;text-align:center;cursor:pointer;transition:all .3s;background:linear-gradient(135deg,#fafafa,#f5f5f5)}.upload-area:hover{border-color:#667eea;background:linear-gradient(135deg,#f8f9ff,#f0f4ff)}.upload-area.dragging{border-color:#667eea;background:linear-gradient(135deg,#f0f4ff,#e8edff);border-style:solid;transform:scale(1.01)}.upload-icon{margin-bottom:16px;color:#aaa;transition:all .3s}.upload-area:hover .upload-icon{color:#667eea;transform:translateY(-4px)}.upload-area.dragging .upload-icon{color:#667eea;transform:translateY(-8px) scale(1.1)}.upload-text{margin:0 0 8px;font-size:16px;font-weight:600;color:#444}.upload-hint{margin:0 0 16px;font-size:13px;color:#999}.upload-formats{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.upload-formats span{font-size:11px;color:#bbb;padding:4px 10px;background:#0000000a;border-radius:12px}.upload-tips{display:flex;flex-direction:column;gap:10px;margin-top:20px;padding:16px;background:#f8f9fa;border-radius:12px}.tip-item{display:flex;align-items:center;gap:10px;font-size:13px;color:#666}.tip-item svg{color:#667eea;flex-shrink:0}.qrcode-generator{padding:0;width:100%}.qrcode-title{display:flex;align-items:center;gap:12px;margin:0 0 24px;padding-bottom:20px;border-bottom:2px solid #f0f0f0;font-size:20px;font-weight:700;color:#333}.qrcode-title svg{color:#667eea;width:24px;height:24px}.qrcode-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media (max-width: 500px){.qrcode-layout{grid-template-columns:1fr}}.qrcode-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#555}.label-icon{font-size:14px}.form-group textarea{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;resize:vertical;transition:all .2s;font-family:inherit}.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea::placeholder{color:#aaa}.logo-upload-area{display:flex;justify-content:center}.logo-upload-placeholder{width:100%;padding:24px;border:2px dashed #e0e0e0;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .2s;background:#fafafa}.logo-upload-placeholder:hover{border-color:#667eea;background:#f5f7ff}.logo-upload-placeholder svg{color:#aaa}.logo-upload-placeholder span{font-size:13px;color:#666}.upload-hint{font-size:11px!important;color:#999!important}.logo-preview-wrapper{position:relative;display:inline-block}.logo-preview{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid #e0e0e0}.remove-logo-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;border:none;background:#ff4d4f;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 8px #ff4d4f66}.remove-logo-btn:hover{background:#ff7875;transform:scale(1.1)}.advanced-toggle{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:none;background:transparent;color:#667eea;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.advanced-toggle:hover{color:#5a6fd6}.advanced-settings{display:flex;flex-direction:column;gap:16px;padding:16px;background:#f8f9fa;border-radius:10px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-group input[type=range]{width:100%;height:6px;border-radius:3px;background:#e0e0e0;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;box-shadow:0 2px 6px #667eea66;transition:all .2s}.form-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.input-hint{font-size:11px;color:#999;margin-top:4px}.color-settings{display:grid;grid-template-columns:1fr 1fr;gap:12px}.color-group{gap:6px!important}.color-input-wrapper{display:flex;align-items:center;gap:8px}.color-input-wrapper input[type=color]{width:32px;height:32px;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;padding:0;background:transparent}.color-input-wrapper input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.color-input-wrapper input[type=color]::-webkit-color-swatch{border-radius:4px;border:none}.color-value{font-size:12px;font-family:monospace;color:#666;text-transform:uppercase}.generate-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:10px;cursor:pointer;font-size:15px;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.qrcode-preview-section{display:flex;flex-direction:column;gap:12px}.preview-label{font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:1px}.qrcode-preview{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px;background:linear-gradient(135deg,#f8f9fa,#f0f2f5);border-radius:16px;border:2px solid #e8e8e8;flex:1}.preview-image-wrapper{display:inline-block;padding:16px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a}.qrcode-preview img{width:180px;height:180px;display:block}.qrcode-preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 24px;background:linear-gradient(135deg,#f8f9fa,#f0f2f5);border-radius:16px;border:2px dashed #e0e0e0;flex:1;min-height:280px;color:#bbb;text-align:center}.qrcode-preview-placeholder svg{opacity:.4}.qrcode-preview-placeholder span{font-size:13px;color:#999}.preview-actions{display:flex;gap:10px;justify-content:center;width:100%}.use-btn,.download-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.use-btn{background:#667eea;color:#fff}.use-btn:hover{background:#5a6fd6;transform:translateY(-1px)}.download-btn{background:#fff;color:#666;border:1px solid #e0e0e0}.download-btn:hover{background:#f5f5f5;border-color:#ccc}.layer-panel{display:flex;flex-direction:column;height:100%;background:#f8f9fa;border-radius:8px;overflow:hidden}.layer-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#fff;border-bottom:1px solid #e0e0e0}.layer-panel-header h4{margin:0;font-size:14px;font-weight:600;color:#333}.add-layer-btn{width:28px;height:28px;border:none;border-radius:6px;background:#667eea;color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.add-layer-btn:hover{background:#5a6fd6;transform:scale(1.05)}.layer-list{flex:1;overflow-y:auto;padding:8px}.layer-item{display:flex;align-items:center;gap:4px;padding:8px;background:#fff;border:2px solid transparent;border-radius:8px;margin-bottom:6px;cursor:pointer;transition:all .2s;min-height:42px}.layer-item:hover{background:#f0f2ff;border-color:#e0e4ff}.layer-item.active{background:#e8ebff;border-color:#667eea}.layer-item.dragging{opacity:.5;background:#ddd}.layer-drag-handle{cursor:grab;color:#bbb;font-size:12px;padding:0 2px;-webkit-user-select:none;user-select:none;flex-shrink:0;display:flex;align-items:center;justify-content:center}.layer-drag-handle:active{cursor:grabbing}.layer-drag-handle svg{display:block}.layer-btn{width:24px;height:24px;border:none;border-radius:4px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s;flex-shrink:0;color:#666}.layer-btn:hover{background:#e0e4ff}.layer-btn.active{background:#667eea;color:#fff}.delete-btn.active{background:transparent!important;color:#aaa!important}.layer-btn svg{display:block}.visibility-btn:not(.active){opacity:.5}.lock-btn.active{background:#ff6b6b;color:#fff}.delete-btn{width:20px!important;height:20px!important;opacity:0;transition:all .15s ease;color:#aaa!important;background:transparent!important;font-size:16px;font-weight:400;line-height:20px;text-align:center;border-radius:50%!important;padding:0!important;margin-left:2px}.layer-item:hover .delete-btn{opacity:1}.delete-btn:hover{color:#fff!important;background:#e53935!important;transform:scale(1.1)}.delete-btn:active{transform:scale(.95);background:#c62828!important}.layer-info{flex:1;display:flex;align-items:center;gap:4px;min-width:50px;overflow:hidden}.layer-name{flex:1;font-size:13px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:text;min-width:30px}.layer-name-input{flex:1;min-width:50px;padding:2px 6px;border:1px solid #667eea;border-radius:4px;font-size:13px;outline:none}.layer-element-count{font-size:10px;color:#999;flex-shrink:0}.layer-opacity-slider{width:40px;height:4px;cursor:pointer;accent-color:#667eea;flex-shrink:0}.layer-empty{text-align:center;padding:20px;color:#999;font-size:13px}.layer-list::-webkit-scrollbar{width:6px}.layer-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.layer-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.layer-list::-webkit-scrollbar-thumb:hover{background:#bbb}.template-card{background:#fff;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .25s ease;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0}.template-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #667eea26;border-color:#667eea}.template-card-preview{position:relative;overflow:hidden;min-height:120px}.template-thumbnail{width:100%;height:100%;object-fit:cover;display:block}.template-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:8px;min-height:150px}.template-placeholder-name{color:#fff;font-size:14px;font-weight:600;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.2);line-height:1.4}.template-placeholder-size{color:#fffc;font-size:11px;background:#0003;padding:2px 8px;border-radius:10px}.template-badges{position:absolute;top:8px;left:8px;right:8px;display:flex;gap:6px;flex-wrap:wrap}.badge{padding:3px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.template-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;opacity:0;transition:opacity .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.template-card:hover .template-card-overlay{opacity:1}.btn-use{padding:10px 24px;background:#667eea;color:#fff;border:none;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-use:hover{background:#5a6fd6;transform:scale(1.05)}.btn-preview{padding:6px 16px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.6);border-radius:15px;font-size:12px;cursor:pointer;transition:all .2s}.btn-preview:hover{background:#ffffff26;border-color:#fff}.template-card-info{padding:12px}.template-card-name{font-size:13px;font-weight:600;color:#333;margin:0 0 6px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-card-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:#999}.template-size{background:#f5f5f5;padding:2px 6px;border-radius:4px}.template-usage{display:flex;align-items:center;gap:2px}.template-card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.template-tag{font-size:10px;color:#667eea;background:#f0f2ff;padding:2px 6px;border-radius:4px}@media (max-width: 400px){.template-placeholder-name{font-size:12px}.template-card-info{padding:10px}.template-card-name{font-size:12px}}.template-preview-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px}.template-preview-modal{background:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0000004d;position:relative;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close-btn{position:absolute;top:16px;right:16px;width:36px;height:36px;border:none;background:#0000001a;border-radius:50%;font-size:24px;color:#666;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close-btn:hover{background:#0003;color:#333}.modal-content-grid{display:grid;grid-template-columns:1fr 1fr;max-height:90vh}.preview-image-section{background:#f8f9fa;padding:24px;display:flex;align-items:center;justify-content:center;max-height:90vh;overflow:auto}.preview-image-container{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #00000026;max-width:100%;max-height:70vh}.preview-image{display:block;max-width:100%;max-height:70vh;object-fit:contain}.preview-placeholder{min-width:280px;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:16px}.preview-placeholder-text{color:#fff;font-size:24px;font-weight:700;text-align:center;text-shadow:0 2px 8px rgba(0,0,0,.2)}.preview-placeholder-size{color:#fffc;font-size:14px;background:#0003;padding:6px 16px;border-radius:20px}.preview-badges{position:absolute;top:12px;left:12px;display:flex;gap:8px}.badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600}.badge-hot{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}.badge-pro{background:linear-gradient(135deg,#f9ca24,#f0932b);color:#1a1a1a}.preview-info-section{padding:32px;overflow-y:auto;max-height:90vh}.preview-title{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 12px;padding-right:40px}.preview-description{color:#666;font-size:14px;line-height:1.6;margin:0 0 24px}.preview-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:12px}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-label{font-size:11px;color:#999;text-transform:uppercase;letter-spacing:.5px}.meta-value{font-size:14px;color:#333;font-weight:500}.preview-elements{margin-bottom:20px}.preview-elements h4{font-size:12px;color:#999;margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.element-list{display:flex;flex-wrap:wrap;gap:8px}.element-item{font-size:13px;color:#555;background:#f0f2ff;padding:6px 12px;border-radius:20px}.preview-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.tag-item{font-size:12px;color:#667eea;background:#f0f2ff;padding:4px 10px;border-radius:12px}.preview-colors{margin-bottom:24px}.preview-colors h4{font-size:12px;color:#999;margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.color-palette{display:flex;gap:8px}.color-swatch{width:36px;height:36px;border-radius:8px;box-shadow:0 2px 8px #00000026;cursor:pointer;transition:transform .2s}.color-swatch:hover{transform:scale(1.1)}.preview-actions{display:flex;gap:12px;margin-top:auto;padding-top:24px;border-top:1px solid #eee}.btn-use-template{flex:1;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-use-template:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.btn-cancel{padding:14px 24px;background:#f5f5f5;color:#666;border:none;border-radius:12px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#eee}@media (max-width: 700px){.modal-content-grid{grid-template-columns:1fr}.preview-image-section{padding:16px;max-height:40vh}.preview-placeholder{min-height:200px}.preview-info-section{padding:20px;max-height:50vh}.preview-title{font-size:20px}.preview-actions{flex-direction:column}}.left-panel{width:300px;background:#fff;border-right:1px solid #e8e8e8;display:flex;flex-direction:column;overflow:hidden}.panel-tabs{display:flex;border-bottom:1px solid #e8e8e8;flex-shrink:0}.tab-btn{flex:1;padding:12px;border:none;background:transparent;cursor:pointer;font-size:14px;color:#666;transition:all .2s}.tab-btn.active{color:#667eea;border-bottom:2px solid #667eea;font-weight:600}.tab-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;min-height:0}.templates-tab{padding:12px;gap:12px}.search-box{display:flex;gap:8px;margin-bottom:0}.search-box input{flex:1;padding:10px 14px;border:1px solid #e8e8e8;border-radius:8px;font-size:14px;transition:all .2s}.search-box input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-toggle-btn{position:relative;width:40px;height:40px;border:1px solid #e8e8e8;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s}.filter-toggle-btn:hover,.filter-toggle-btn.active{border-color:#667eea;color:#667eea;background:#f8f9ff}.filter-badge{position:absolute;top:6px;right:6px;width:8px;height:8px;background:#ff6b6b;border-radius:50%}.category-chips{display:flex;flex-wrap:wrap;gap:6px}.category-chip{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid #e8e8e8;border-radius:16px;background:#fff;font-size:12px;color:#666;cursor:pointer;transition:all .2s}.category-chip:hover{border-color:#667eea;background:#f8f9ff}.category-chip.active{border-color:#667eea;background:#667eea;color:#fff}.chip-icon{font-size:14px}.chip-name{font-weight:500}.chip-count{font-size:10px;background:#0000001a;padding:1px 5px;border-radius:8px}.category-chip.active .chip-count{background:#ffffff4d}.advanced-filters{background:#f8f9fa;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:12px;animation:filterSlideDown .2s ease}@keyframes filterSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-section{display:flex;flex-direction:column;gap:6px}.filter-section label{font-size:11px;color:#999;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.filter-options{display:flex;flex-wrap:wrap;gap:6px}.filter-option{padding:5px 10px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;font-size:12px;color:#555;cursor:pointer;transition:all .15s}.filter-option:hover{border-color:#667eea;background:#f8f9ff}.filter-option.active{border-color:#667eea;background:#667eea;color:#fff}.clear-filters-btn{padding:8px 16px;border:none;border-radius:6px;background:#fff;color:#ff6b6b;font-size:12px;font-weight:500;cursor:pointer;align-self:flex-start;transition:all .2s}.clear-filters-btn:hover{background:#fff5f5}.template-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;flex:1;align-content:start}.loading-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:12px;color:#999}.loading-spinner{width:32px;height:32px;border:3px solid #f0f0f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{grid-column:1 / -1;text-align:center;color:#999;padding:40px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.empty-icon{font-size:48px;opacity:.5}.clear-btn{padding:8px 16px;border:1px solid #667eea;border-radius:6px;background:#fff;color:#667eea;font-size:12px;cursor:pointer;transition:all .2s}.clear-btn:hover{background:#667eea;color:#fff}.template-item{aspect-ratio:3/4;border:2px solid #e8e8e8;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s;background:#f5f5f5;position:relative}.template-item:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.template-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:12px;text-align:center;padding:8px}.pro-badge{position:absolute;top:8px;right:8px;background:gold;color:#333;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700}.elements-tab{padding:12px;gap:16px}.element-quick-actions{display:flex;gap:10px}.quick-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 16px;border:1px solid #e8e8e8;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s}.quick-action-btn:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.quick-action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.quick-action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.quick-icon{font-size:18px}.quick-label{font-size:13px;font-weight:600}.element-section{display:flex;flex-direction:column;gap:10px}.section-header{display:flex;align-items:center;justify-content:space-between}.section-title{font-size:12px;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.5px}.section-hint{font-size:10px;color:#aaa}.element-card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.element-card-grid.wide{grid-template-columns:1fr}.element-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;border:1px solid #f0f0f0;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s}.element-card:hover{border-color:#667eea;background:#fafbff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea1f}.element-card.wide{flex-direction:row;padding:12px 14px;gap:12px}.element-card-preview{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.element-card-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.element-card-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.element-card-name{font-size:11px;color:#555;font-weight:500;text-align:center}.element-card.wide .element-card-name{font-size:13px;text-align:left}.element-card-desc{font-size:11px;color:#999}.element-category{margin-bottom:24px;width:100%}.element-category h3{font-size:11px;color:#999;margin-bottom:12px;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.element-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.element-btn{width:100%;padding:12px 8px;border:1px solid #e8e8e8;border-radius:6px;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;transition:all .2s;font-size:12px;color:#666}.element-btn:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-1px);box-shadow:0 2px 8px #667eea26}.element-btn span{font-size:20px;line-height:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{background:#fff;border-radius:16px;padding:24px;max-width:480px;max-height:85vh;overflow:auto;box-shadow:0 20px 60px #0000004d;animation:modalFadeIn .25s ease}.modal-content.qrcode-modal{max-width:560px;width:90vw}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.modal-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.btn-cancel{display:none}.modal-close-btn{position:absolute;top:16px;right:16px;width:36px;height:36px;border:none;border-radius:50%;background:#f5f5f5;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1}.modal-close-btn:hover{background:#e8e8e8;color:#333}.modal-content{position:relative}.layers-tab{padding:0;overflow:hidden}.layers-tab .layer-panel{height:100%}.tab-content::-webkit-scrollbar{width:6px}.tab-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.tab-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.tab-content::-webkit-scrollbar-thumb:hover{background:#bbb}.canvas-area{flex:1;display:flex;flex-direction:column;background:#e8e8e8;overflow:hidden}.canvas-toolbar{height:44px;background:#fff;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;gap:8px;padding:0 12px;box-shadow:0 1px 4px #0000000a}.toolbar-section{display:flex;align-items:center;gap:4px;background:#f8f9fa;padding:4px;border-radius:8px}.toolbar-divider-v{width:1px;height:24px;background:#e0e0e0;margin:0 4px}.zoom-controls{gap:2px}.zoom-btn{width:28px;height:28px;padding:0;border:none;border-radius:6px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .15s}.zoom-btn:hover{background:#fff;color:#333;box-shadow:0 2px 6px #00000014}.zoom-btn.fit{margin-left:4px}.zoom-level{min-width:48px;text-align:center;font-size:12px;font-weight:500;color:#555;padding:0 4px}.view-options{gap:4px}.toggle-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:6px;background:transparent;cursor:pointer;transition:all .15s;font-size:12px;color:#888;font-weight:500}.toggle-btn input{display:none}.toggle-btn:hover{background:#fff;color:#555}.toggle-btn.active{background:#667eea;color:#fff;box-shadow:0 2px 8px #667eea40}.toggle-btn.active:hover{background:#5a6fd6}.toggle-btn svg{opacity:.8}.toggle-btn.active svg{opacity:1}.canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;position:relative}.canvas-drop-zone{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;pointer-events:none}.canvas-wrapper canvas{box-shadow:0 4px 24px #0000001f;background:#fff}.grid-toggle,.snap-toggle{font-size:12px;display:flex;align-items:center;gap:6px}.color-picker-container{position:relative}.color-picker-trigger{display:flex;gap:8px;align-items:center;cursor:pointer}.color-preview{width:40px;height:40px;border:1px solid #e8e8e8;border-radius:4px;cursor:pointer}.color-input{flex:1;padding:8px;border:1px solid #e8e8e8;border-radius:4px;font-size:14px}.color-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9998}.color-picker-popup{position:absolute;top:100%;left:0;margin-top:8px;padding:16px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:9999}.color-picker-actions{margin-top:12px;display:flex;justify-content:flex-end}.color-picker-actions button{padding:6px 16px;border:none;background:#667eea;color:#fff;border-radius:4px;cursor:pointer;font-size:14px}.color-picker-actions button:hover{background:#5568d3}.right-panel{width:320px;background:#fff;border-left:1px solid #e8e8e8;display:flex;flex-direction:column;overflow:hidden}.panel-header{height:48px;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;justify-content:space-between;padding:0 16px}.panel-header h3{font-size:16px;font-weight:600}.close-panel-btn{width:24px;height:24px;border:none;background:transparent;cursor:pointer;font-size:20px;color:#999}.panel-content{flex:1;overflow-y:auto;padding:16px}.no-selection{text-align:center;color:#999;padding:40px 20px}.property-group{margin-bottom:20px}.property-group h4{font-size:12px;color:#999;margin-bottom:8px;text-transform:uppercase}.property-item{margin-bottom:12px}.property-item label{display:block;font-size:12px;color:#666;margin-bottom:4px}.property-item input,.property-item select,.property-item textarea{width:100%;padding:8px;border:1px solid #e8e8e8;border-radius:4px;font-size:14px}.property-item input[type=range]{width:calc(100% - 60px);display:inline-block}.value-display{display:inline-block;width:50px;text-align:right;font-size:12px;color:#666}.color-picker-wrapper{display:flex;gap:8px;align-items:center}.property-row{display:flex;gap:8px}.position-size-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.delete-btn{width:100%;padding:10px;background:#ff4d4f;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background .2s}.delete-btn:hover{background:#ff7875}.delete-btn:active{background:#cf1322}.editor-container{height:100vh;display:flex;flex-direction:column;overflow:hidden}.main-container{flex:1;display:flex;overflow:hidden}.help-page{height:100vh;overflow-y:auto;overflow-x:hidden;background:#f8f9fa;display:flex;flex-direction:column}.help-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px 0;position:sticky;top:0;z-index:100;box-shadow:0 4px 20px #667eea4d}.help-header-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:24px}.back-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;font-size:14px;cursor:pointer;transition:all .2s}.back-btn:hover{background:#fff3;border-color:#ffffff80}.help-header h1{flex:1;margin:0;font-size:24px;font-weight:700;display:flex;align-items:center;gap:12px}.logo-icon{font-size:28px}.version-badge{padding:4px 12px;background:#fff3;border-radius:20px;font-size:12px;font-weight:500}.help-nav{background:#fff;border-bottom:1px solid #e8e8e8;position:sticky;top:76px;z-index:99}.nav-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;gap:8px;overflow-x:auto}.help-nav a{padding:16px 20px;color:#666;text-decoration:none;font-size:14px;font-weight:500;white-space:nowrap;border-bottom:2px solid transparent;transition:all .2s}.help-nav a:hover{color:#667eea;border-bottom-color:#667eea}.help-content{flex:1;padding:40px 24px}.content-wrapper{max-width:900px;margin:0 auto}.help-section{background:#fff;border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:0 2px 12px #0000000a}.help-section h2{font-size:24px;font-weight:700;color:#333;margin:0 0 24px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.help-section h3{font-size:18px;font-weight:600;color:#444;margin:28px 0 16px}.help-section h3:first-of-type{margin-top:0}.help-section p{color:#666;line-height:1.8;margin:0 0 12px}.intro-card{background:linear-gradient(135deg,#f5f7ff,#f0f4ff);border-left:4px solid #667eea;padding:20px 24px;border-radius:0 12px 12px 0;margin-bottom:24px}.intro-card p{margin:0;font-size:15px;color:#555}.steps{display:flex;flex-direction:column;gap:16px}.steps.horizontal{flex-direction:row;flex-wrap:wrap}.step{display:flex;align-items:flex-start;gap:16px}.steps.horizontal .step{flex:1;min-width:200px;flex-direction:column;align-items:center;text-align:center}.step-number{width:36px;height:36px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.step-content h4{margin:0 0 6px;font-size:15px;font-weight:600;color:#333}.step-content p,.steps.horizontal .step span{margin:0;font-size:14px;color:#666}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:24px}.feature-card{background:#f8f9fa;padding:20px;border-radius:12px;transition:all .2s}.feature-card:hover{background:#f0f4ff;transform:translateY(-2px)}.feature-icon{font-size:28px;margin-bottom:12px}.feature-card h4{margin:0 0 8px;font-size:15px;font-weight:600;color:#333}.feature-card p{margin:0;font-size:13px;color:#666}.interface-diagram{margin:24px 0}.diagram-box{border:2px solid #e0e0e0;border-radius:12px;overflow:hidden}.diagram-header{background:#667eea;color:#fff;padding:12px;text-align:center;font-weight:600;font-size:14px}.diagram-row{display:flex;min-height:200px}.diagram-sidebar{width:120px;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:13px;color:#666;border-right:1px solid #e0e0e0}.diagram-sidebar:last-child{border-right:none;border-left:1px solid #e0e0e0}.diagram-canvas{flex:1;background:#fafafa;display:flex;align-items:center;justify-content:center;font-size:14px;color:#888}.info-box{background:#f8f9fa;border-radius:10px;padding:16px 20px;margin:16px 0}.info-box p{margin:8px 0;font-size:14px}.info-box p:first-child{margin-top:0}.info-box p:last-child{margin-bottom:0}.info-box.tip{background:#f0f9ff;border-left:4px solid #3b82f6}.info-box.warning{background:#fff8f0;border-left:4px solid #f59e0b}.shape-grid{display:flex;flex-wrap:wrap;gap:12px;margin:16px 0}.shape-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 24px;background:#f8f9fa;border-radius:10px;min-width:80px}.shape-preview{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#667eea}.shape-preview.rect{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px}.shape-preview.circle{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:50%}.shape-preview.triangle{width:0;height:0;border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid #4facfe}.shape-preview.line{width:32px;height:3px;background:linear-gradient(90deg,#a8edea,#fed6e3);border-radius:2px}.shape-item span{font-size:12px;color:#666}.help-table{width:100%;border-collapse:collapse;margin:16px 0}.help-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;font-size:14px}.help-table td:first-child{width:180px;color:#333}.help-table td:last-child{color:#666}.help-table tr:last-child td{border-bottom:none}.toggle-demo{display:flex;flex-direction:column;gap:16px;margin:16px 0}.toggle-item{display:flex;align-items:flex-start;gap:16px;padding:16px;background:#f8f9fa;border-radius:10px}.toggle-icon{width:40px;height:40px;background:#e0e0e0;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#888;flex-shrink:0}.toggle-icon.active{background:#667eea;color:#fff}.toggle-info h4{margin:0 0 4px;font-size:14px;font-weight:600;color:#333}.toggle-info p{margin:0;font-size:13px;color:#666}.export-formats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:16px 0}.format-card{background:#f8f9fa;padding:20px;border-radius:12px;text-align:center}.format-icon{font-size:32px;margin-bottom:12px}.format-card h4{margin:0 0 8px;font-size:16px;font-weight:600;color:#333}.format-card p{margin:0 0 12px;font-size:13px;color:#666}.format-use{display:inline-block;padding:4px 12px;background:#e8f4ff;color:#3b82f6;border-radius:20px;font-size:11px;font-weight:500}kbd{display:inline-block;padding:4px 8px;background:#f0f0f0;border:1px solid #d0d0d0;border-radius:4px;font-family:monospace;font-size:12px;color:#333;box-shadow:0 1px 2px #0000001a}.shortcuts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.shortcut-group h4{margin:0 0 16px;font-size:14px;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px}.shortcut-item{display:flex;align-items:center;gap:12px;margin-bottom:12px;font-size:13px}.shortcut-item span{color:#666}.contact-section{text-align:center}.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}.contact-card{background:#f8f9fa;padding:24px;border-radius:12px;transition:all .2s}.contact-card:hover{background:#f0f4ff;transform:translateY(-2px)}.contact-icon{font-size:32px;margin-bottom:12px}.contact-card h4{margin:0 0 8px;font-size:15px;font-weight:600;color:#333}.contact-card p{margin:0;font-size:14px;color:#667eea}.help-footer{background:#fff;border-top:1px solid #e8e8e8;padding:24px;text-align:center}.help-footer p{margin:0;font-size:13px;color:#999}@media (max-width: 768px){.help-header-content{flex-wrap:wrap}.help-header h1{order:-1;width:100%;font-size:20px;margin-bottom:16px}.feature-grid,.export-formats,.shortcuts-grid,.contact-cards{grid-template-columns:1fr}.steps.horizontal{flex-direction:column}.steps.horizontal .step{flex-direction:row;text-align:left}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:AlibabaPuHuiTi,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color:#333;background:#f5f5f5;overflow:hidden;height:100vh;display:flex;flex-direction:column}#root{width:100%;height:100vh}.login-page,.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container,.register-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.logo{text-align:center;margin-bottom:30px}.logo h1{font-size:32px;color:#667eea;margin-bottom:8px}.logo p{color:#999;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-size:14px;font-weight:600}.form-group input{width:100%;padding:12px 16px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;transition:all .3s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.btn{width:100%;padding:14px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:block;text-align:center}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-bottom:12px}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea}.btn-secondary:hover{background:#f8f9ff}.divider{text-align:center;margin:20px 0;color:#999;font-size:12px;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#e8e8e8}.divider:before{left:0}.divider:after{right:0}.error-message{background:#fff3cd;color:#856404;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.success-message{background:#d4edda;color:#155724;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:45px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;font-size:18px;padding:4px;opacity:.6;transition:opacity .2s}.password-toggle:hover{opacity:1}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;font-size:14px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;margin:0}.checkbox-label input[type=checkbox]{width:auto;margin:0;cursor:pointer}.forgot-password-link{color:#667eea;text-decoration:none;font-size:14px;transition:color .2s}.forgot-password-link:hover{color:#764ba2;text-decoration:underline}.btn-wechat{width:100%;padding:14px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;background:#07c160;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}.btn-wechat:hover{background:#06ad56;transform:translateY(-2px);box-shadow:0 6px 20px #07c16066}.wechat-icon{font-size:20px}.success-container,.error-container,.verifying-container{text-align:center;padding:40px 20px}.success-icon,.error-icon{width:80px;height:80px;margin:0 auto 20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700}.success-icon{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.error-icon{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.success-container .success-message,.error-container .error-message{background:transparent;padding:0;margin-bottom:30px;border-radius:0}.success-container .success-message strong,.error-container .error-message strong{display:block;font-size:20px;margin-bottom:12px;color:#333}.success-container .success-message p,.error-container .error-message p{color:#666;font-size:14px;margin:8px 0}.hint{font-size:12px!important;color:#999!important;margin-top:16px!important}.verifying-container .spinner{width:50px;height:50px;margin:0 auto 20px}.verifying-container p{color:#666;font-size:14px}
