@import"https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;touch-action:pan-x pan-y;-webkit-overflow-scrolling:touch}#root{width:100%;height:100vh;overflow:hidden;overscroll-behavior:none;touch-action:none}.card{position:absolute;width:250px;height:180px;background:#fff;border-radius:8px;border-left:4px solid #ccc;box-shadow:0 2px 8px #0000001a;cursor:move;-webkit-user-select:none;user-select:none;transition:none;transform-origin:center;padding:12px;display:flex;flex-direction:column;overflow:hidden}.card-snap{transition:left .2s cubic-bezier(.4,0,.2,1),top .2s cubic-bezier(.4,0,.2,1),box-shadow .2s ease}.card-dimension-changing{transition:left .8s cubic-bezier(.4,0,.2,1),top .8s cubic-bezier(.4,0,.2,1),box-shadow .2s ease}.card-dragging{transition:box-shadow .2s ease}.card:hover{box-shadow:0 4px 16px #00000026;z-index:10}.card:active{cursor:grabbing;z-index:100}.card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #eee}.card-icon{font-size:20px;line-height:1}.card-title{font-weight:600;font-size:14px;color:#333;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stack-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#1d4ed8;color:#fff;font-size:11px;font-weight:700;border-radius:10px;margin-left:auto;cursor:pointer;transition:background .2s ease}.stack-badge:hover{background:#5568d3}.stack-badge-container{position:relative;margin-left:auto;display:flex;align-items:center;gap:4px}.stack-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:#94a3b8;color:#fff;font-size:13px;font-weight:700;border:none;border-radius:4px;cursor:pointer;transition:background .2s ease;line-height:1}.stack-toggle-btn:hover{background:#64748b}.stack-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:180px;max-width:250px;z-index:1000;overflow:hidden}.stack-menu-item{padding:8px 12px;font-size:12px;color:#333;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .15s ease;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stack-menu-item:last-child{border-bottom:none}.stack-menu-item:hover{background:#f5f5f5}.card-body{font-size:12px;flex:1;display:flex;flex-direction:column;overflow:hidden}.card-content{color:#666;margin-bottom:8px;line-height:1.4;font-size:11px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;text-overflow:ellipsis;min-height:46px}.card-file-info{color:#666;margin-bottom:8px;font-size:11px;line-height:1.3}.card-file-source{display:flex;align-items:center;gap:4px;margin-bottom:4px;color:#1d4ed8;font-weight:500}.card-file-url{color:#888;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-metadata{display:flex;flex-direction:column;gap:2px;margin-top:auto}.metadata-item{display:flex;gap:4px;color:#555;font-size:10px;line-height:1.2}.metadata-item strong{color:#333;min-width:55px}@media(max-width:768px){.card{width:220px;height:160px;padding:10px}.card-title{font-size:13px}.card-icon{font-size:18px}.card-description{font-size:11px}.metadata-item{font-size:9px}}@media(max-width:480px){.card{width:200px;height:150px;padding:8px}.card-title{font-size:12px}.card-icon{font-size:16px}.card-description{font-size:10px}.metadata-item{font-size:8px}.metadata-item strong{min-width:45px}}.card-editor-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.card-editor-modal{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.card-editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;gap:16px}.card-editor-header h2{margin:0;font-size:20px;font-weight:600;color:#111827;flex-shrink:0}.header-actions{display:flex;gap:8px;align-items:center}.btn-header{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;white-space:nowrap}.close-button{background:none;border:none;font-size:32px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease}.close-button:hover{background:#f3f4f6;color:#111827}.card-editor-form{padding:24px;overflow-y:auto;flex:1}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;color:#111827;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.file-link{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:8px 12px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#1d4ed8;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s ease}.file-link:hover{background:#1d4ed8;color:#fff;border-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 2px 8px #667eea33}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-actions{display:flex;gap:12px;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.form-actions-top{border-bottom:1px solid #e5e7eb;border-top:none;margin-top:0;padding-top:16px}.form-actions-right{display:flex;gap:12px}.btn-cancel,.btn-save{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover{background:#e5e7eb}.btn-save{background:#1d4ed8;color:#fff}.btn-save:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.btn-save:active{transform:translateY(0)}.btn-delete{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 4px 8px #dc35454d}.delete-confirm-modal{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:16px}.delete-confirm-content{background:#fff;padding:30px;border-radius:12px;max-width:400px;text-align:center;box-shadow:0 8px 24px #0003}.delete-confirm-content h3{margin:0 0 16px;font-size:24px;color:#333}.delete-confirm-content p{margin:0 0 12px;color:#666;font-size:16px}.delete-warning{color:#dc3545!important;font-weight:600;font-size:14px!important;margin-bottom:24px!important}.delete-confirm-actions{display:flex;gap:12px;justify-content:center}.btn-delete-confirm{padding:10px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;background:#dc3545;color:#fff}.btn-delete-confirm:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 4px 8px #dc354566}@media(max-width:768px){.card-editor-backdrop{padding:10px}.card-editor-modal{max-width:100%;max-height:95vh}.card-editor-header{padding:16px 18px}.card-editor-header h2{font-size:18px}.card-editor-content{padding:16px 18px}.editor-section h3{font-size:13px}.btn-header,.btn-cancel,.btn-save,.btn-delete{min-width:44px;min-height:44px;padding:8px 14px;font-size:13px}}@media(max-width:480px){.card-editor-backdrop{padding:0}.card-editor-modal{border-radius:0;max-height:100vh;height:100vh}.card-editor-header{padding:12px 16px}.card-editor-header h2{font-size:16px}.card-editor-content{padding:12px 16px}.btn-header,.btn-cancel,.btn-save,.btn-delete{font-size:12px;padding:6px 12px}.header-actions{flex-wrap:wrap}}.dimension-management{display:flex;flex-direction:column;gap:20px}.dimension-management-header h3{margin:0 0 8px;font-size:18px;font-weight:700;color:#111827}.dimension-management-description{margin:0 0 12px;font-size:14px;color:#6b7280;line-height:1.5}.dimension-create-button{padding:8px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #10b98140}.dimension-create-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.dimension-create-dialog{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.dimension-create-content{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d}.dimension-create-content h4{margin:0 0 20px;font-size:18px;font-weight:700;color:#111827}.dimension-create-field{margin-bottom:16px}.dimension-create-field label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:#374151}.dimension-create-field input,.dimension-create-field select{width:100%;padding:8px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:14px;transition:border-color .2s ease}.dimension-create-field input:focus,.dimension-create-field select:focus{outline:none;border-color:#3b82f6}.dimension-create-hint{margin:6px 0 0;font-size:12px;color:#6b7280}.dimension-create-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.dimension-create-cancel,.dimension-create-confirm{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.dimension-create-cancel{background:#f3f4f6;color:#374151}.dimension-create-cancel:hover{background:#e5e7eb}.dimension-create-confirm{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b98140}.dimension-create-confirm:hover{box-shadow:0 4px 12px #10b98166}.dimension-custom-badge{margin-left:8px;padding:2px 8px;background:#dbeafe;color:#1d4ed8;font-size:11px;font-weight:600;border-radius:4px}.dimension-config-actions{display:flex;gap:8px;align-items:center}.dimension-config-delete{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease;opacity:.6}.dimension-config-delete:hover{background:#fee2e2;opacity:1}.dimension-configs-list{display:flex;flex-direction:column;gap:12px}.dimension-config-item{background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;overflow:hidden;transition:all .2s ease}.dimension-config-item:hover{border-color:#d1d5db}.dimension-config-item.disabled{opacity:.5;background:#f3f4f6}.dimension-config-item.editing{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dimension-config-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px}.dimension-config-info{display:flex;align-items:center;gap:12px;flex:1}.dimension-config-toggle{display:flex;align-items:center;gap:12px;cursor:pointer;flex:1}.dimension-config-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#1e40af}.dimension-config-icon{font-size:24px;line-height:1}.dimension-config-name{font-size:16px;font-weight:700;color:#111827}.dimension-config-type-badge{padding:4px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:12px;font-weight:600;color:#6b7280;text-transform:capitalize}.dimension-config-expand{padding:6px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:600;color:#374151;cursor:pointer;transition:all .2s ease}.dimension-config-expand:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.dimension-config-expand:disabled{opacity:.3;cursor:not-allowed}.dimension-config-details{padding:20px;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:16px;background:#fff}.dimension-config-field{display:flex;flex-direction:column;gap:8px}.dimension-config-field label{font-size:13px;font-weight:600;color:#374151}.dimension-config-field input[type=text]{padding:10px 14px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;color:#111827;transition:all .2s ease}.dimension-config-field input[type=text]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dimension-config-radio-group{display:flex;gap:16px}.dimension-config-radio-group label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;transition:all .2s ease}.dimension-config-radio-group label:hover{background:#f3f4f6;border-color:#d1d5db}.dimension-config-radio-group input[type=radio]{width:16px;height:16px;cursor:pointer;accent-color:#1e40af}.dimension-config-radio-group span{font-size:14px;font-weight:500;color:#374151}.dimension-config-hint{margin:0;font-size:12px;color:#6b7280;font-style:italic}.dimension-config-color-picker{display:flex;gap:12px;align-items:center}.dimension-config-color-picker input[type=color]{width:60px;height:40px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;padding:2px}.dimension-config-color-input{flex:1;padding:10px 14px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:Monaco,Courier New,monospace;color:#111827}.dimension-management-footer{display:flex;justify-content:flex-end;padding-top:8px}.dimension-apply-button{padding:10px 24px;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea40}.dimension-apply-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.dimension-apply-button:active{transform:translateY(0)}.settings-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal{background:#fff;border-radius:12px;width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid #e5e7eb}.settings-header h2{margin:0;font-size:24px;font-weight:700;color:#1e40af}.settings-multispace{margin:4px 0 0;font-size:13px;color:#6b7280;font-weight:400}.settings-tabs{display:flex;border-bottom:2px solid #e5e7eb;padding:0 28px;gap:4px}.settings-tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s ease;margin-bottom:-2px}.settings-tab:hover{color:#374151;background:#f9fafb}.settings-tab.active{color:#1e40af;border-bottom-color:#1e40af}.settings-close{background:none;border:none;font-size:32px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.settings-close:hover{background:#f3f4f6;color:#111827}.settings-content{flex:1;overflow-y:auto;padding:24px 28px}.settings-section{margin-bottom:32px}.color-by-selector{margin-top:12px}.color-by-select{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit;background:#fff;cursor:pointer;transition:all .2s ease}.color-by-select:hover{border-color:#9ca3af}.color-by-select:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px #667eea1a}.settings-section:last-child{margin-bottom:0}.settings-section h3{margin:0 0 8px;font-size:18px;font-weight:700;color:#111827}.settings-description{margin:0 0 16px;font-size:14px;color:#6b7280;line-height:1.5}.dimensions-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.dimension-item{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.dimension-item:hover{background:#f3f4f6;border-color:#d1d5db}.dimension-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#1e40af}.dimension-icon{font-size:18px;line-height:1}.dimension-name{font-size:14px;font-weight:600;color:#374151;flex:1;display:flex;align-items:center;gap:8px}.dimension-custom-badge-small{padding:2px 6px;background:#dbeafe;color:#1d4ed8;font-size:10px;font-weight:600;border-radius:3px}.cloud-services{display:flex;flex-direction:column;gap:16px}.cloud-service-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;transition:all .2s ease}.cloud-service-item:hover{background:#f3f4f6;border-color:#d1d5db}.cloud-service-info{display:flex;align-items:center;gap:16px}.cloud-service-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:#fff;box-shadow:0 2px 6px #0000001a}.cloud-service-item h4{margin:0 0 4px;font-size:16px;font-weight:700;color:#111827}.cloud-service-status{margin:0;font-size:13px;color:#6b7280}.cloud-connect-button{padding:8px 20px;background:#1e40af;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #1e40af33}.cloud-connect-button:hover{background:#1e3a8a;box-shadow:0 4px 8px #1e40af4d;transform:translateY(-1px)}.cloud-connect-button.connected{background:#dc2626}.cloud-connect-button.connected:hover{background:#b91c1c}.cloud-services-note{margin-top:16px;padding:12px 16px;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;font-size:13px;color:#92400e;line-height:1.6}.cloud-services-note strong{font-weight:700}.cloud-services-note code{background:#fde68a;padding:2px 6px;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:12px}.settings-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 28px;border-top:1px solid #e5e7eb;background:#f9fafb}.settings-cancel,.settings-save{padding:10px 24px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.settings-cancel{background:#fff;color:#374151;border:1px solid #d1d5db}.settings-cancel:hover{background:#f9fafb;border-color:#9ca3af}.settings-save{background:#1e40af;color:#fff;box-shadow:0 2px 4px #1e40af33}.settings-save:hover{background:#1e3a8a;box-shadow:0 4px 8px #1e40af4d;transform:translateY(-1px)}.settings-placeholder{padding:40px;text-align:center;color:#6b7280;font-size:14px;background:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}.cell-labels-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.cell-label-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.cell-label-coords{display:flex;flex-direction:column;min-width:150px}.cell-label-coords strong{font-size:14px;color:#1f2937}.cell-label-dims{font-size:11px;color:#6b7280;margin-top:2px}.cell-label-text{flex:1;font-size:14px;color:#374151;font-weight:500}.cell-label-delete{width:28px;height:28px;border-radius:50%;border:1px solid #e5e7eb;background:#fff;color:#ef4444;font-size:20px;line-height:1;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.cell-label-delete:hover{background:#fef2f2;border-color:#ef4444}.add-cell-label-button{width:100%;padding:12px;border:2px dashed #d1d5db;background:#fff;color:#1e40af;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s}.add-cell-label-button:hover{border-color:#1e40af;background:#eff6ff}.dimension-selector{display:flex;flex-direction:column;gap:6px;min-width:150px}.dimension-label{font-size:9px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px}.dimension-dropdown{padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s ease;outline:none}.dimension-dropdown:hover{border-color:#4a9eff}.dimension-dropdown:focus{border-color:#4a9eff;box-shadow:0 0 0 3px #4a9eff1a}.dimension-dropdown option:disabled{color:#ccc}.canvas-container{position:relative;display:flex;flex-direction:column;height:100vh;background:#f5f5f5}.canvas-controls{position:absolute;top:10px;left:50%;transform:translate(-50%);display:flex;justify-content:space-between;align-items:center;padding:5px 14px;background:#f0f0f0cc;border-bottom:none;box-shadow:0 2px 8px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;gap:14px;z-index:1000}.controls-left{display:flex;gap:8px;align-items:center;flex:1}.controls-right{display:flex;gap:8px;align-items:center}.btn-logout{padding:6px 12px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:11px;font-weight:500;transition:all .2s;white-space:nowrap}.btn-logout:hover{background:#000000d9;transform:translateY(-1px)}.app-logo{flex-shrink:0}.title-group{display:flex;flex-direction:column;gap:2px}.canvas-title{margin:0;font-size:14px;font-weight:700;color:#333;letter-spacing:-.5px}.canvas-subtitle{margin:0;font-size:8px;color:#666;font-weight:400}.controls-center{display:flex;justify-content:center;align-items:flex-end;gap:14px;flex:0 0 auto;margin:0 14px}.btn-new-card{padding:10px 20px;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea40;white-space:nowrap;margin-bottom:6px}.btn-new-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-new-card:active{transform:translateY(0)}.btn-icon-action{display:flex;padding:7px;background:#667eea1a;color:#1d4ed8;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease;min-width:30px;min-height:30px;align-items:center;justify-content:center}.btn-icon-action:hover{background:#667eea33}.btn-icon-action:active{transform:scale(.95)}.btn-text-mobile{display:none}.btn-text-full{display:inline}.btn-search-toggle{display:none;padding:10px;background:#667eea1a;color:#1d4ed8;border:none;border-radius:8px;font-size:20px;cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px;align-items:center;justify-content:center}.btn-search-toggle:hover{background:#667eea33}.search-wrapper{display:flex;flex-direction:column;gap:6px;transition:all .3s ease}.search-wrapper.hidden{display:none}.search-label{font-size:9px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em}.search-container{position:relative;display:flex;align-items:center}.search-input{padding:9px 36px 9px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;width:240px;transition:all .2s ease;font-family:inherit}.search-input:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed81a}.search-input::placeholder{color:#9ca3af}.search-clear{position:absolute;right:8px;background:none;border:none;font-size:20px;color:#6b7280;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.search-clear:hover{background:#f3f4f6;color:#111827}.axis-controls{position:absolute;display:flex;flex-direction:column;gap:16px;z-index:100;background:#fffffff2;padding:14px 16px;border-radius:10px;box-shadow:0 4px 12px #0000001a,0 1px 4px #00000014;border:1px solid rgba(0,0,0,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:420px}.axis-selectors{display:flex;flex-direction:row;gap:12px;align-items:flex-end}.x-axis-controls,.y-axis-controls{top:100px;left:140px}.swap-axes-button{padding:6px 12px;background:#1d4ed8;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #667eea40;height:38px;display:flex;align-items:center;justify-content:center}.swap-axes-button:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.swap-axes-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.quick-selections{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid rgba(0,0,0,.1)}.quick-selections-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.quick-selections-label{font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em}.add-quick-selection-button{padding:4px 10px;background:#10b981;color:#fff;border:none;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-quick-selection-button:hover{background:#059669;transform:translateY(-1px)}.quick-selections-list{display:flex;flex-direction:column;gap:6px}.quick-selection-item{display:flex;gap:6px;align-items:center}.quick-selection-button{flex:1;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;color:#374151}.quick-selection-button:hover{background:#e5e7eb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.quick-selection-y{color:#1d4ed8;font-weight:600}.quick-selection-separator{color:#9ca3af;font-size:14px}.quick-selection-x{color:#7c3aed;font-weight:600}.delete-quick-selection-button{padding:6px 10px;background:#ef4444;color:#fff;border:none;border-radius:5px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;line-height:1}.delete-quick-selection-button:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 4px #ef444440}.delete-quick-selection-button:active{transform:translateY(0)}.canvas{position:relative;overflow:visible;background:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px);background-size:50px 50px;background-color:#fafafa;flex-shrink:0;flex-grow:0}.canvas-wrapper{position:absolute;inset:0;overflow:hidden;background:#fafafa;display:flex;align-items:center;justify-content:center;touch-action:none}.floating-x-labels,.floating-y-labels{position:absolute;inset:0;z-index:10;overflow:hidden}.axis-label{padding:6px 12px;background:#fffffff2;border-radius:6px;font-size:13px;font-weight:600;color:#333;box-shadow:0 2px 6px #00000026;pointer-events:none;white-space:nowrap;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.y-axis-label{writing-mode:vertical-rl;text-orientation:mixed;max-width:fit-content;padding:6px 8px}.axis-dimension-label{position:absolute;background:#1e40af0d;color:#1e40af;padding:6px 12px;border:2px solid rgba(30,64,175,.3);border-radius:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;z-index:150;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s ease;box-sizing:border-box;line-height:1}.axis-dimension-label:hover{background:#1e40af1a;border-color:#1e40af80;transform:scale(1.02)}.axis-dimension-label:active{transform:scale(.98)}.x-dimension-label{top:80px;left:60px;right:60px;height:18px;display:flex;align-items:center;justify-content:center;padding:1px 8px!important;font-size:10px}.y-dimension-label{top:130px;bottom:80px;left:8px;width:18px;writing-mode:vertical-rl;text-orientation:mixed;display:flex;align-items:center;justify-content:center;padding:8px 2px!important;font-size:10px}.axis-swap-button{position:absolute;top:80px;left:8px;width:44px;height:44px;background:#667eea1a;color:#1d4ed8;border:2px solid rgba(102,126,234,.3);border-radius:8px;font-size:20px;cursor:pointer;z-index:160;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.axis-swap-button:hover{background:#667eea33;border-color:#667eea80;transform:rotate(90deg)}.axis-swap-button:active{transform:rotate(90deg) scale(.95)}.axis-divider{position:absolute;pointer-events:none;z-index:0}.vertical-divider{top:0;bottom:0;width:0;border-left:2px dashed rgba(0,0,0,.15)}.horizontal-divider{left:0;right:0;height:0;border-top:2px dashed rgba(0,0,0,.15)}.cell-label{position:absolute;font-size:16px;font-weight:600;color:#6464644d;pointer-events:none;z-index:0;text-align:center;max-width:250px;padding:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas *{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.slot-badge-container{display:flex;align-items:center;gap:4px;pointer-events:auto}.slot-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:#1d4ed8;color:#fff;font-size:12px;font-weight:700;border-radius:12px;cursor:pointer;transition:background .2s ease;box-shadow:0 2px 4px #0003}.slot-badge:hover{background:#5568d3}.slot-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:#94a3b8;color:#fff;font-size:14px;font-weight:700;border:none;border-radius:6px;cursor:pointer;transition:background .2s ease;line-height:1;box-shadow:0 2px 4px #0003}.slot-toggle-btn:hover{background:#64748b}.slot-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:180px;max-width:250px;z-index:1000;overflow:hidden}.slot-menu-item{padding:8px 12px;font-size:12px;color:#333;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .15s ease;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-menu-item:last-child{border-bottom:none}.slot-menu-item:hover{background:#f5f5f5}.zoom-button:disabled{background:#cbd5e1;color:#94a3b8;cursor:not-allowed;box-shadow:none}.zoom-button:disabled:hover{background:#cbd5e1;transform:none}.zoom-button.card-scale-button{font-size:24px;line-height:1}.zoom-reset,.zoom-fit{font-size:18px;margin-top:8px}.zoom-slider{-webkit-appearance:none;appearance:none;width:8px;height:200px;background:transparent;outline:none;cursor:pointer;writing-mode:vertical-lr;direction:rtl}.zoom-slider::-webkit-slider-runnable-track{width:8px;height:100%;background:linear-gradient(to bottom,#1e40af,#e5e7eb);border-radius:4px;border:none}.zoom-slider::-moz-range-track{width:8px;height:100%;background:linear-gradient(to bottom,#1e40af,#e5e7eb);border-radius:4px;border:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;background:#1e40af;border:3px solid white;border-radius:50%;cursor:grab;box-shadow:0 2px 6px #0003;transition:all .2s ease;margin-left:-8px}.zoom-slider::-webkit-slider-thumb:active{cursor:grabbing}.zoom-slider::-moz-range-thumb{width:24px;height:24px;background:#1e40af;border:3px solid white;border-radius:50%;cursor:grab;box-shadow:0 2px 6px #0003;transition:all .2s ease;border:none;margin-left:-8px}.zoom-slider::-moz-range-thumb:active{cursor:grabbing}@media(max-width:768px){.zoom-control{right:10px;padding:12px 8px}.zoom-button{width:44px;height:44px;font-size:22px}.zoom-slider{height:180px}}.zoom-control{position:fixed;right:8px;top:100px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:1000}.zoom-control.collapsed{gap:0}.zoom-control.expanded{gap:8px}.zoom-toggle{width:48px;height:48px;background:#f0f0f0cc;border:1px solid rgba(0,0,0,.1);border-radius:10px;cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 8px #00000026;padding:0;line-height:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.zoom-control.expanded .zoom-toggle{font-size:32px;font-weight:300}.zoom-toggle:hover{background:#f0f0f0f2;box-shadow:0 4px 12px #0003;transform:scale(1.05)}.zoom-toggle:active{transform:scale(.98)}.zoom-controls-panel{display:flex;flex-direction:column;align-items:center;gap:12px;background:#f0f0f0cc;padding:16px 12px;border-radius:12px;box-shadow:0 4px 12px #00000026;border:1px solid rgba(0,0,0,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-top:8px;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.zoom-button{width:40px;height:40px;border:none;background:#1e40af;color:#fff;border-radius:8px;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #1e40af33;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.zoom-button:hover{background:#1e3a8a;box-shadow:0 4px 8px #1e40af4d;transform:scale(1.05)}.zoom-button:active{transform:scale(.95)}.zoom-reset{font-size:18px;margin-top:8px}.zoom-slider{-webkit-appearance:none;appearance:none;width:8px;height:200px;background:linear-gradient(to top,#e5e7eb,#1e40af);border-radius:4px;outline:none;cursor:pointer;writing-mode:vertical-lr;direction:rtl}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;background:#1e40af;border:3px solid white;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0003;transition:all .2s ease}.zoom-slider::-webkit-slider-thumb:hover{background:#1e3a8a;transform:scale(1.1);box-shadow:0 3px 8px #0000004d}.zoom-slider::-moz-range-thumb{width:24px;height:24px;background:#1e40af;border:3px solid white;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0003;transition:all .2s ease}.zoom-slider::-moz-range-thumb:hover{background:#1e3a8a;transform:scale(1.1);box-shadow:0 3px 8px #0000004d}@media(max-width:768px){.zoom-control{right:10px;padding:12px 8px}.zoom-button{width:44px;height:44px;font-size:22px}.zoom-slider{height:180px}.canvas-controls{top:8px;left:8px;right:8px;transform:none;padding:6px 10px;gap:8px;flex-wrap:nowrap;overflow:visible;max-width:calc(100vw - 16px)}.controls-left{gap:8px;flex-shrink:1;min-width:0}.app-logo{width:36px;height:36px}.title-group{gap:0;min-width:0}.controls-center{gap:6px;margin:0;flex-shrink:0}.controls-right{gap:8px;margin-left:auto}.canvas-subtitle{display:none}.canvas-title{font-size:12px}.btn-icon-action{padding:8px;font-size:18px;min-width:40px;min-height:40px}.canvas-title{font-size:16px}.canvas-subtitle{font-size:10px}.btn-new-card{padding:8px 14px;font-size:13px}.btn-logout{padding:6px 12px;font-size:12px}.axis-dimension-label{font-size:8px;padding:0;border-width:1px}.x-dimension-label{height:10px!important;padding:0 4px!important}.y-dimension-label{width:16px!important;padding:6px 1px!important}.axis-swap-button{width:36px;height:36px;font-size:18px}.axis-label{font-size:11px}.btn-search-toggle{display:flex}.search-wrapper{position:absolute;top:100%;left:0;right:0;margin-top:8px;background:#fffffffa;padding:12px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:999}.search-wrapper.hidden{display:none}.search-wrapper.visible{display:flex}.search-input{width:100%}}@media(max-width:480px){.canvas-controls{flex-direction:row;align-items:center;gap:6px;padding:5px 8px}.controls-left{gap:6px}.app-logo{width:32px;height:32px}.canvas-title{font-size:11px}.controls-center{gap:4px}.btn-icon-action{padding:6px;font-size:16px;min-width:36px;min-height:36px}.zoom-button,.axis-dimension-label{min-width:44px;min-height:44px}.zoom-control{right:8px;top:auto;bottom:20px;padding:10px 6px}.zoom-button{width:40px;height:40px;font-size:20px}.zoom-slider{height:150px}}@media(hover:none)and (pointer:coarse){.card{touch-action:none}.canvas{touch-action:none;-webkit-user-select:none;user-select:none}.btn-new-card,.btn-logout,.zoom-button{min-width:48px;min-height:48px}.axis-dimension-label{min-width:unset;min-height:unset}.card:hover{box-shadow:0 2px 12px #0000001a}.btn-new-card:hover,.btn-logout:hover{transform:none}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#1d4ed8,#2563eb);padding:20px;position:relative}.loading-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);z-index:1000;animation:fadeIn .2s ease}.login-box{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:60px 50px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%;text-align:center}.login-title{font-size:48px;font-weight:700;margin:0 0 10px;background:linear-gradient(135deg,#1d4ed8,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{font-size:16px;color:#666;margin:0 0 40px;font-style:italic}.login-error{background:#fee;color:#c33;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.login-success{background:#e7f7e7;color:#2d7a4d;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #a8e6a8}.login-options{display:flex;flex-direction:column;gap:12px;margin-bottom:30px}.login-divider{display:flex;align-items:center;text-align:center;color:#999;font-size:14px;margin:8px 0}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid #ddd}.login-divider span{padding:0 12px}.login-button{padding:14px 24px;font-size:15px;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;position:relative}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-icon{width:20px;height:20px;flex-shrink:0}.demo-button{background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;font-size:16px;padding:16px 32px}.demo-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.demo-button:active{transform:translateY(0)}.cognito-button{background:#1d4ed8;color:#fff}.cognito-button:hover:not(:disabled){background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.social-button{background:#fff;color:#333;border:1.5px solid #ddd}.social-button:hover:not(:disabled){background:#fafafa;border-color:#ccc;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.google-button:hover:not(:disabled){border-color:#4285f4}.apple-button:hover:not(:disabled){border-color:#000}.facebook-button:hover:not(:disabled){border-color:#1877f2}.secondary-button{background:transparent;color:#1d4ed8;border:2px solid #1d4ed8}.secondary-button:hover:not(:disabled){background:#f8f9ff;transform:translateY(-1px)}.secondary-button:active{transform:translateY(0)}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-input{padding:14px 16px;font-size:15px;border:2px solid #e0e0e0;border-radius:10px;width:100%;box-sizing:border-box;transition:border-color .3s ease;font-family:inherit}.auth-input:focus{outline:none;border-color:#1d4ed8}.auth-input:disabled{background:#f5f5f5;cursor:not-allowed}.auth-buttons{display:flex;flex-direction:column;gap:10px;margin-top:8px}.auth-link{text-align:center;margin-top:16px;font-size:14px;color:#666}.link-button{background:none;border:none;color:#1d4ed8;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;font-size:inherit;font-family:inherit}.link-button:hover{color:#5568d3}.password-requirements{font-size:12px;color:#888;margin-top:-4px;margin-bottom:8px;text-align:left}.verify-message{text-align:center;margin-bottom:20px;color:#666;line-height:1.6}.verify-message strong{color:#333}.token-input{padding:14px 16px;font-size:14px;border:2px solid #e0e0e0;border-radius:10px;width:100%;box-sizing:border-box;font-family:Courier New,monospace;transition:border-color .3s ease}.token-input:focus{outline:none;border-color:#1d4ed8}.backend-login-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px}.small-button{padding:12px 20px;font-size:14px}.small-button:disabled{opacity:.5;cursor:not-allowed}.small-button:disabled:hover{transform:none}.login-info{color:#888;font-size:14px;line-height:1.6;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.login-info p{margin:8px 0;font-size:13px;color:#999}.auth-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #1d4ed8;border-radius:50%;animation:spin 1s linear infinite;margin:20px auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:480px){.login-box{padding:40px 30px}.login-title{font-size:36px}.login-button{font-size:14px;padding:12px 20px}.demo-button{padding:14px 28px}}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:10px;padding:6px 12px;background:#fffffff2;border:1px solid rgba(0,0,0,.1);border-radius:8px;cursor:pointer;transition:all .2s}.user-menu-button:hover{background:#fff;box-shadow:0 2px 8px #0000001a}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.user-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.user-name{font-size:14px;font-weight:600;color:#1f2937;white-space:nowrap}.user-multispace{font-size:11px;color:#6b7280;white-space:nowrap}.menu-arrow{font-size:10px;color:#6b7280;margin-left:4px}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #00000026;min-width:220px;overflow:visible;z-index:1001;animation:slideDown .15s ease-out}.user-menu-dropdown.dropdown-right{right:0}.user-menu-dropdown.dropdown-left{left:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.menu-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:none;border:none;text-align:left;font-size:14px;color:#374151;cursor:pointer;transition:background .15s}.menu-item:hover:not(.disabled){background:#f9fafb}.menu-item.disabled{opacity:.5;cursor:not-allowed}.menu-item-parent{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.menu-item-parent:active:not(.disabled){background:#f9fafb}.submenu-arrow{font-size:14px;color:#9ca3af}.submenu{position:absolute;top:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #00000026;min-width:200px;max-height:400px;overflow-y:auto;z-index:1002}.submenu-right{left:100%;margin-left:8px;animation:slideRight .15s ease-out}.submenu-left{right:100%;margin-right:8px;animation:slideLeft .15s ease-out}@keyframes slideRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes slideLeft{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.submenu-item{width:100%;display:flex;align-items:center;gap:8px;padding:10px 14px;background:none;border:none;text-align:left;font-size:13px;color:#374151;cursor:pointer;transition:background .15s}.submenu-item:hover{background:#f9fafb}.submenu-item.active{background:#eff6ff;color:#1e40af;font-weight:500}.submenu-icon{font-size:16px;width:20px;text-align:center}.submenu-divider{height:1px;background:#e5e7eb;margin:4px 0}.submenu-item-create{color:#3b82f6;font-weight:500}.submenu-item-create:hover{background:#eff6ff}.menu-divider{height:1px;background:#e5e7eb;margin:4px 0}.menu-item-logout{color:#dc2626}.menu-item-logout:hover{background:#fee2e2}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50000;animation:fadeIn .2s;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease-out}.modal-content h2{margin:0 0 20px;font-size:20px;color:#1f2937}.modal-content p{margin:10px 0;color:#4b5563;line-height:1.6}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#374151}.form-group input[type=text],.form-group textarea{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.color-input-group{display:flex;gap:8px;align-items:center}.color-input-group input[type=color]{width:48px;height:38px;padding:2px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer}.color-input-group input[type=text]{flex:1}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px}.modal-actions button{padding:10px 20px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.modal-actions button:hover{background:#f9fafb}.modal-actions button.primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.modal-actions button.primary:hover{background:#2563eb}.modal-actions button.primary:disabled{background:#93c5fd;border-color:#93c5fd;cursor:not-allowed}.help-content{margin:20px 0}.help-content h3{margin:16px 0 8px;font-size:16px;color:#1f2937}.help-content p{margin:8px 0;padding-left:12px}.help-content p strong{color:#1f2937}.menu-user-info-mobile{display:none}@media(max-width:768px){.user-menu-button{padding:6px 8px;gap:8px}.user-info{display:none}.menu-arrow{margin-left:0}.menu-user-info-mobile{display:flex;align-items:center;gap:12px;padding:16px;background:linear-gradient(135deg,#667eea14,#764ba214)}.user-avatar-large{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;flex-shrink:0}.user-details{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.user-name-large{font-size:16px;font-weight:600;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-multispace-large{font-size:13px;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{right:auto;left:0;min-width:280px}}@media(max-width:480px){.user-menu-dropdown{min-width:calc(100vw - 40px);max-width:320px}}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#333;font-family:system-ui,-apple-system,sans-serif}.loading-spinner{width:60px;height:60px;border:4px solid rgba(50,100,200,.1);border-top-color:#3264c8;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:18px;font-weight:500;color:#3264c8;margin-bottom:8px}.loading-subtext{font-size:14px;color:#666;opacity:.8}.loading-dots:after{content:"";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.demo-welcome-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.demo-welcome-dialog{background:#fff;border-radius:16px;max-width:500px;width:90%;padding:32px;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.demo-welcome-dialog h2{margin:0 0 20px;font-size:24px;font-weight:700;color:#1e40af;text-align:center}.demo-welcome-content{margin-bottom:24px}.demo-welcome-content p{margin:0 0 12px;font-size:15px;color:#374151}.demo-welcome-content ul{list-style:none;padding:0;margin:0 0 16px}.demo-welcome-content li{padding:10px 0;font-size:15px;color:#374151;line-height:1.6}.demo-note{padding:12px 16px;background:#eff6ff;border-left:3px solid #3b82f6;border-radius:6px;font-size:14px;color:#1e40af;margin-top:16px!important}.demo-welcome-button{width:100%;padding:14px;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.demo-welcome-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.demo-welcome-button:active{transform:translateY(0)}@media(max-width:768px){.demo-welcome-dialog{padding:24px;max-width:calc(100% - 32px)}.demo-welcome-dialog h2{font-size:20px}.demo-welcome-content p,.demo-welcome-content li{font-size:14px}}
