.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.documents-ai-page{padding:var(--spacing-lg);max-width:1400px;margin:0 auto}.documents-ai-page .page-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.documents-ai-page .page-header h1{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;margin:0;font-size:24px;font-weight:600}.documents-ai-page .header-actions{display:flex;gap:var(--spacing-sm)}.btn-back{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:none;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.btn-back:hover{background:var(--bg-secondary);color:var(--text-primary)}.empty-state{text-align:center;padding:var(--spacing-xxl);background:var(--bg-card);border-radius:12px;border:1px dashed var(--border-color)}.empty-state svg{color:var(--text-tertiary);margin-bottom:var(--spacing-md)}.empty-state h3{margin:0 0 var(--spacing-sm);color:var(--text-primary)}.empty-state p{margin:0 0 var(--spacing-lg);color:var(--text-secondary)}.loading-state{text-align:center;padding:var(--spacing-xxl);color:var(--text-secondary)}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.document-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:var(--spacing-lg);cursor:pointer;transition:all .2s}.document-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000001a}.document-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.document-card .card-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.card-description{font-size:13px;color:var(--text-secondary);margin:0 0 var(--spacing-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--text-tertiary);margin-bottom:var(--spacing-md)}.card-meta span{display:flex;align-items:center;gap:4px}.card-actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end}.status-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.status-draft{background:#f3f4f6;color:#6b7280}.status-processing{background:#dbeafe;color:#1d4ed8;animation:pulse 1.5s infinite}.status-ready{background:#d1fae5;color:#059669}.status-error{background:#fee2e2;color:#dc2626}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.template-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:var(--spacing-lg);cursor:pointer;transition:all .2s}.template-card:hover{border-color:var(--color-primary)}.template-card.inactive{opacity:.6}.card-badges{display:flex;gap:var(--spacing-xs)}.badge{padding:3px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase}.badge-default{background:#dbeafe;color:#1d4ed8}.badge-inactive{background:#f3f4f6;color:#6b7280}.btn-primary{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.btn-secondary:hover{background:var(--bg-hover)}.btn-secondary.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon.btn-danger:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626}.document-editor{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}@media(max-width:1024px){.document-editor{grid-template-columns:1fr}}.editor-form,.editor-images{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:var(--spacing-lg)}.form-card h3{margin:0 0 var(--spacing-lg);font-size:16px;font-weight:600;color:var(--text-primary)}.form-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xs);font-size:13px;font-weight:500;color:var(--text-secondary)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-primary);transition:all .2s}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;min-height:80px}.form-hint{display:block;margin-top:4px;font-size:12px;color:var(--text-tertiary)}.form-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.btn-ai-small{display:flex;align-items:center;gap:4px;padding:4px 8px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer}.btn-ai-small:hover{opacity:.9}.pdf-status{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.status-label{font-size:13px;color:var(--text-secondary)}.error-message.small{padding:var(--spacing-sm);font-size:12px;margin-bottom:var(--spacing-md)}.drop-zone{border:2px dashed var(--border-color);border-radius:12px;padding:var(--spacing-xl);text-align:center;transition:all .2s;cursor:pointer}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--color-primary);background:#3b82f60d}.drop-zone.uploading{opacity:.6;pointer-events:none}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);cursor:pointer}.drop-zone-content svg{color:var(--text-tertiary)}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm);margin-top:var(--spacing-md)}.image-thumb{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:var(--bg-secondary)}.image-thumb img{width:100%;height:100%;object-fit:cover}.image-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.image-thumb:hover .image-overlay{opacity:1}.image-order{position:absolute;top:4px;left:4px;width:24px;height:24px;background:#ffffffe6;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.btn-delete-image{background:#fff;border:none;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#dc2626;transition:transform .15s,background .15s}.btn-delete-image:hover{background:#fee2e2;transform:scale(1.1)}.image-actions{display:flex;gap:6px;align-items:center}.drag-handle{background:#fff;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:grab;color:var(--text-secondary);transition:transform .15s,background .15s}.drag-handle:hover{background:#e0f2fe;color:#0284c7}.drag-handle:active{cursor:grabbing}.images-hint{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary);margin-top:var(--spacing-md);margin-bottom:var(--spacing-xs)}.image-thumb{cursor:grab;transition:transform .2s,box-shadow .2s,border-color .2s;border:2px solid transparent}.image-thumb:active{cursor:grabbing}.image-thumb.dragging{opacity:.5;transform:scale(.95)}.image-thumb.drag-over{border-color:#3b82f6;transform:scale(1.02);box-shadow:0 0 0 3px #3b82f64d}.image-thumb.drag-over:before{content:"";position:absolute;inset:0;background:#3b82f61a;z-index:5;pointer-events:none}.template-editor-page .page-header h1{flex:0 1 auto}.template-editor-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-lg);min-height:600px}.template-editor-layout.with-preview{grid-template-columns:280px 1fr 1fr}@media(max-width:1200px){.template-editor-layout,.template-editor-layout.with-preview{grid-template-columns:1fr}}.editor-settings{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:var(--spacing-lg);height:fit-content}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.toggle{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.toggle input{display:none}.toggle-slider{width:40px;height:22px;background:var(--border-color);border-radius:11px;position:relative;transition:background .2s}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-slider{background:var(--color-primary)}.toggle input:checked+.toggle-slider:after{transform:translate(18px)}.toggle-label{font-size:13px;color:var(--text-secondary)}.variables-help{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.variables-help h4{margin:0 0 var(--spacing-sm);font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-tertiary)}.variables-help ul{margin:0;padding:0;list-style:none}.variables-help li{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.variables-help code{background:var(--bg-secondary);padding:2px 6px;border-radius:4px;font-size:11px}.editor-code{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.editor-tabs{display:flex;border-bottom:1px solid var(--border-color)}.editor-tabs .tab{padding:var(--spacing-sm) var(--spacing-lg);background:none;border:none;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-bottom:2px solid transparent;margin-bottom:-1px}.editor-tabs .tab:hover{color:var(--text-primary)}.editor-tabs .tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.code-area{flex:1;min-height:400px}.code-area textarea{width:100%;height:100%;min-height:400px;padding:var(--spacing-md);background:#1e1e1e;color:#d4d4d4;border:none;font-family:Monaco,Menlo,monospace;font-size:13px;line-height:1.5;resize:none}.code-area textarea:focus{outline:none}.editor-preview{background:#fff;border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.preview-header{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:12px;font-weight:500;color:var(--text-secondary)}.preview-iframe{flex:1;width:100%;border:none;background:#fff}.error-message{padding:var(--spacing-md);background:#fee2e2;color:#dc2626;border-radius:8px;margin-bottom:var(--spacing-md);font-size:14px}.success-message{padding:var(--spacing-md);background:#d1fae5;color:#059669;border-radius:8px;margin-bottom:var(--spacing-md);font-size:14px}.btn-ingest{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.btn-ingest:hover{opacity:.9;background:linear-gradient(135deg,#667eea,#764ba2)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal-content{background:var(--bg-card);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0000004d}.ingest-modal{max-width:520px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{display:flex;align-items:center;gap:var(--spacing-sm);margin:0;font-size:18px;font-weight:600}.modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:8px;transition:all .2s}.modal-close:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-body{padding:var(--spacing-lg)}.modal-description{margin:0 0 var(--spacing-lg);font-size:14px;color:var(--text-secondary);line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.modal-footer .btn-secondary:disabled{opacity:.5;cursor:not-allowed}.ingest-progress{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#dbeafe;border-radius:8px;margin-top:var(--spacing-md)}.ingest-progress span{font-size:13px;color:#1d4ed8}.spinner{width:20px;height:20px;border:2px solid #93c5fd;border-top-color:#1d4ed8;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.characteristics-card h3{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.characteristics-card h3 svg{color:var(--color-primary)}.char-section{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.char-section:last-of-type{border-bottom:none;margin-bottom:var(--spacing-sm)}.char-section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm)}.char-row-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.char-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media(max-width:768px){.char-row-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.char-row-2,.char-row-3{grid-template-columns:1fr}}.energy-select option[value="A+"],.energy-select option[value=A]{color:#059669;font-weight:600}.energy-select option[value=B],.energy-select option[value=C]{color:#d97706}.energy-select option[value=D],.energy-select option[value=E],.energy-select option[value=F],.energy-select option[value=G]{color:#dc2626}.missing-badge{font-size:10px;background:#fef3c7;color:#92400e;padding:2px 6px;border-radius:4px;margin-left:8px;font-weight:500}.input-missing{border-color:#fbbf24!important;background:#fffbeb!important}.input-missing::placeholder{color:#d97706}.price-input-wrapper{display:flex;gap:var(--spacing-xs)}.price-input-wrapper .form-input{flex:1}.currency-select{width:60px;padding:var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer}.currency-select:focus{outline:none;border-color:var(--color-primary)}.features-group{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.features-input{display:flex;gap:var(--spacing-xs)}.features-input .form-input{flex:1}.btn-add-feature{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn-add-feature:hover{opacity:.9}.features-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.feature-tag{display:flex;align-items:center;gap:6px;padding:6px 10px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#3730a3;border-radius:6px;font-size:13px;font-weight:500}.remove-feature{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:#3730a333;border:none;border-radius:4px;color:#3730a3;cursor:pointer;padding:0;transition:all .2s}.remove-feature:hover{background:#3730a366}.ai-extracted-badge{display:inline-flex;align-items:center;gap:4px;margin-left:auto;padding:4px 8px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border-radius:4px;font-size:11px;font-weight:500}.confidence-badge{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;position:relative;overflow:hidden}.confidence-badge .conf-bar{position:absolute;left:0;top:0;bottom:0;opacity:.3;transition:width .3s ease}.confidence-badge .conf-label{position:relative;z-index:1}.conf-high{background:#d1fae5;color:#059669}.conf-high .conf-bar{background:#059669}.conf-medium{background:#fef3c7;color:#92400e}.conf-medium .conf-bar{background:#f59e0b}.conf-low{background:#fee2e2;color:#dc2626}.conf-low .conf-bar{background:#dc2626}.input-low-conf{border-color:#f59e0b!important;background:linear-gradient(to right,#fffbeb,var(--bg-secondary))!important}.input-low-conf:focus{box-shadow:0 0 0 3px #f59e0b33!important}:root{--color-primary: #1976d2;--color-primary-dark: #1565c0;--color-primary-light: #42a5f5;--color-success: #2e7d32;--color-success-light: #4caf50;--color-error: #d32f2f;--color-error-light: #f44336;--color-warning: #f57c00;--color-info: #0288d1;--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #fafafa;--bg-hover: #f0f0f0;--text-primary: #212121;--text-secondary: #757575;--text-tertiary: #9e9e9e;--text-disabled: #bdbdbd;--border-color: #e0e0e0;--border-color-light: #f5f5f5;--border-color-dark: #bdbdbd;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 4px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 8px rgba(0, 0, 0, .15);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit}a{text-decoration:none;color:inherit}ul,ol{list-style:none}.btn-primary{background:var(--color-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:4px;border:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-base);cursor:pointer;transition:background-color .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);white-space:nowrap;text-decoration:none}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-primary:disabled{background:var(--bg-hover);color:var(--text-disabled);cursor:not-allowed}.btn-secondary{background:#fff;color:var(--color-primary);border:1px solid var(--border-color);padding:var(--spacing-sm) var(--spacing-md);border-radius:4px;font-weight:var(--font-weight-medium);font-size:var(--font-size-base);cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);white-space:nowrap;text-decoration:none}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--color-primary)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--color-error);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:4px;border:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-base);cursor:pointer;transition:background-color .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);white-space:nowrap;text-decoration:none}.btn-danger:hover:not(:disabled){background:var(--color-error-light)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-success{background:var(--color-success);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:4px;border:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-base);cursor:pointer;transition:background-color .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);white-space:nowrap;text-decoration:none}.btn-success:hover:not(:disabled){background:var(--color-success-light)}.btn-success:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-md)}.btn-block{width:100%}.btn-icon{padding:var(--spacing-sm);min-width:40px;min-height:40px}@media(max-width:768px){.btn-primary,.btn-secondary,.btn-danger,.btn-success{padding:var(--spacing-md);font-size:var(--font-size-base);min-height:44px}.btn-sm{padding:var(--spacing-sm);font-size:var(--font-size-sm);min-height:36px}.btn-lg{padding:var(--spacing-lg);font-size:var(--font-size-lg);min-height:52px}.btn-icon{min-width:44px;min-height:44px}}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;border:1px solid #e0e4e8;border-radius:8px;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;background:#fff;color:#1a1a2e}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:#f5f7f9;color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb}.form-input::placeholder{color:#b0b8c1}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.error-message{padding:var(--spacing-md);margin-bottom:var(--spacing-md);background-color:#fee;color:#c33;border:1px solid #c33;border-radius:4px;font-size:var(--font-size-sm)}.success-message{padding:var(--spacing-md);margin-bottom:var(--spacing-md);background-color:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:4px;font-size:var(--font-size-sm)}.form-card{background:#fff;border-radius:8px;padding:var(--spacing-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-lg);overflow:visible;position:relative}.form-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);overflow:visible}.table-container{background:#fff;border-radius:8px;box-shadow:var(--shadow-md);overflow-x:auto;margin-top:var(--spacing-lg);-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;background:#fff;min-width:600px}.table thead{background:var(--bg-secondary)}.table th{padding:var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--text-secondary);border-bottom:2px solid var(--border-color);white-space:nowrap}.table td{padding:var(--spacing-md);border-bottom:1px solid var(--border-color-light)}.table tbody tr:hover{background:var(--bg-hover)}.table tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.table-actions button{white-space:nowrap}.link-button{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:0;font-size:inherit;font-family:inherit;text-decoration:underline;text-align:left}.link-button:hover{color:var(--color-primary-dark)}.role-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.role-badge.admin{background:#e3f2fd;color:#1976d2}.role-badge.user{background:#f3e5f5;color:#7b1fa2}.priority-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:#fff}.priority-badge[data-priority="0"]{background:#4caf50}.priority-badge[data-priority="1"]{background:#ff9800}.priority-badge[data-priority="2"]{background:#f44336}.category-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.category-badge[data-type=expense]{background:#e3f2fd;color:#1976d2;border:1px solid #90caf9}.category-badge[data-type=income]{background:#e8f5e9;color:#2e7d32;border:1px solid #81c784}.settled-badge{display:inline-block;padding:4px 8px;background:#e8f5e9;color:#2e7d32;border-radius:4px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.amount{font-weight:var(--font-weight-semibold)}.amount.positive{color:var(--color-success)}.amount.negative{color:var(--color-error)}.amount-cell{text-align:right;font-family:Courier New,monospace}.iva-cell{text-align:center}.percentage-cell{text-align:center;font-weight:var(--font-weight-medium)}@media(max-width:1024px){.table th,.table td{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.table-actions{flex-direction:column;gap:4px}.table-actions button{padding:4px 8px;font-size:var(--font-size-xs)}}@media(max-width:768px){.table-container{margin-top:var(--spacing-md);border-radius:0;margin-left:-8px;margin-right:-8px}.table{min-width:500px}.table th,.table td{padding:var(--spacing-sm);font-size:var(--font-size-xs)}.hide-mobile{display:none!important}.role-badge,.priority-badge,.category-badge,.settled-badge{padding:2px 6px;font-size:10px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:var(--spacing-md);box-sizing:border-box}.modal-content{background:#fff;border-radius:8px;box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:fadeIn .2s ease-out}.categorize-modal{max-width:1100px!important;width:95%!important;max-height:95vh}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);flex-shrink:0}.modal-header h2{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;flex-shrink:0}.modal-close:hover{color:var(--text-primary);background-color:var(--bg-hover)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-top:1px solid var(--border-color);background-color:var(--bg-secondary);flex-shrink:0;flex-wrap:wrap;gap:var(--spacing-md)}.modal-footer-info{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.modal-footer-info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.modal-footer-info-label{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.modal-footer-info-value{font-size:var(--font-size-base);color:var(--text-primary);font-weight:var(--font-weight-semibold)}.modal-footer-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.applied-rule-edit-button{background:var(--color-primary);color:#fff;border:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:4px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color .2s}.applied-rule-edit-button:hover{background:var(--color-primary-dark)}@media(max-width:768px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-width:100%;width:100%;max-height:95vh;border-radius:16px 16px 0 0;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.categorize-modal{max-width:100%!important;width:100%!important;max-height:100vh;border-radius:0}.modal-header{padding:var(--spacing-md);border-radius:16px 16px 0 0}.modal-header h2{font-size:var(--font-size-lg)}.modal-body{padding:var(--spacing-md)}.modal-footer{padding:var(--spacing-md);flex-direction:column;align-items:stretch}.modal-footer-info{justify-content:space-between;width:100%}.modal-footer-actions{width:100%}.modal-footer-actions button{flex:1}.modal-close{width:40px;height:40px;font-size:32px}}.layout{display:flex;height:100vh;background:var(--bg-secondary)}.sidebar{width:260px;background:#fff;border-right:1px solid var(--border-color);display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .3s ease;z-index:100}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color-light);display:flex;justify-content:space-between;align-items:flex-start}.sidebar-header h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:var(--spacing-xs)}.user-info{font-size:var(--font-size-sm);color:var(--text-secondary);word-break:break-word}.nav-menu{flex:1;padding:var(--spacing-md) 0;overflow-y:auto}.nav-menu li{margin:0}.nav-menu a{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-lg);color:var(--text-primary);font-size:var(--font-size-base);transition:background-color .2s ease;border-left:3px solid transparent}.nav-menu a:hover{background:var(--bg-hover)}.nav-menu a.active{background:var(--bg-hover);border-left-color:var(--color-primary);color:var(--color-primary);font-weight:var(--font-weight-medium)}.nav-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;margin-right:10px;opacity:.6}.nav-menu a.active .nav-icon,.nav-dropdown-toggle.active .nav-icon{opacity:1}.nav-submenu{background:var(--bg-secondary);list-style:none;padding:0;margin:0}.nav-submenu a{padding-left:calc(var(--spacing-lg) + 1.5rem);font-size:.9rem;display:flex;align-items:center}.nav-separator{height:1px;background:var(--border-color-light);margin:var(--spacing-sm) var(--spacing-md)}.nav-dropdown-toggle{background:none;border:none;width:100%;text-align:left;cursor:pointer;padding:var(--spacing-sm) var(--spacing-lg);display:flex;align-items:center;font-size:inherit;font-family:inherit;color:var(--text-primary);border-left:3px solid transparent;transition:background-color .2s ease}.nav-dropdown-toggle:hover{background:var(--bg-hover)}.nav-dropdown-toggle.active{background:var(--bg-hover);border-left-color:var(--color-primary);color:var(--color-primary);font-weight:var(--font-weight-medium)}.main-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.page-container{padding:var(--spacing-lg);background:var(--bg-secondary);min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-sm)}.page-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0}.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;padding:var(--spacing-xs);color:var(--text-primary)}.mobile-menu-btn svg{width:24px;height:24px}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid var(--border-color);padding:0 var(--spacing-md);align-items:center;justify-content:space-between;z-index:99;box-shadow:var(--shadow-sm)}.mobile-header h1{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary);margin:0}.sidebar-close-btn{display:none;background:none;border:none;cursor:pointer;padding:var(--spacing-xs);color:var(--text-secondary);font-size:24px;line-height:1}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99}.sidebar-overlay.visible{display:block}@media(max-width:1024px){.sidebar{width:220px}.main-content,.page-container{padding:var(--spacing-md)}.page-header h1{font-size:var(--font-size-xl)}}@media(max-width:768px){.layout{flex-direction:column}.mobile-header{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close-btn{display:block}.main-content{margin-top:56px;padding:var(--spacing-md);min-height:calc(100vh - 56px)}.page-container{padding:var(--spacing-sm)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.page-header h1{font-size:var(--font-size-lg)}.page-header button,.page-header .btn-primary{width:100%}.nav-menu a,.nav-dropdown-toggle{padding:var(--spacing-md) var(--spacing-lg)}}@media(max-width:480px){.main-content{padding:var(--spacing-sm)}.page-container{padding:var(--spacing-xs)}.sidebar{width:100%}.page-header h1{font-size:var(--font-size-md)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stats-grid-3{grid-template-columns:repeat(3,1fr)}.stats-grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{background:#fff;border-radius:8px;padding:var(--spacing-lg);box-shadow:var(--shadow-sm);text-align:center}.stat-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.stat-card-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--spacing-xs)}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.summary-card{background:#fff;border-radius:8px;padding:var(--spacing-md);box-shadow:var(--shadow-md)}.summary-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md)}.summary-title.expense{color:var(--color-error)}.summary-title.income{color:var(--color-success)}.summary-title.iva{color:#7b1fa2}.summary-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary);cursor:pointer}.summary-value:hover{text-decoration:underline}.summary-label{font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:var(--spacing-xs)}.summary-item{margin-bottom:var(--spacing-md)}.summary-item:last-child{margin-bottom:0}.settings-container{padding:var(--spacing-lg);max-width:600px}.settings-title{margin-bottom:var(--spacing-xs);color:var(--color-primary)}.settings-subtitle{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.settings-status{border-radius:8px;padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.settings-status.configured{background:#e8f5e9;border:1px solid #4caf50}.settings-status.not-configured{background:#fff3e0;border:1px solid #ff9800}.settings-info-box{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background:var(--bg-secondary);border-radius:8px}.settings-info-box h3{margin-bottom:var(--spacing-md)}.settings-info-box ul{padding-left:var(--spacing-lg);color:var(--text-secondary)}.settings-info-box li{margin-bottom:var(--spacing-xs)}.user-name{font-weight:var(--font-weight-medium)}.user-email{font-size:var(--font-size-sm);color:var(--text-secondary)}.status-indicator{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:var(--spacing-xs)}.status-indicator.active{background:#4caf50}.status-indicator.inactive{background:#9e9e9e}.status-text{font-size:var(--font-size-sm)}.status-text.active{color:#4caf50}.status-text.inactive{color:#9e9e9e}.count-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-weight:var(--font-weight-medium)}.count-badge.primary{background:#e3f2fd;color:#1976d2}.count-badge.success{background:#e8f5e9;color:#388e3c}.count-badge.neutral{background:#f5f5f5;color:#9e9e9e}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}@media(max-width:1024px){.stats-grid-3,.stats-grid-4,.summary-grid,.summary-cards{grid-template-columns:repeat(2,1fr)}.settings-container{padding:var(--spacing-md);max-width:100%}}@media(max-width:768px){.stats-grid,.stats-grid-3,.stats-grid-4,.summary-cards{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.stat-card{padding:var(--spacing-md)}.stat-card-value{font-size:var(--font-size-xl)}.stat-card-label{font-size:var(--font-size-xs)}.summary-grid{grid-template-columns:1fr;gap:var(--spacing-sm)}.summary-card{padding:var(--spacing-sm)}.summary-value{font-size:var(--font-size-md)}.settings-container{padding:var(--spacing-sm)}.settings-info-box{padding:var(--spacing-md);margin-top:var(--spacing-lg)}}@media(max-width:480px){.stats-grid,.stats-grid-3,.stats-grid-4{grid-template-columns:1fr}.stat-card-value{font-size:var(--font-size-lg)}}.filters-section{background:#fafbfc;border:1px solid #e8eaed;border-radius:12px;padding:var(--spacing-md) var(--spacing-lg)}.filters-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:0;margin-bottom:0}.filters-header h3{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin:0}.filters-icon{display:flex;align-items:center;color:var(--text-tertiary)}.filters-icon svg{width:14px;height:14px}.filters-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--color-primary);color:#fff;font-size:10px;font-weight:var(--font-weight-bold);margin-left:var(--spacing-xs)}.filters-toggle{display:none;transition:transform .3s ease;color:var(--text-tertiary)}.filters-toggle.expanded{transform:rotate(180deg)}.filters-content{padding-top:var(--spacing-lg)}.filters-content .form-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-md);align-items:end}@media(max-width:1400px){.filters-content .form-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:1024px){.filters-content .form-grid{grid-template-columns:repeat(3,1fr)}}.filters-content .form-group{margin-bottom:0}.filters-content .form-label{font-size:11px;font-weight:var(--font-weight-medium);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.filters-content .form-input,.filters-content .form-select{background:#fff;border:1px solid #e0e4e8;border-radius:8px;padding:10px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s;height:44px;box-sizing:border-box}.filters-content .form-input:focus,.filters-content .form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.filters-content .form-input::placeholder{color:#b0b8c1}.filters-content .form-group>div{min-height:44px}@media(min-width:769px){.filters-header{cursor:default;margin-bottom:0}.filters-content{display:block!important;max-height:none!important;opacity:1!important}}@media(max-width:768px){.filters-section{padding:var(--spacing-md)}.filters-toggle{display:flex}.filters-content{max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease,padding .3s ease;padding-top:0}.filters-content.expanded{max-height:2000px;opacity:1;padding-top:var(--spacing-md);overflow:visible}.filters-content .form-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}}@media(max-width:480px){.filters-content .form-grid{grid-template-columns:1fr}}.desktop-only{display:block!important}.mobile-only{display:none!important}@media(max-width:768px){.desktop-only{display:none!important}.mobile-only{display:block!important}}.table-container.desktop-only{display:block!important}.movements-cards.mobile-only{display:none!important}@media(max-width:768px){.table-container.desktop-only{display:none!important}.movements-cards.mobile-only{display:flex!important}}.movements-cards{display:flex;flex-direction:column;gap:var(--spacing-sm)}.movement-card{background:#fff;border-radius:12px;padding:var(--spacing-md);box-shadow:var(--shadow-sm);border-left:4px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.movement-card:active{transform:scale(.98)}.movement-card.expense{border-left-color:var(--color-error)}.movement-card.income{border-left-color:var(--color-success)}.movement-card.uncategorized{background:linear-gradient(to right,#fff9e6,#fff 20%)}.movement-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.movement-date{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;font-weight:var(--font-weight-medium)}.movement-amount{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.movement-amount.income{color:var(--color-success)}.movement-amount.expense{color:var(--color-error)}.movement-concept{font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.4;margin-bottom:var(--spacing-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.movement-card-footer,.movement-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.movement-tag{display:inline-block;padding:4px 10px;border-radius:12px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.movement-tag.income{background:#e8f5e9;color:var(--color-success);border:1px solid var(--color-success)}.movement-tag.expense{background:#e3f2fd;color:#1976d2;border:1px solid #90caf9}.movement-base,.movement-iva{font-size:var(--font-size-xs);color:var(--text-secondary);padding:2px 8px;background:var(--bg-secondary);border-radius:8px}.movement-uncategorized{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-warning);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.movement-uncategorized svg{stroke:var(--color-warning)}.fab-button{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background-color:#ff6b35;border:none;box-shadow:0 4px 12px #ff6b3566;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:100;transition:transform .2s ease,box-shadow .2s ease}.fab-button:active{transform:scale(.95);box-shadow:0 2px 8px #ff6b3566}@media(max-width:768px){.fab-button.mobile-only{display:flex!important}}.email-content{max-width:100%;word-wrap:break-word;overflow-wrap:break-word}.email-content img{max-width:100%;height:auto;display:block;margin:var(--spacing-md) 0}.email-content table{max-width:100%;border-collapse:collapse;margin:var(--spacing-md) 0}.email-content pre{white-space:pre-wrap;word-wrap:break-word;background-color:#f5f5f5;padding:var(--spacing-md);border-radius:4px;overflow-x:auto}.email-content blockquote{border-left:4px solid #e0e0e0;padding-left:var(--spacing-md);margin:var(--spacing-md) 0;color:var(--text-secondary)}.email-content a{color:var(--color-primary);text-decoration:underline}.email-content a:hover{text-decoration:none}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:var(--spacing-md);box-sizing:border-box}.auth-card{background:#fff;border-radius:8px;padding:var(--spacing-2xl);box-shadow:var(--shadow-lg);width:100%;max-width:400px}.auth-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:var(--spacing-xs);text-align:center}.auth-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:center;margin-bottom:var(--spacing-lg)}.auth-footer{margin-top:var(--spacing-lg);text-align:center;font-size:var(--font-size-sm);color:var(--text-secondary)}.auth-footer a{color:var(--color-primary)}.auth-2fa-box{background:var(--bg-secondary);padding:var(--spacing-md);border-radius:8px;margin-bottom:var(--spacing-md);text-align:center}.auth-2fa-icon{font-size:2rem;margin-bottom:var(--spacing-xs)}.auth-2fa-text{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.auth-code-input{text-align:center;font-size:var(--font-size-xl);letter-spacing:.5em;font-family:monospace}.auth-hint{font-size:var(--font-size-xs);color:var(--text-tertiary);text-align:center;margin-top:var(--spacing-xs)}@media(max-width:768px){.auth-container{padding:var(--spacing-sm);align-items:flex-start;padding-top:var(--spacing-2xl)}.auth-card{padding:var(--spacing-lg);border-radius:12px;max-width:100%}.auth-title{font-size:var(--font-size-xl)}}@media(max-width:480px){.auth-container{padding:0;align-items:stretch}.auth-card{min-height:100vh;border-radius:0;display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-lg)}}.container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-md)}.text-center{text-align:center}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}
