.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:2rem}.error-boundary-content{text-align:center;max-width:500px}.error-icon{font-size:4rem;margin-bottom:1rem}.error-boundary h1{color:var(--text-primary);font-size:1.75rem;margin-bottom:.5rem}.error-message{color:var(--text-secondary);margin-bottom:1.5rem}.error-details{text-align:left;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.error-details summary{cursor:pointer;color:var(--text-secondary);font-weight:500;margin-bottom:.5rem}.error-details pre{font-size:.75rem;color:var(--error);overflow-x:auto;white-space:pre-wrap;word-break:break-word}.error-actions{display:flex;gap:1rem;justify-content:center}.error-actions button{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .15s}.error-actions .btn-primary{background:var(--accent-primary);color:#fff;border:none}.error-actions .btn-primary:hover{background:var(--accent-secondary)}.error-actions .btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.error-actions .btn-secondary:hover{background:var(--bg-tertiary)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000026;pointer-events:auto;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-icon{flex-shrink:0;display:flex;align-items:center}.toast-message{flex:1;font-size:.875rem;color:var(--text-primary);line-height:1.4}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:transparent;color:var(--text-secondary);border-radius:4px;cursor:pointer;transition:all .15s ease}.toast-close:hover{background:var(--bg-hover);color:var(--text-primary)}.toast-success{border-left:3px solid var(--success)}.toast-success .toast-icon{color:var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-error .toast-icon{color:var(--danger)}.toast-warning{border-left:3px solid var(--warning)}.toast-warning .toast-icon{color:var(--warning)}.toast-info{border-left:3px solid var(--info)}.toast-info .toast-icon{color:var(--info)}@media(max-width:480px){.toast-container{left:1rem;right:1rem;bottom:1rem;max-width:none}}:root{--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-normal: .25s ease;--modal-radius: 16px;--modal-shadow: 0 25px 60px rgba(0, 0, 0, .4);--modal-overlay-bg: rgba(0, 0, 0, .6);--modal-backdrop-blur: 4px;--modal-width-compact: 400px;--modal-width-sm: 480px;--modal-width-md: 600px;--modal-width-lg: 800px;--modal-width-xl: 1000px;--modal-width-xxl: 1200px;--modal-height-sm: auto;--modal-height-md: auto;--modal-height-lg: auto;--modal-height-xl: auto}:root,[data-theme=dark]{--bg-primary: #18181b;--bg-secondary: #1f1f23;--bg-tertiary: #27272a;--bg-hover: #2e2e33;--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-dim: #71717a;--accent-primary: #a78bfa;--accent-hover: #c4b5fd;--accent-light: #8b5cf6;--text-on-accent: #18181b;--border: #3f3f46;--border-light: #52525b;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--shadow: rgba(0, 0, 0, .4);--shadow-lg: rgba(0, 0, 0, .6);--accent-rgb: 167, 139, 250;--success-rgb: 34, 197, 94;--warning-rgb: 245, 158, 11;--error-rgb: 239, 68, 68;--info-rgb: 59, 130, 246;--bg-card: #1f1f23;--bg-input: #18181b;--text-muted: #71717a;--text-tertiary: #52525b;--accent: var(--accent-primary);--primary: var(--accent-primary);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f4f4f5;--bg-hover: #e4e4e7;--text-primary: #18181b;--text-secondary: #3f3f46;--text-dim: #71717a;--text-muted: #a1a1aa;--text-tertiary: #71717a;--accent-primary: #7c3aed;--accent-hover: #6d28d9;--accent-light: #a78bfa;--text-on-accent: #ffffff;--border: #d4d4d8;--border-light: #e4e4e7;--success: #16a34a;--warning: #d97706;--error: #dc2626;--info: #2563eb;--shadow: rgba(0, 0, 0, .08);--shadow-lg: rgba(0, 0, 0, .15);--accent-rgb: 124, 58, 237;--success-rgb: 22, 163, 74;--warning-rgb: 217, 119, 6;--error-rgb: 220, 38, 38;--info-rgb: 37, 99, 235;--bg-card: #ffffff;--bg-input: #ffffff;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--accent: var(--accent-primary);--primary: var(--accent-primary)}[data-theme=midnight]{--bg-primary: #0a0e27;--bg-secondary: #141a3a;--bg-tertiary: #1e2542;--bg-hover: #252d4f;--text-primary: #e4e7f5;--text-secondary: #a5aed4;--text-dim: #6b7599;--text-muted: #6b7599;--text-tertiary: #5a6385;--accent-primary: #00d9ff;--accent-hover: #33e1ff;--accent-light: #66e9ff;--text-on-accent: #0a0e27;--border: #2a3458;--border-light: #384166;--success: #10b981;--warning: #f59e0b;--error: #f43f5e;--info: #00d9ff;--shadow: rgba(0, 0, 0, .5);--shadow-lg: rgba(0, 0, 0, .7);--accent-rgb: 0, 217, 255;--success-rgb: 16, 185, 129;--warning-rgb: 245, 158, 11;--error-rgb: 244, 63, 94;--info-rgb: 0, 217, 255;--bg-card: #141a3a;--bg-input: #0a0e27;--accent: var(--accent-primary);--primary: var(--accent-primary);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 8px rgba(0, 0, 0, .5)}[data-theme=cosmic]{--bg-primary: #1a1625;--bg-secondary: #241f31;--bg-tertiary: #2d2640;--bg-hover: #362f4a;--text-primary: #f5f0ff;--text-secondary: #c4b5fd;--text-dim: #8b7fad;--text-muted: #8b7fad;--text-tertiary: #6b5f8a;--accent-primary: #c084fc;--accent-hover: #d8b4fe;--accent-light: #e9d5ff;--text-on-accent: #1a1625;--border: #3d3455;--border-light: #4a4065;--success: #4ade80;--warning: #fbbf24;--error: #f87171;--info: #67e8f9;--shadow: rgba(0, 0, 0, .5);--shadow-lg: rgba(0, 0, 0, .7);--accent-rgb: 192, 132, 252;--success-rgb: 74, 222, 128;--warning-rgb: 251, 191, 36;--error-rgb: 248, 113, 113;--info-rgb: 103, 232, 249;--bg-card: #241f31;--bg-input: #1a1625;--cosmic-pink: #ec4899;--cosmic-purple: #a855f7;--cosmic-blue: #3b82f6;--cosmic-cyan: #22d3ee;--cosmic-teal: #14b8a6;--accent: var(--accent-primary);--primary: var(--accent-primary);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 8px rgba(0, 0, 0, .5)}[data-theme=blossom]{--bg-primary: #faf8f5;--bg-secondary: #ffffff;--bg-tertiary: #f5f2ed;--bg-hover: #ebe7e0;--text-primary: #3d3832;--text-secondary: #5c564d;--text-dim: #8a8379;--text-muted: #a9a196;--text-tertiary: #c4bdb3;--accent-primary: #b8860b;--accent-hover: #996f09;--accent-light: #daa520;--text-on-accent: #ffffff;--border: #e5e0d8;--border-light: #f0ece6;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--shadow: rgba(61, 56, 50, .08);--shadow-lg: rgba(61, 56, 50, .12);--accent-rgb: 184, 134, 11;--success-rgb: 34, 197, 94;--warning-rgb: 245, 158, 11;--error-rgb: 239, 68, 68;--info-rgb: 59, 130, 246;--bg-card: #ffffff;--bg-input: #ffffff;--blossom-gold: #d4a854;--blossom-sand: #c2b280;--blossom-taupe: #a89984;--blossom-terracotta: #cc7a5c;--blossom-sage: #9caf88;--accent: var(--accent-primary);--primary: var(--accent-primary);--shadow-sm: 0 1px 3px rgba(61, 56, 50, .06);--shadow-md: 0 4px 6px rgba(61, 56, 50, .08)}*{margin:0;padding:0;box-sizing:border-box;transition:background-color var(--transition-normal),color var(--transition-normal),border-color var(--transition-normal)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5}#root{min-height:100vh;width:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background-color:var(--accent-primary);color:var(--text-on-accent)}[data-theme=cosmic] body{background:radial-gradient(ellipse at 20% 20%,rgba(236,72,153,.05) 0%,transparent 40%),radial-gradient(ellipse at 80% 80%,rgba(59,130,246,.05) 0%,transparent 40%),radial-gradient(ellipse at 50% 50%,rgba(168,85,247,.03) 0%,transparent 50%),var(--bg-primary)}[data-theme=cosmic] ::selection{background:linear-gradient(135deg,#c084fc,#ec4899);color:#1a1625}[data-theme=cosmic] ::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#c084fc66,#ec48994d)}[data-theme=cosmic] ::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#c084fc99,#ec489980)}.btn-primary{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.625rem 1.25rem;background:var(--accent-primary);color:var(--text-on-accent);border:none;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}[data-theme=cosmic] .btn-primary{background:linear-gradient(135deg,#c084fc,#ec4899);box-shadow:0 2px 10px #c084fc4d}[data-theme=cosmic] .btn-primary:hover{background:linear-gradient(135deg,#d8b4fe,#f472b6);box-shadow:0 4px 20px #c084fc66}.btn.btn-primary{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.625rem 1.25rem;background:var(--accent-primary);color:var(--text-on-accent);border:none;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.btn-secondary{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.625rem 1.25rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn.btn-secondary{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.625rem 1.25rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon.btn-edit:hover{color:var(--accent-primary)}.btn-icon.btn-delete:hover{background:rgba(var(--error-rgb),.1);color:var(--error)}.modal-overlay{position:fixed;inset:0;background:var(--modal-overlay-bg);-webkit-backdrop-filter:blur(var(--modal-backdrop-blur));backdrop-filter:blur(var(--modal-backdrop-blur));display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:5vh var(--spacing-lg) var(--spacing-lg);overflow-y:auto;animation:modalOverlayFadeIn .2s ease-out}@keyframes modalOverlayFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--modal-radius);display:grid;grid-template-rows:auto auto 1fr auto;width:100%;box-shadow:var(--modal-shadow);animation:modalSlideIn .25s ease-out;overflow:hidden}.modal.modal-compact{max-width:var(--modal-width-compact);height:auto;max-height:80vh}.modal.modal-sm{max-width:var(--modal-width-sm);height:auto;max-height:85vh}.modal.modal-md{max-width:var(--modal-width-md);height:auto;max-height:85vh}.modal.modal-lg{max-width:var(--modal-width-lg);height:auto;max-height:90vh}.modal.modal-xl{max-width:var(--modal-width-xl);height:auto;max-height:90vh}.modal.modal-xxl{max-width:var(--modal-width-xxl);height:auto;max-height:92vh}.modal.modal-full{max-width:95vw;height:auto;max-height:95vh}.modal.modal-auto{height:auto;max-height:90vh}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.modal-header h2,.modal-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.625rem}.modal-title svg{color:var(--accent-primary);flex-shrink:0}.modal-header-actions{display:flex;align-items:center;gap:.75rem}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-tabs{display:flex;gap:.25rem;padding:0 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);overflow-x:auto;scrollbar-width:none}.modal-tabs::-webkit-scrollbar{display:none}.modal-tab{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--text-primary);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.modal-tab svg{width:18px;height:18px;flex-shrink:0}.modal-tab:hover:not(:disabled){color:var(--accent-primary);background:var(--bg-hover)}.modal-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);font-weight:700}.modal-tab:disabled{opacity:.5;cursor:not-allowed}.modal-tab .badge{background:var(--bg-tertiary);color:var(--text-secondary);padding:.125rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600}.modal-tab.active .badge{background:var(--accent-primary);color:var(--text-on-accent)}.modal-body{flex:1;overflow-y:auto;padding:1.5rem;min-height:0;transition:min-height .15s ease-out}.modal:has(.modal-tabs) .modal-body{min-height:350px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--bg-tertiary)}.modal-footer-left{margin-right:auto}.modal-error{display:flex;align-items:center;gap:.5rem;background:#ef44441a;border:1px solid var(--error);color:var(--error);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.875rem;margin-bottom:1rem}.modal-success{display:flex;align-items:center;gap:.5rem;background:#22c55e1a;border:1px solid var(--success);color:var(--success);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.875rem;margin-bottom:1rem}.form-section{margin-bottom:1.5rem}.form-section:last-child{margin-bottom:0}.form-section-title{font-size:.7rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.form-row{display:grid;gap:1rem;margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.form-row.cols-2{grid-template-columns:repeat(2,1fr)}.form-row.cols-3{grid-template-columns:repeat(3,1fr)}.form-row.cols-4{grid-template-columns:repeat(4,1fr)}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group.full-width{width:100%}.form-group label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.form-group textarea{resize:vertical;min-height:60px}.form-error{background:#ef44441a;color:#dc2626;padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.875rem}.form-field{display:flex;flex-direction:column;gap:.375rem}.form-field.full-width{grid-column:1 / -1}.form-field label{font-size:.875rem;font-weight:600;color:var(--text-primary);letter-spacing:.01em}.form-field label .required{color:var(--error);margin-left:2px}.form-field input,.form-field select,.form-field textarea{padding:.625rem .875rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-fast)}.form-field input:hover:not(:disabled),.form-field select:hover:not(:disabled),.form-field textarea:hover:not(:disabled){border-color:var(--accent-primary);background:var(--bg-secondary)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #7c3aed26}.form-field input:disabled,.form-field select:disabled,.form-field textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-secondary)}.form-field textarea{resize:vertical;min-height:80px}.form-field input[type=number]{-moz-appearance:textfield}.form-field input[type=number]::-webkit-outer-spin-button,.form-field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.form-checkbox-group{display:flex;gap:1rem}.form-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-checkbox input{width:18px;height:18px;cursor:pointer}.form-checkbox span{font-size:.875rem;color:var(--text-primary)}.checkbox-group{display:flex;align-items:center;gap:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400;font-size:.875rem;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.checkbox-label:hover{color:var(--text-secondary)}.type-selector{display:flex;gap:1rem;margin-bottom:1.5rem}.type-option{flex:1;display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-tertiary);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.type-option input{display:none}.type-option:hover{border-color:var(--border-light);background:var(--bg-hover)}.type-option.selected{border-color:var(--accent-primary);background:#7c3aed1a}.type-option-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.type-option.selected .type-option-icon{background:var(--accent-primary);color:var(--text-on-accent)}.type-option-info h4{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 .125rem}.type-option-info p{font-size:.8125rem;color:var(--text-secondary);margin:0}.form-group-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1rem;overflow:visible}.form-group-card:last-child{margin-bottom:0}.form-group-card-title{font-size:.6875rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.75px;margin-bottom:.875rem;opacity:.7}.form-group-card-fields{display:flex;flex-wrap:wrap;gap:.75rem}.form-group-card-fields .form-field{flex:1;min-width:150px}.form-group-card-fields .form-field.small{flex:0 0 120px;min-width:120px}.empty-contacts-new{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.empty-contacts-new svg{color:var(--text-tertiary);opacity:.5}.empty-contacts-new p{margin:0;font-size:1rem;font-weight:500;color:var(--text-primary)}.empty-contacts-new span{font-size:.875rem;color:var(--text-secondary)}.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text-secondary)}.modal-loading .spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.spin,.spinning{animation:spin .8s linear infinite}.modal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem;text-align:center;color:var(--text-secondary)}.modal-empty svg{width:48px;height:48px;opacity:.5}.modal-empty p{font-size:.9375rem}@media(min-width:768px)and (max-width:1023px){.modal-overlay{padding:var(--spacing-lg)}.modal.modal-xl{max-width:95%}.form-row.cols-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.modal-overlay{padding:var(--spacing-sm);align-items:flex-end}.modal{max-height:90vh;max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin-bottom:0}.modal.modal-sm,.modal.modal-md,.modal.modal-lg,.modal.modal-xl{max-width:100%;width:100%}.modal-header,.modal-body{padding:1rem 1.25rem}.modal-footer{padding:.875rem 1.25rem;flex-direction:column-reverse;gap:var(--spacing-sm)}.modal-footer .btn-primary,.modal-footer .btn-secondary{width:100%;justify-content:center}.form-row.cols-2,.form-row.cols-3,.form-row.cols-4{grid-template-columns:1fr}.type-selector{flex-direction:column}.modal-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}}.btn-secondary{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.625rem 1.25rem;background:transparent;color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-light)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.625rem 1.25rem;background:var(--error);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-danger:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-light);color:var(--text-primary)}.btn-icon.btn-icon-danger:hover:not(:disabled){background:#ef44441a;border-color:var(--error);color:var(--error)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.delete-confirmation-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1rem 0}.delete-confirmation-icon{width:64px;height:64px;border-radius:50%;background:#ef44441a;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--error)}.delete-confirmation-message{color:var(--text-secondary);font-size:.9375rem;margin:0;line-height:1.5}.delete-confirmation-message strong{color:var(--text-primary)}.delete-confirmation-error{width:100%;margin-top:1.5rem;background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);overflow:hidden;text-align:left}.delete-error-header{display:flex;align-items:center;gap:.5rem;padding:.75rem;color:var(--error);font-weight:500;font-size:.875rem}.delete-error-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:#0000000d;border:none;border-top:1px solid rgba(239,68,68,.1);color:var(--text-secondary);cursor:pointer;font-size:.875rem}.delete-error-toggle:hover{background:#00000014}.delete-error-details{padding:.75rem;font-size:.875rem;color:var(--text-secondary);border-top:1px solid rgba(239,68,68,.1);background:#00000005}[data-theme=light] input,[data-theme=light] select,[data-theme=light] textarea{background:var(--bg-card);border-color:var(--border)}[data-theme=light] input:focus,[data-theme=light] select:focus,[data-theme=light] textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #7c3aed1a}[data-theme=light] .data-table-container,[data-theme=light] .entry-card,[data-theme=light] .page-header,[data-theme=light] .modal{box-shadow:var(--shadow-sm)}[data-theme=light] .data-table thead{background:var(--bg-tertiary)}[data-theme=light] .data-table th{color:var(--text-secondary);font-weight:600}[data-theme=light] .tab-group{background:var(--bg-tertiary);border-color:var(--border)}[data-theme=light] .tab-btn{color:var(--text-secondary)}[data-theme=light] .tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}[data-theme=light] .tab-btn.active{background:var(--accent-primary);color:var(--text-on-accent)}[data-theme=light] .main-tabs{background:var(--bg-tertiary)}[data-theme=light] .main-tab{color:var(--text-secondary)}[data-theme=light] .main-tab:hover{background:var(--bg-hover);color:var(--text-primary)}[data-theme=light] .main-tab.active{background:var(--accent-primary);color:var(--text-on-accent)}[data-theme=light] .search-dropdown,[data-theme=light] .column-filter-dropdown{background:var(--bg-card);box-shadow:var(--shadow-md);border-color:var(--border)}[data-theme=light] .status-badge.active{background:#16a34a26;color:#15803d}[data-theme=light] .status-badge.inactive{background:#71717a26;color:#52525b}[data-theme=light] .type-badge.customer{background:#2563eb1f;color:#1d4ed8}[data-theme=light] .type-badge.supplier{background:#16a34a1f;color:#15803d}[data-theme=light] .type-btn{background:var(--bg-card);border-color:var(--border)}[data-theme=light] .type-btn.success{color:#15803d}[data-theme=light] .type-btn.error{color:#b91c1c}[data-theme=light] .type-btn.info{color:#1d4ed8}[data-theme=light] .type-btn.success.active{border-color:#16a34a;background:#16a34a1f}[data-theme=light] .type-btn.error.active{border-color:#dc2626;background:#dc26261f}[data-theme=light] .type-btn.info.active{border-color:#2563eb;background:#2563eb1f}[data-theme=light] .entry-card{background:var(--bg-card)}[data-theme=light] .entry-card-header{background:var(--bg-tertiary)}[data-theme=light] .recent-section,[data-theme=light] .section-header{background:var(--bg-card)}[data-theme=light] .recent-list{background:var(--bg-secondary)}[data-theme=light] .search-field,[data-theme=light] .warehouse-select,[data-theme=light] .qty-input input{background:var(--bg-card);border-color:var(--border)}[data-theme=light] .qty-unit{background:var(--bg-tertiary);border-color:var(--border)}[data-theme=light] .submit-btn:disabled{opacity:.6;background:var(--text-dim)}[data-theme=light] .modal-tabs{background:var(--bg-secondary)}[data-theme=light] .modal-tab.active{color:var(--accent-primary)}[data-theme=light] .data-table-pagination{background:var(--bg-tertiary)}[data-theme=light] .pagination-btn{background:var(--bg-card);border-color:var(--border)}[data-theme=light] .pagination-btn:hover:not(:disabled){background:var(--bg-hover)}[data-theme=light] .column-settings-dropdown{background:var(--bg-card);box-shadow:var(--shadow-md)}[data-theme=light] .empty-state,[data-theme=light] .empty-recent,[data-theme=light] .no-stock-selected{color:var(--text-muted)}[data-theme=light] .group-badge{background:#7c3aed1a;color:#6d28d9}[data-theme=light] .selected-chip{background:#7c3aed14;border-color:var(--accent-primary)}[data-theme=light] .party-code,[data-theme=light] .stock-code,[data-theme=light] .chip-code,[data-theme=light] .item-code{color:var(--accent-primary)}[data-theme=light] ::-webkit-scrollbar-track{background:var(--bg-tertiary)}[data-theme=light] ::-webkit-scrollbar-thumb{background:var(--border)}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.page-layout{max-width:100%;display:flex;flex-direction:column;height:100%;min-height:0}.page-layout>.data-table-container{flex:1;min-height:0;display:flex;flex-direction:column}.page-layout>.data-table-container .data-table-scroll-container{flex:1;min-height:0}.page-loading{display:flex;justify-content:center;align-items:center;min-height:300px;color:var(--text-secondary);font-size:.875rem}.page-loading svg{animation:spin 1s linear infinite}.page-error{display:flex;align-items:center;gap:.5rem;background:rgba(var(--error-rgb),.1);border:1px solid var(--error);color:var(--error);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.875rem}.page-error svg{flex-shrink:0}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.status-badge.active,.status-badge.approved,.status-badge.completed,.status-badge.delivered,.status-badge.paid{background:rgba(var(--success-rgb),.15);color:var(--success)}.status-badge.pending,.status-badge.draft,.status-badge.partial{background:rgba(var(--warning-rgb),.15);color:var(--warning)}.status-badge.confirmed,.status-badge.sent,.status-badge.shipped{background:rgba(var(--info-rgb),.15);color:var(--info)}.status-badge.inactive,.status-badge.rejected,.status-badge.cancelled,.status-badge.overdue{background:rgba(var(--error-rgb),.15);color:var(--error)}.status-badge.default{background:rgba(var(--accent-rgb),.15);color:var(--accent-primary)}.type-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.type-badge.customer{background:rgba(var(--info-rgb),.15);color:var(--info)}.type-badge.supplier,.type-badge.income{background:rgba(var(--success-rgb),.15);color:var(--success)}.type-badge.expense{background:rgba(var(--error-rgb),.15);color:var(--error)}.row-actions{display:flex;gap:.5rem;justify-content:flex-end;align-items:center}.btn-icon.btn-icon-sm{width:28px;height:28px}.btn-icon.btn-icon-lg{width:40px;height:40px}.btn-icon.btn-icon-danger:hover{background:rgba(var(--error-rgb),.1);color:var(--error)}.btn-icon.btn-icon-success:hover{background:rgba(var(--success-rgb),.1);color:var(--success)}.btn-icon.btn-icon-info:hover{background:rgba(var(--info-rgb),.1);color:var(--info)}.btn-icon.btn-icon-warning:hover{background:rgba(var(--warning-rgb),.1);color:var(--warning)}.amount-cell{font-family:Courier New,Consolas,monospace;font-weight:600;font-size:.875rem;white-space:nowrap}.amount-cell.positive,.amount-cell.incoming{color:var(--success)}.amount-cell.negative,.amount-cell.outgoing{color:var(--error)}.code-cell{font-family:Courier New,Consolas,monospace;font-weight:600;font-size:.8125rem;color:var(--accent-primary);background:rgba(var(--accent-rgb),.08);padding:.25rem .5rem;border-radius:var(--radius-sm)}.icon-cell{display:flex;align-items:center;gap:.5rem}.icon-cell svg{flex-shrink:0;color:var(--text-secondary)}.flow-type-selector{display:flex;gap:.5rem}.flow-type-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.flow-type-btn:hover{background:var(--bg-hover);border-color:var(--border-light)}.flow-type-btn.income.selected{background:rgba(var(--success-rgb),.15);border-color:var(--success);color:var(--success)}.flow-type-btn.expense.selected{background:rgba(var(--error-rgb),.15);border-color:var(--error);color:var(--error)}.overdue{color:var(--error);font-weight:600}.revision-badge{font-size:.65rem;font-weight:600;padding:.125rem .375rem;border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary)}.login-container{min-height:100vh;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;overflow:hidden;z-index:0}.login-bg-shape{position:absolute;border-radius:50%;background:rgba(var(--accent-rgb),.15);filter:blur(60px)}.login-bg-shape-1{width:600px;height:600px;top:-200px;right:-100px;background:rgba(var(--accent-rgb),.2)}.login-bg-shape-2{width:500px;height:500px;bottom:-150px;left:-150px;background:rgba(var(--info-rgb),.15)}.login-bg-shape-3{width:400px;height:400px;top:50%;left:30%;background:rgba(var(--success-rgb),.1)}[data-theme=cosmic] .login-bg-shape-1{background:#ec489959;filter:blur(80px)}[data-theme=cosmic] .login-bg-shape-2{background:#3b82f64d;filter:blur(80px)}[data-theme=cosmic] .login-bg-shape-3{background:#22d3ee40;filter:blur(80px)}[data-theme=cosmic] .login-bg:before{content:"";position:absolute;width:450px;height:450px;bottom:20%;right:10%;background:#a855f74d;border-radius:50%;filter:blur(80px)}[data-theme=cosmic] .login-bg:after{content:"";position:absolute;width:350px;height:350px;top:30%;left:10%;background:#14b8a633;border-radius:50%;filter:blur(80px)}[data-theme=blossom] .login-bg-shape-1{background:#d4a85440;filter:blur(100px)}[data-theme=blossom] .login-bg-shape-2{background:#c2b2804d;filter:blur(100px)}[data-theme=blossom] .login-bg-shape-3{background:#9caf8833;filter:blur(100px)}[data-theme=blossom] .login-bg:before{content:"";position:absolute;width:500px;height:500px;bottom:10%;right:5%;background:#cc7a5c26;border-radius:50%;filter:blur(100px)}[data-theme=blossom] .login-bg:after{content:"";position:absolute;width:400px;height:400px;top:20%;left:5%;background:#a8998433;border-radius:50%;filter:blur(100px)}[data-theme=blossom] .login-card{background:#ffffffe6;border:1px solid rgba(229,224,216,.8);box-shadow:0 25px 80px #3d38321a,0 0 40px #b8860b0d}[data-theme=blossom] .login-button{background:linear-gradient(135deg,#d4a854,#b8860b);border:none;color:#fff}[data-theme=blossom] .login-button:hover:not(:disabled){background:linear-gradient(135deg,#daa520,#996f09);box-shadow:0 4px 20px #b8860b4d}.login-content{display:flex;align-items:center;gap:100px;position:relative;z-index:1;width:100%;max-width:1100px}.login-branding{flex:1;color:var(--text-primary)}.brand-logo{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:3rem}.brand-logo-icon{width:44px;height:44px;background:transparent;border:2px solid var(--accent-color);border-radius:50%;display:flex;align-items:center;justify-content:center}.brand-logo-icon svg{color:var(--accent-color)}.brand-logo span{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;color:var(--text-primary)}.login-branding h1{font-size:3rem;font-weight:700;line-height:1.15;margin-bottom:var(--spacing-md);color:var(--text-primary)}.login-branding p{font-size:1.1rem;color:var(--text-secondary);line-height:1.6}.login-card{background:var(--bg-secondary);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:20px;padding:3rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg);transition:transform .3s ease,opacity .3s ease}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-form .form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:0;background:transparent;padding:0;border:none;border-radius:0;box-shadow:none}.login-form .form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary);background:transparent}.login-form .form-group input{padding:.875rem 1rem!important;border:1px solid var(--border-color)!important;border-radius:10px!important;font-size:1rem!important;color:var(--text-primary)!important;background:var(--bg-tertiary)!important;transition:all .2s}.login-form .form-group input::placeholder{color:var(--text-muted)!important}.login-form .form-group input:hover{border-color:var(--accent-color-alpha)!important}.login-form .form-group input:focus{outline:none!important;border-color:var(--accent-color)!important;box-shadow:0 0 0 3px var(--accent-color-alpha)!important;background:var(--bg-tertiary)!important}.login-form .login-error{background:#dc262626;border:1px solid rgba(220,38,38,.3);color:var(--color-error);padding:1rem;border-radius:10px;font-size:.875rem}.form-actions{display:flex;align-items:center;justify-content:flex-end;margin-top:.5rem}.login-button{background:transparent;color:var(--accent-color);border:2px solid var(--accent-color);padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.login-button:hover:not(:disabled){background:var(--accent-color);color:var(--accent-contrast)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{position:absolute;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);color:var(--text-muted);font-size:.8rem;z-index:1}.login-success-overlay{position:fixed;inset:0;background:var(--bg-primary);z-index:1000;display:flex;align-items:center;justify-content:center;animation:overlayZoomIn .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes overlayZoomIn{0%{opacity:0;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.success-animation{display:flex;flex-direction:column;align-items:center;animation:contentPop .4s cubic-bezier(.34,1.56,.64,1) .1s both}@keyframes contentPop{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}.success-check{width:120px;height:120px;background:var(--accent-color);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;animation:checkBounce .5s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes checkBounce{0%{transform:scale(0)}60%{transform:scale(1.15)}to{transform:scale(1)}}.success-check svg{color:var(--accent-contrast);animation:checkIcon .3s ease .5s both}@keyframes checkIcon{0%{opacity:0;transform:scale(.5) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}}.success-text{color:var(--text-primary);font-size:1.5rem;font-weight:600;opacity:0;animation:textSlideUp .4s ease .6s forwards}@keyframes textSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-container.logging-in .login-card{transform:scale(.97);opacity:.7}@media(max-width:1000px){.login-content{flex-direction:column;gap:3rem;text-align:center}.login-branding{max-width:420px}.login-branding h1{font-size:2.25rem}.brand-logo{justify-content:center;margin-bottom:2rem}}@media(max-width:480px){.login-container{padding:var(--spacing-md)}.login-card{padding:2rem 1.5rem;border-radius:16px}.login-branding h1{font-size:1.75rem}.login-branding p{font-size:1rem}.success-check{width:100px;height:100px}}.sidebar{width:260px;height:100vh;height:100dvh;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100;transition:all .2s ease}.sidebar.drawer{width:280px;box-shadow:4px 0 20px #0000004d;animation:slideIn .25s ease}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.sidebar.compact{width:220px;font-size:.9em}.sidebar.collapsed{width:64px}.sidebar-header{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;height:56px;gap:var(--spacing-sm)}.sidebar.compact .sidebar-header{height:48px}.sidebar.collapsed .sidebar-header{padding:var(--spacing-sm);flex-direction:column;height:auto;gap:var(--spacing-xs)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--accent-primary);font-size:1.1rem;font-weight:700;white-space:nowrap;overflow:hidden}.sidebar.compact .sidebar-logo{font-size:1rem;gap:6px}.sidebar.collapsed .sidebar-logo{justify-content:center}.header-actions{display:flex;gap:4px}.header-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .2s}.header-btn:hover{background:var(--bg-hover);color:var(--accent-primary)}.expand-btn{margin-top:var(--spacing-xs)}.sidebar-nav{flex:1;min-height:0;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden}.sidebar.compact .sidebar-nav{padding:var(--spacing-xs);gap:1px}.nav-group{display:flex;flex-direction:column;gap:1px}.nav-group-label{font-size:.65rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-xs) var(--spacing-sm);margin-top:var(--spacing-xs)}.sidebar.compact .nav-group-label{font-size:.6rem;padding:2px var(--spacing-xs);margin-top:2px}.sidebar.collapsed .nav-group-label{display:none}.nav-group-divider{height:1px;background:var(--border);margin:var(--spacing-xs) var(--spacing-sm)}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:.5rem var(--spacing-sm);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative;white-space:nowrap;font-size:.9rem}.sidebar.collapsed .nav-item{justify-content:center;padding:.6rem}.sidebar.compact .nav-item{padding:.35rem var(--spacing-xs);gap:6px;font-size:.8rem}.nav-item svg{flex-shrink:0}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-tertiary);color:var(--accent-primary);font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:25%;bottom:25%;width:3px;background:var(--accent-primary);border-radius:0 2px 2px 0}.sidebar.compact .nav-item.active:before{width:2px}.sidebar-footer{padding:var(--spacing-sm);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar.compact .sidebar-footer{padding:var(--spacing-xs);gap:2px}.sidebar.collapsed .sidebar-footer{padding:var(--spacing-xs)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden}.sidebar.collapsed .user-info{justify-content:center;padding:var(--spacing-xs)}.sidebar.compact .user-info{padding:4px var(--spacing-xs);gap:6px}.user-info svg{flex-shrink:0}.user-details{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.user-name{color:var(--text-primary);font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.compact .user-name{font-size:.75rem}.user-username{font-size:.75rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.compact .user-username{font-size:.65rem}.sidebar-footer-actions{display:flex;flex-direction:column;gap:var(--spacing-xs)}.footer-action-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:.4rem var(--spacing-sm);background:transparent;border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;white-space:nowrap}.sidebar.compact .footer-action-button{padding:.3rem var(--spacing-xs);gap:6px;font-size:.75rem}.sidebar.collapsed .footer-action-button{justify-content:center;padding:.5rem}.footer-action-button svg{flex-shrink:0}.footer-action-button:hover{background:#3b82f61a;border-color:var(--accent-primary);color:var(--accent-primary)}.logout-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:.4rem var(--spacing-sm);background:transparent;border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;white-space:nowrap}.sidebar.compact .logout-button{padding:.3rem var(--spacing-xs);gap:6px;font-size:.75rem}.sidebar.collapsed .logout-button{justify-content:center;padding:.5rem}.logout-button svg{flex-shrink:0}.logout-button:hover{background:#dc26261a;border-color:var(--error);color:var(--error)}@media(max-height:700px){.sidebar-header{height:48px}.sidebar-nav{padding:var(--spacing-xs)}.nav-item{padding:.4rem var(--spacing-xs)}.user-info{padding:var(--spacing-xs) var(--spacing-sm)}}[data-theme=cosmic] .sidebar{background:linear-gradient(180deg,#241f31fa,#1a1625fa);border-right-color:#3d345580}[data-theme=cosmic] .sidebar:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top left,rgba(236,72,153,.08) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(59,130,246,.08) 0%,transparent 50%);pointer-events:none;z-index:0}[data-theme=cosmic] .sidebar>*{position:relative;z-index:1}[data-theme=cosmic] .sidebar-logo{background:linear-gradient(135deg,#c084fc,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=cosmic] .nav-item.active{background:linear-gradient(135deg,#c084fc26,#ec48991a);border-left-color:#c084fc}[data-theme=cosmic] .nav-item:hover:not(.active){background:#c084fc14}[data-theme=cosmic] .header-btn:hover{background:#c084fc26;color:#c084fc}.sidebar.drawer .sidebar-header{justify-content:space-between}.sidebar.drawer .close-btn{color:var(--text-secondary)}.sidebar.drawer .close-btn:hover{background:var(--bg-hover);color:var(--error)}.drawer-actions{padding:var(--spacing-sm) 0;border-top:1px solid var(--border);margin-bottom:var(--spacing-sm)}.drawer-action-btn{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.drawer-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar.drawer .nav-item{padding:var(--spacing-md) var(--spacing-md);min-height:48px}.sidebar.drawer .nav-group-label{padding:var(--spacing-sm) var(--spacing-md)}@media(hover:none)and (pointer:coarse){.sidebar .nav-item{min-height:48px}.sidebar .header-btn{min-width:44px;min-height:44px}.sidebar .logout-button{min-height:48px}}.app-layout{display:flex;min-height:100vh;height:100vh;background:var(--bg-primary);overflow:hidden}.main-content{flex:1;margin-left:260px;padding:var(--spacing-xl);overflow-y:auto;transition:margin-left .2s ease;display:flex;flex-direction:column;min-height:0}.main-content.compact{margin-left:220px}.main-content.collapsed{margin-left:64px}.main-content.full-width{margin-left:0;padding-top:60px}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:90;align-items:center;padding:0 var(--spacing-md);gap:var(--spacing-md)}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.mobile-menu-btn:hover{background:var(--bg-hover)}.mobile-menu-btn:active{background:var(--bg-tertiary)}.mobile-header-title{font-size:1.125rem;font-weight:700;color:var(--accent-primary)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:95;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(min-width:768px)and (max-width:1023px){.app-layout.tablet .mobile-header{display:flex}.app-layout.tablet .sidebar-overlay{display:block}.app-layout.tablet .main-content{margin-left:0;padding:var(--spacing-md);padding-top:calc(56px + var(--spacing-md));overflow-x:hidden;min-height:calc(100vh - 56px);min-height:calc(100dvh - 56px)}}@media(max-width:767px){.app-layout.mobile .mobile-header{display:flex}.app-layout.mobile .sidebar-overlay{display:block}.app-layout.mobile .main-content{margin-left:0;padding:var(--spacing-md);padding-top:calc(56px + var(--spacing-md))}}@media(max-width:1023px){.mobile-header{display:flex}.sidebar-overlay{display:block}}.widget-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;transition:all .2s ease}.widget-container:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.widget-container-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border);min-height:44px}.widget-title{margin:0;font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-actions{display:flex;align-items:center;gap:.25rem}.widget-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:all .15s ease}.widget-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.widget-action-btn:disabled{opacity:.5;cursor:not-allowed}.widget-action-btn.spinning svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.widget-menu-wrapper{position:relative}.widget-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);min-width:180px;max-height:320px;overflow-y:auto;z-index:1000}.widget-menu button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .875rem;border:none;background:transparent;color:var(--text-primary);font-size:.8125rem;text-align:left;cursor:pointer;transition:background .15s}.widget-menu button:hover{background:var(--bg-hover)}.widget-menu button.danger{color:var(--danger)}.widget-menu button.danger:hover{background:#ef44441a}.widget-container-content{flex:1;padding:1rem;overflow:auto;display:flex;flex-direction:column}.widget-loading{flex:1;display:flex;align-items:center;justify-content:center}.widget-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.widget-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--text-secondary);font-size:.8125rem;text-align:center}.widget-error button{padding:.375rem .75rem;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);font-size:.75rem;border-radius:6px;cursor:pointer;transition:all .15s}.widget-error button:hover{background:var(--bg-hover);border-color:var(--primary)}.widget-drag-handle{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:transparent;color:var(--text-dim);border-radius:4px;cursor:grab;transition:all .15s ease;flex-shrink:0}.widget-drag-handle:hover{background:var(--bg-hover);color:var(--text-primary)}.widget-drag-handle:active{cursor:grabbing}.widget-container.dragging{box-shadow:0 8px 32px #0000004d;border-color:var(--primary)}.widget-menu-divider{height:1px;background:var(--border);margin:.25rem 0}.widget-menu-header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .875rem;border:none;background:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;text-align:left;cursor:pointer;transition:background .15s}.widget-menu-header:hover{background:var(--bg-hover);color:var(--text-primary)}.widget-menu-header .submenu-arrow{margin-left:auto;font-size:.625rem;color:var(--text-dim)}.widget-size-options{display:flex;flex-direction:column;padding:0 .25rem}.widget-size-options .size-option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;margin:.125rem 0;border:none;background:var(--bg-tertiary);color:var(--text-primary);font-size:.8125rem;text-align:left;border-radius:6px;cursor:pointer;transition:all .15s}.widget-size-options .size-option:hover{background:var(--bg-hover)}.widget-size-options .size-option.active{background:rgba(var(--accent-rgb),.15);color:var(--accent-primary)}.widget-size-options .size-option .size-icon{width:18px;text-align:center;font-size:.875rem}.widget-size-options .size-option .size-dims{margin-left:auto;font-size:.6875rem;color:var(--text-dim);font-family:monospace}.widget-resize-handle{position:absolute;bottom:0;right:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--bg-tertiary);cursor:nwse-resize;opacity:.7;transition:opacity .15s ease,background .15s ease,transform .15s ease;border-radius:8px 0 12px;z-index:10;border-left:1px solid var(--border);border-top:1px solid var(--border)}.widget-container:hover .widget-resize-handle{opacity:1}.widget-resize-handle:hover{opacity:1!important;background:var(--primary);color:#fff;transform:scale(1.1)}.widget-container.resizing{z-index:100;box-shadow:var(--shadow-xl);border-color:var(--primary)}.widget-container.resizing .widget-resize-handle{opacity:1;background:var(--primary);color:#fff}.widget-resize-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--primary);color:#fff;padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600;font-family:monospace;pointer-events:none;z-index:20;box-shadow:var(--shadow-lg)}.widget-container{position:relative}.widget-error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:150px;padding:1.5rem;text-align:center;background:linear-gradient(135deg,#fff5f5,#fed7d7);border-radius:8px;gap:1rem}.widget-error-icon{color:#e53e3e;opacity:.8}.widget-error-content{display:flex;flex-direction:column;gap:.5rem}.widget-error-title{margin:0;font-size:1rem;font-weight:600;color:#c53030}.widget-error-message{margin:0;font-size:.875rem;color:#742a2a;opacity:.9}.widget-error-details{margin-top:.5rem;text-align:left;font-size:.75rem;color:#742a2a}.widget-error-details summary{cursor:pointer;font-weight:500;margin-bottom:.25rem}.widget-error-details pre{margin:0;padding:.5rem;background:#0000000d;border-radius:4px;overflow-x:auto;white-space:pre-wrap;word-break:break-word;font-family:Monaco,Consolas,monospace;font-size:.7rem}.widget-error-retry-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#e53e3e;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.widget-error-retry-btn:hover{background:#c53030;transform:translateY(-1px)}.widget-error-retry-btn:active{transform:translateY(0)}.widget-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary);font-size:.8125rem;text-align:center}.widget-empty-state.success,.widget-empty-state .success-icon{color:var(--success)}.widget-empty-state .warning-icon{color:var(--warning)}.widget-currency-list{display:flex;flex-direction:column;gap:.75rem}.currency-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem;background:var(--bg-tertiary);border-radius:8px}.currency-info{display:flex;align-items:center;gap:.5rem}.currency-icon{color:var(--primary)}.currency-code{font-weight:600;font-size:.875rem}.currency-rate{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.rate-value{font-weight:600;font-size:.9375rem}.rate-change{display:flex;align-items:center;gap:.25rem;font-size:.75rem}.rate-change.positive{color:var(--success)}.rate-change.negative{color:var(--danger)}.widget-tcmb-list{display:flex;flex-direction:column;gap:.75rem}.tcmb-row{display:flex;flex-direction:column;gap:.375rem;padding:.5rem;background:var(--bg-tertiary);border-radius:8px}.tcmb-info{display:flex;align-items:center;gap:.5rem}.tcmb-icon{color:var(--info)}.tcmb-code{font-weight:600;font-size:.875rem}.tcmb-rates{display:flex;gap:1rem}.tcmb-rate{display:flex;flex-direction:column;gap:.125rem}.tcmb-rate .rate-label{font-size:.6875rem;color:var(--text-secondary);text-transform:uppercase}.tcmb-rate .rate-value{font-size:.8125rem;font-weight:500}.machine-grid-widget{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.machine-card{padding:.625rem;background:var(--bg-tertiary);border-radius:8px;border-left:3px solid var(--border)}.machine-card.online{border-left-color:var(--success)}.machine-card.offline{border-left-color:var(--danger);opacity:.7}.machine-card-header{display:flex;align-items:center;gap:.375rem;margin-bottom:.375rem}.machine-card-header svg:first-child{color:var(--text-secondary)}.machine-code{flex:1;font-weight:600;font-size:.75rem}.status-online{color:var(--success)}.status-offline{color:var(--danger)}.machine-card-body{display:flex;flex-direction:column;gap:.125rem}.machine-name{font-size:.6875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.machine-last-seen{font-size:.625rem;color:var(--text-tertiary)}.workorder-summary-widget{display:flex;justify-content:space-around;align-items:center;height:100%}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem}.stat-item svg{color:var(--text-secondary)}.stat-item.pending svg{color:var(--warning)}.stat-item.in-progress svg{color:var(--info)}.stat-item.completed svg{color:var(--success)}.stat-value{font-size:1.5rem;font-weight:700}.stat-item.pending .stat-value{color:var(--warning)}.stat-item.in-progress .stat-value{color:var(--info)}.stat-item.completed .stat-value{color:var(--success)}.stat-label{font-size:.6875rem;color:var(--text-secondary)}.due-cheque-widget{display:flex;flex-direction:column;gap:.75rem}.cheque-summary{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#fbbf241a;border-radius:8px}.cheque-summary .warning-icon{color:var(--warning)}.cheque-count{font-weight:600}.cheque-total{margin-left:auto;font-weight:600;color:var(--warning)}.cheque-list{display:flex;flex-direction:column;gap:.5rem}.cheque-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;background:var(--bg-tertiary);border-radius:6px;font-size:.8125rem}.cheque-info{display:flex;align-items:center;gap:.375rem}.cheque-no{font-weight:500}.cheque-details{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.cheque-amount{font-weight:600;font-size:.75rem}.cheque-date{display:flex;align-items:center;gap:.25rem;font-size:.6875rem;color:var(--text-secondary)}.cheque-more{font-size:.75rem;color:var(--text-secondary);text-align:center}.low-stock-widget{display:flex;flex-direction:column;gap:.75rem}.stock-alert-header{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#ef44441a;border-radius:8px}.stock-alert-header .warning-icon{color:var(--danger)}.alert-count{font-size:1.25rem;font-weight:700;color:var(--danger)}.alert-text{font-size:.8125rem;color:var(--text-secondary)}.stock-list{display:flex;flex-direction:column;gap:.375rem}.stock-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;background:var(--bg-tertiary);border-radius:6px}.stock-info{display:flex;align-items:center;gap:.375rem}.stock-code{font-size:.8125rem;font-weight:500}.stock-levels{display:flex;align-items:center;gap:.25rem;font-size:.75rem}.stock-current{color:var(--danger);font-weight:600}.stock-separator{color:var(--text-tertiary)}.stock-minimum{color:var(--text-secondary)}.stock-more{font-size:.75rem;color:var(--text-secondary);text-align:center}.party-summary-widget{display:flex;flex-direction:column;gap:.75rem;height:100%}.party-counts{display:flex;justify-content:space-around;flex:1}.party-count{display:flex;flex-direction:column;align-items:center;gap:.25rem}.customer-icon{color:var(--info)}.supplier-icon{color:var(--primary)}.count-value{font-size:1.5rem;font-weight:700}.count-label{font-size:.6875rem;color:var(--text-secondary)}.party-balance{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg-tertiary);border-radius:8px}.balance-label{font-size:.8125rem;color:var(--text-secondary)}.balance-value{display:flex;align-items:center;gap:.25rem;font-weight:600}.balance-value.positive{color:var(--success)}.balance-value.negative{color:var(--danger)}.system-health-widget{display:flex;flex-direction:column;gap:.625rem}.health-item{display:flex;align-items:center;gap:.5rem}.health-item svg{color:var(--text-secondary);flex-shrink:0}.health-bar{flex:1;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.health-bar-fill{height:100%;background:var(--success);border-radius:4px;transition:width .3s ease}.health-item.warning .health-bar-fill{background:var(--warning)}.health-item.critical .health-bar-fill{background:var(--danger)}.health-value{font-size:.75rem;font-weight:600;min-width:32px;text-align:right}.uptime{font-size:.6875rem;color:var(--text-secondary);text-align:center;margin-top:.25rem}.clock-widget{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:.25rem}.clock-time{font-size:2rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.clock-date{font-size:.75rem;color:var(--text-secondary);text-transform:capitalize}.quick-links-widget{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.quick-links-widget.wide{grid-template-columns:repeat(4,1fr)}.quick-link{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.625rem;background:var(--bg-tertiary);border-radius:8px;text-decoration:none;color:var(--text-primary);transition:all .15s ease}.quick-link:hover{background:var(--bg-hover);transform:translateY(-2px)}.quick-link-icon{color:var(--primary)}.quick-link-label{font-size:.6875rem;font-weight:500;text-align:center}.widget-container.has-alert{border-color:var(--warning)}.widget-container.has-warning{border-color:var(--danger)}.widget-grid{display:grid;gap:1rem;margin-bottom:1.5rem;grid-auto-flow:dense;max-width:1600px;margin-left:auto;margin-right:auto}.widget-grid.compact{gap:.75rem}.widget-grid-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:var(--bg-secondary);border:2px dashed var(--border);border-radius:12px;color:var(--text-secondary);text-align:center}.widget-grid-empty p{margin:.25rem 0}.widget-grid-empty p:first-child{font-weight:600;color:var(--text-primary)}.widget-unknown{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:.8125rem;text-align:center}@media(max-width:1200px){.widget-grid{grid-template-columns:repeat(3,1fr)!important}}@media(max-width:900px){.widget-grid{grid-template-columns:repeat(2,1fr)!important}}@media(max-width:600px){.widget-grid{grid-template-columns:1fr!important}}.widget-drag-overlay{opacity:.95;cursor:grabbing;pointer-events:none}.widget-drag-overlay .widget-container{width:100%;height:100%;box-shadow:0 12px 40px #0006;border-color:var(--primary);transform:scale(1.02)}.widget-grid.is-dragging .widget-container:not(.dragging){transition:all .2s ease}.widget-grid.is-dragging .widget-container:not(.dragging):hover{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.3);transform:scale(.98)}.widget-container.dragging{opacity:.3!important;border-style:dashed!important;background:var(--bg-tertiary)}.add-widget-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:85vh;background:var(--bg-secondary);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;z-index:1001}.add-widget-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.add-widget-modal .modal-header h2{font-size:1.125rem;font-weight:600;margin:0}.modal-search{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border)}.modal-search svg{color:var(--text-secondary)}.modal-search input{flex:1;background:transparent;border:none;font-size:.9375rem;color:var(--text-primary);outline:none}.modal-search input::placeholder{color:var(--text-tertiary)}.category-filter{display:flex;gap:.5rem;padding:.75rem 1.25rem;overflow-x:auto;border-bottom:1px solid var(--border)}.category-chip{padding:.375rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:999px;font-size:.75rem;font-weight:500;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .15s ease}.category-chip:hover{background:var(--bg-hover);color:var(--text-primary)}.category-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.widget-list{flex:1;overflow-y:auto;padding:1rem 1.25rem}.widget-group{margin-bottom:1.25rem}.widget-group:last-child{margin-bottom:0}.widget-group-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.widget-group-items{display:flex;flex-direction:column;gap:.5rem}.widget-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;transition:all .15s ease}.widget-item:hover{border-color:var(--primary-light)}.widget-item-info{flex:1;min-width:0}.widget-item-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.widget-name{font-weight:600;font-size:.875rem}.widget-size{padding:.125rem .375rem;background:var(--bg-tertiary);border-radius:4px;font-size:.6875rem;color:var(--text-secondary)}.widget-description{font-size:.8125rem;color:var(--text-secondary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.widget-item .btn-sm{flex-shrink:0;padding:.375rem .75rem;font-size:.75rem}.widget-item .btn-loading{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.widget-list-empty{text-align:center;padding:2rem;color:var(--text-secondary)}.settings-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:480px;background:var(--bg-secondary);border-radius:16px;display:flex;flex-direction:column;z-index:1001}.settings-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.settings-modal .modal-header h2{font-size:1.125rem;font-weight:600;margin:0}.settings-modal .modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:1.5rem}.setting-group{display:flex;flex-direction:column;gap:.5rem}.setting-label{font-weight:600;font-size:.9375rem}.setting-description{font-size:.8125rem;color:var(--text-secondary);margin:0}.setting-control{display:flex;align-items:center;gap:1rem;margin-top:.25rem}.setting-control input[type=range]{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;appearance:none;cursor:pointer}.setting-control input[type=range]::-webkit-slider-thumb{appearance:none;width:18px;height:18px;background:var(--primary);border-radius:50%;cursor:pointer;transition:transform .15s ease}.setting-control input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.range-value{min-width:70px;font-size:.875rem;font-weight:500;text-align:right}.setting-control select{flex:1;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;font-size:.875rem;color:var(--text-primary);cursor:pointer}.setting-control select:focus{outline:none;border-color:var(--primary)}.column-preview{display:flex;gap:4px;height:24px;margin-top:.5rem}.preview-column{flex:1;background:var(--primary-light);border-radius:4px;opacity:.6}.settings-modal .modal-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-top:1px solid var(--border)}.footer-right{display:flex;gap:.5rem}.settings-modal .btn-loading{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.dashboard{max-width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:var(--spacing-xl)}.dashboard-header-left h1{font-size:1.75rem;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.dashboard-header-left p{color:var(--text-secondary);font-size:.9375rem;margin:0}.dashboard-header-actions{display:flex;gap:.5rem;align-items:center}.dashboard-user-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.info-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-normal)}.info-card:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #7c3aed1a}.card-icon{color:var(--accent-primary);margin-bottom:var(--spacing-md)}.info-card h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.card-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.card-content p{color:var(--text-secondary);font-size:.875rem;line-height:1.6;margin:0}.card-content strong{color:var(--text-primary);font-weight:500}.permission-list{list-style:none;padding-left:var(--spacing-md);margin-top:var(--spacing-sm);max-height:200px;overflow-y:auto}.permission-list li{padding:var(--spacing-xs) 0;color:var(--text-secondary);font-size:.8125rem;font-family:Courier New,monospace}.permission-list li:before{content:"→ ";color:var(--accent-primary);margin-right:var(--spacing-xs)}details{margin-top:var(--spacing-md)}summary{cursor:pointer;color:var(--accent-primary);font-weight:500;-webkit-user-select:none;user-select:none;padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast)}summary:hover{background:var(--bg-tertiary)}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;color:var(--text-secondary)}.dashboard-loading .spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;text-align:center;color:var(--danger)}.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.dashboard-empty svg{color:var(--text-tertiary);opacity:.5}.dashboard-empty h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.dashboard-empty p{margin:0}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}@media(max-width:768px){.dashboard-header{flex-direction:column}.dashboard-header-actions{width:100%;justify-content:flex-end}}
