@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=Playfair+Display:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:60;transition:transform var(--transition-normal)}[data-theme=dark] .sidebar{background:var(--bg-sidebar-flat);border-right:none;box-shadow:4px 0 24px #00000026}.sidebar-overlay,.sidebar-close{display:none}.sidebar-header{padding:var(--space-lg);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color-light)}[data-theme=dark] .sidebar-header{border-bottom-color:#ffffff14}.sidebar-logo{display:flex;align-items:center;gap:var(--space-sm)}.sidebar-logo-icon{width:42px;height:42px;border-radius:var(--radius-md);background:linear-gradient(135deg,#c2856e,#d4a574);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #c2856e4d}.sidebar-brand{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--text-primary);line-height:1.2}[data-theme=dark] .sidebar-brand{color:#fff}.sidebar-brand-sub{font-size:.68rem;color:var(--text-tertiary);font-weight:500;letter-spacing:.04em;text-transform:uppercase}[data-theme=dark] .sidebar-brand-sub{color:#fff6}.sidebar-nav{flex:1;padding:var(--space-md);display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:var(--space-sm);padding:10px 14px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition-fast);border:none;background:none;cursor:pointer;width:100%;text-align:left;text-decoration:none;position:relative}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}[data-theme=dark] .sidebar-link{color:#ffffff8c}[data-theme=dark] .sidebar-link:hover{background:#ffffff0f;color:#ffffffe6}.sidebar-link.active{background:var(--color-primary);color:#fff;font-weight:600}[data-theme=dark] .sidebar-link.active{background:#c2856e2e;color:#d9a898}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-color-light);display:flex;flex-direction:column;gap:var(--space-sm)}[data-theme=dark] .sidebar-footer{border-top-color:#ffffff14}.sidebar-user{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm)}.sidebar-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,#d4a574,#c2856e);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{display:block;font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-theme=dark] .sidebar-user-name{color:#ffffffd9}.sidebar-user-role{display:block;font-size:.6875rem;color:var(--text-tertiary)}[data-theme=dark] .sidebar-user-role{color:#ffffff59}@media(max-width:768px){.sidebar,.sidebar-open{transform:translate(-100%)!important;visibility:hidden}.sidebar-overlay{display:none!important}.sidebar-close{display:none}}.app-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);background:var(--bg-card);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:40}.header-left{display:flex;align-items:center;gap:var(--space-md)}.header-menu-btn{display:none}.header-title{font-family:var(--font-display);font-size:1.125rem;font-weight:600}.header-right{display:flex;align-items:center;gap:var(--space-sm)}@media(max-width:768px){.header-menu-btn,.app-header{display:none}}.bottom-nav{display:none}@media(max-width:768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--bg-card);border-top:1px solid var(--border-color);z-index:100;justify-content:space-around;align-items:center;padding:0 var(--space-xs);box-shadow:0 -2px 12px #0000000f}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 8px;border-radius:var(--radius-md);color:var(--text-tertiary);text-decoration:none;font-size:.625rem;font-weight:500;transition:all var(--transition-fast);min-width:52px}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item.active svg{filter:drop-shadow(0 2px 6px rgba(194,133,110,.3))}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:var(--space-lg);position:relative;overflow:hidden}.login-decoration{position:absolute;inset:0;pointer-events:none}.login-circle{position:absolute;border-radius:50%;opacity:.15}.login-circle-1{width:400px;height:400px;background:var(--color-primary);top:-100px;right:-100px;animation:float 8s ease-in-out infinite}.login-circle-2{width:300px;height:300px;background:var(--color-accent);bottom:-80px;left:-80px;animation:float 10s ease-in-out infinite reverse}.login-circle-3{width:200px;height:200px;background:var(--color-secondary);top:40%;left:20%;animation:float 12s ease-in-out infinite 2s}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-2xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl);position:relative;z-index:1;animation:slideUp .5s ease}.login-logo{text-align:center;margin-bottom:var(--space-xl)}.login-logo-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto var(--space-md)}.login-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.login-error{padding:10px 14px;background:#e87f7f1a;border:1px solid rgba(232,127,127,.3);border-radius:var(--radius-md);color:var(--color-danger);font-size:.875rem;text-align:center}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;display:flex}.password-toggle:hover{color:var(--text-secondary)}.login-footer{text-align:center;color:var(--text-tertiary);font-size:.8125rem;margin-top:var(--space-lg)}.dashboard{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md)}.dashboard-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--space-lg)}.dashboard-chart h3{margin-bottom:var(--space-md);font-size:1rem}.chart-legend{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-md);margin-top:var(--space-md);justify-content:center}.chart-legend-item{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary)}.chart-legend-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0}@media(max-width:768px){.dashboard{gap:var(--space-md)}.dashboard-kpis{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.dashboard-charts{grid-template-columns:1fr;gap:var(--space-md)}.dashboard-chart{padding:var(--space-md)!important}.dashboard-chart h3{font-size:.875rem;margin-bottom:var(--space-sm)}.recharts-responsive-container{font-size:.75rem}}@media(max-width:480px){.dashboard-kpis{grid-template-columns:repeat(2,1fr)}}.pedidos-page{display:flex;flex-direction:column;gap:var(--space-lg)}.pedidos-filters{display:flex;flex-direction:column;gap:var(--space-md)}.filter-group{display:flex;gap:var(--space-md);flex-wrap:wrap}.filter-group .form-select{min-width:180px}.pedidos-cards-mobile{display:none;flex-direction:column;gap:var(--space-md)}.pedido-card-mobile{cursor:pointer;transition:all var(--transition-fast)}.pedido-card-mobile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.pedido-card-atrasado{border-left:4px solid var(--color-danger)}@media(max-width:768px){.pedidos-table-wrapper{display:none}.pedidos-cards-mobile{display:flex}.filter-group{flex-direction:column}.filter-group .form-select{min-width:100%}}.calendario-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-xl);margin-bottom:var(--space-lg)}.calendario-nav h2{min-width:200px;text-align:center}.calendario-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-color-light);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.calendario-header{padding:var(--space-sm);text-align:center;font-weight:600;font-size:.8125rem;color:var(--text-secondary);background:var(--bg-secondary);text-transform:uppercase;letter-spacing:.05em}.calendario-cell{min-height:100px;padding:var(--space-xs);background:var(--bg-card);display:flex;flex-direction:column;gap:2px}.calendario-empty{background:var(--bg-secondary);opacity:.5}.calendario-today{background:var(--bg-active)}.calendario-today .calendario-day{background:var(--color-primary);color:#fff}.calendario-day{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;margin-bottom:2px}.calendario-event{padding:2px 6px;border-radius:4px;background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-fast)}.calendario-event:hover{background:var(--bg-hover);transform:scale(1.02)}.calendario-event-text{font-size:.6875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.calendario-more{font-size:.625rem;color:var(--text-tertiary);text-align:center;padding:2px}@media(max-width:768px){.calendario-cell{min-height:60px}.calendario-event-text{font-size:.5625rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #C2856E;--color-primary-light: #D9A898;--color-primary-dark: #A66B54;--color-secondary: #6B8F8B;--color-secondary-light: #8FB5B0;--color-accent: #D4A574;--color-accent-light: #E8C9A8;--color-success: #6B9E7B;--color-warning: #D4A04A;--color-danger: #C4615A;--color-danger-dark: #A84D47;--color-info: #5B8BAF;--bg-primary: #FAF7F5;--bg-secondary: #F3EFEB;--bg-card: #FFFFFF;--bg-sidebar: linear-gradient(180deg, #2D2A35 0%, #1F1D26 100%);--bg-sidebar-flat: #2D2A35;--bg-hover: rgba(194, 133, 110, .06);--bg-active: rgba(194, 133, 110, .12);--bg-input: #FFFFFF;--bg-modal-overlay: rgba(30, 28, 36, .5);--text-primary: #2D2A35;--text-secondary: #7A7685;--text-tertiary: #A9A5B2;--text-inverse: #FFFFFF;--text-link: #C2856E;--border-color: #E8E4DF;--border-color-light: #F0ECE8;--border-color-focus: #C2856E;--shadow-sm: 0 1px 3px rgba(45, 42, 53, .05);--shadow-md: 0 4px 16px rgba(45, 42, 53, .08);--shadow-lg: 0 8px 32px rgba(45, 42, 53, .1);--shadow-xl: 0 20px 60px rgba(45, 42, 53, .14);--shadow-glow: 0 0 24px rgba(194, 133, 110, .18);--font-display: "Playfair Display", serif;--font-body: "Plus Jakarta Sans", sans-serif;--font-mono: "JetBrains Mono", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--sidebar-width: 260px;--header-height: 64px;--max-content-width: 1400px}[data-theme=dark]{--color-primary: #D09E88;--color-primary-light: #A07060;--color-primary-dark: #E8BBA8;--color-secondary: #7FABA5;--color-secondary-light: #5E8D88;--color-accent: #D4A574;--color-accent-light: #B08458;--color-success: #72A882;--color-warning: #D4A84E;--color-danger: #D06B65;--color-danger-dark: #B55550;--color-info: #6B9BC0;--bg-primary: #191720;--bg-secondary: #141218;--bg-card: #23212B;--bg-sidebar: linear-gradient(180deg, #1C1A24 0%, #141218 100%);--bg-sidebar-flat: #1C1A24;--bg-hover: rgba(208, 158, 136, .08);--bg-active: rgba(208, 158, 136, .14);--bg-input: #2A2832;--bg-modal-overlay: rgba(10, 9, 15, .65);--text-primary: #EBE8EF;--text-secondary: #9B97A5;--text-tertiary: #5D5968;--text-inverse: #191720;--text-link: #D09E88;--border-color: #322F3B;--border-color-light: #2A2832;--border-color-focus: #D09E88;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .35);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .4);--shadow-glow: 0 0 24px rgba(208, 158, 136, .12)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background var(--transition-normal),color var(--transition-normal)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}a{color:var(--text-link);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.text-center{text-align:center}.text-right{text-align:right}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.w-full{width:100%}.h-full{height:100%}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{background:#fff9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .card-glass{background:#24244299;border:1px solid rgba(255,255,255,.1)}.kpi-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md);transition:all var(--transition-normal);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--kpi-color, var(--color-primary));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.kpi-content{flex:1}.kpi-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;line-height:1.2}.kpi-label{font-size:.825rem;color:var(--text-secondary);font-weight:500;margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;line-height:1.4}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--color-danger);color:var(--text-inverse)}.btn-danger:hover:not(:disabled){background:var(--color-danger-dark)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md)}.btn-icon.btn-sm{width:32px;height:32px}.btn-fab{position:fixed;bottom:var(--space-xl);right:var(--space-xl);width:56px;height:56px;border-radius:var(--radius-full);font-size:1.5rem;padding:0;box-shadow:var(--shadow-lg);z-index:50}.btn-fab:hover{transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow-xl)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.8125rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;color:var(--text-primary);transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-color-focus);box-shadow:0 0 0 3px #b48ead26}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-textarea{resize:vertical;min-height:80px}.form-select{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='%238888A0' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-orcamento{background:#88b4e726;color:#5b8ecc}.badge-aprovado{background:#8bc5a326;color:#5da87a}.badge-na_fila{background:#f0c98726;color:#c4a050}.badge-em_producao{background:#b48ead26;color:#9b6e94}.badge-finalizado{background:#8bc5a333;color:#4d9466}.badge-entregue{background:#a0a0b826;color:#7a7a94}.badge-atrasado{background:#e87f7f26;color:#c55}.badge-cancelado{background:#d96b6b26;color:#b04040}.badge-atrasado{animation:pulse-red 2s ease-in-out infinite}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.7}}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background:var(--bg-secondary)}th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.8125rem;letter-spacing:.03em;text-transform:uppercase;border-bottom:1px solid var(--border-color);white-space:nowrap}td{padding:12px 16px;border-bottom:1px solid var(--border-color-light);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:var(--bg-hover)}tbody tr.row-atrasado{background:#e87f7f0d}.modal-overlay{position:fixed;inset:0;background:var(--bg-modal-overlay);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-md);animation:fadeIn var(--transition-fast)}.modal{background:var(--bg-card);border-radius:var(--radius-xl);padding:var(--space-xl);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-normal)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700}.modal-lg{max-width:800px}.status-timeline{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.status-step{display:flex;align-items:center;gap:4px;font-size:.8125rem;color:var(--text-tertiary)}.status-step.active{color:var(--color-primary);font-weight:600}.status-step.completed{color:var(--color-success)}.status-arrow{color:var(--text-tertiary);font-size:.75rem}.search-bar{position:relative}.search-bar .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.search-bar input{padding-left:42px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.page-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:.875rem;margin-top:2px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.6}.empty-state-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;margin-bottom:var(--space-sm)}.empty-state-text{color:var(--text-secondary);font-size:.9375rem;max-width:400px}.spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--space-3xl)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideIn{0%{transform:translate(-10px);opacity:0}to{transform:translate(0);opacity:1}}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:200;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{padding:12px 20px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;animation:slideIn var(--transition-normal);min-width:280px}.toast-success{border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid var(--color-danger)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media(max-width:768px){:root{--sidebar-width: 0px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.btn-fab{bottom:var(--space-lg);right:var(--space-lg)}.modal{max-width:100%;margin:var(--space-sm);padding:var(--space-lg)}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.125rem}}@media(min-width:769px)and (max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.form-row{grid-template-columns:1fr}}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column}.app-content{flex:1;padding:var(--space-lg);max-width:var(--max-content-width);width:100%;margin:0 auto}@media(max-width:768px){.app-main{margin-left:0}.app-content{padding:var(--space-md);padding-bottom:80px}.sidebar{transform:translate(-100%)}.sidebar-open{transform:translate(0)}.page-header{margin-bottom:var(--space-md)}.page-title{font-size:1.25rem}.page-subtitle{font-size:.8125rem}}.kpi-card{position:relative;overflow:hidden}@media(max-width:768px){.kpi-card{padding:var(--space-md)!important}.kpi-icon{width:36px!important;height:36px!important}.kpi-icon svg{width:18px!important;height:18px!important}.kpi-value{font-size:1.25rem!important}.kpi-label{font-size:.7rem!important}}.dashboard-greeting{margin-bottom:var(--space-lg)}.dashboard-greeting h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary)}.dashboard-greeting p{color:var(--text-secondary);font-size:.875rem;margin-top:2px}@media(max-width:768px){.dashboard-greeting h2{font-size:1.25rem}.dashboard-greeting p{font-size:.8125rem}}@media(max-width:768px){.table-container{margin:0 calc(-1 * var(--space-md))}table{font-size:.8125rem}th,td{padding:8px 10px}}
