@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary-50:#fff8f0;--primary-100:#fdebd0;--primary-200:#fadcaa;--primary-300:#f5b862;--primary-400:#f0993e;--primary-500:#e67e22;--primary-600:#ca6c1a;--primary-700:#a55717;--primary-800:#7d4214;--primary-900:#5a300f;--neutral-50:#f8fafc;--neutral-100:#f1f5f9;--neutral-200:#e2e8f0;--neutral-300:#cbd5e1;--neutral-400:#94a3b8;--neutral-500:#64748b;--neutral-600:#475569;--neutral-700:#334155;--neutral-800:#1e293b;--neutral-900:#0f172a;--success-50:#f0fdf4;--success-100:#dcfce7;--success-500:#22c55e;--success-600:#16a34a;--success-700:#15803d;--danger-50:#fef2f2;--danger-100:#fee2e2;--danger-500:#ef4444;--danger-600:#dc2626;--danger-700:#b91c1c;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-500:#f59e0b;--warning-600:#d97706;--warning-700:#b45309;--info-50:#eff6ff;--info-100:#dbeafe;--info-500:#3b82f6;--info-600:#2563eb;--info-700:#1d4ed8;--bg-primary:#f5f6fa;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-elevated:#fff;--bg-overlay:#0f172a80;--text-primary:#1e293b;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-inverse:#fff;--text-link:var(--primary-600);--border-default:#e2e8f0;--border-strong:#cbd5e1;--border-focus:var(--primary-500);--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-glow:0 0 20px #e67e2226;--glass-bg:#ffffffb3;--glass-border:#ffffff4d;--glass-blur:12px;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:clamp(.6875rem, .65rem + .1vw, .75rem);--text-sm:clamp(.8125rem, .78rem + .1vw, .875rem);--text-base:clamp(.875rem, .85rem + .15vw, 1rem);--text-lg:clamp(1rem, .95rem + .2vw, 1.125rem);--text-xl:clamp(1.125rem, 1.05rem + .3vw, 1.25rem);--text-2xl:clamp(1.25rem, 1.1rem + .5vw, 1.5rem);--text-3xl:clamp(1.5rem, 1.3rem + .7vw, 1.875rem);--text-4xl:clamp(1.75rem, 1.5rem + 1vw, 2.25rem);--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.65;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--z-base:0;--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-overlay:400;--z-modal:500;--z-toast:600;--sidebar-width:260px;--sidebar-collapsed:72px;--topbar-height:64px;--mobile-nav-height:64px;--container-max:1400px}[data-theme=dark]{--bg-primary:#0c0e1a;--bg-secondary:#141625;--bg-tertiary:#1a1d30;--bg-elevated:#1e2138;--bg-overlay:#0009;--text-primary:#e8ecf4;--text-secondary:#a0aabb;--text-tertiary:#64748b;--text-inverse:#0f172a;--text-link:var(--primary-400);--border-default:#252840;--border-strong:#353858;--border-focus:var(--primary-400);--shadow-xs:0 1px 2px #0003;--shadow-sm:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 6px -1px #00000059, 0 2px 4px -2px #0003;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0003;--shadow-xl:0 20px 25px -5px #0006, 0 8px 10px -6px #0003;--shadow-glow:0 0 25px #f39c1226;--glass-bg:#141625bf;--glass-border:#ffffff14}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}a{color:var(--text-link);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-500)}img{max-width:100%;height:auto;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{line-height:var(--leading-tight);color:var(--text-primary);font-weight:600}h1{font-size:var(--text-4xl);font-weight:700}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}::selection{background:var(--primary-200);color:var(--primary-900)}[data-theme=dark] ::selection{background:var(--primary-700);color:var(--primary-100)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--neutral-600)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}.app-layout{min-height:100vh;display:flex}.app-sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-default);height:100vh;z-index:var(--z-fixed);transition:transform var(--transition-base), width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.app-sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{padding:var(--space-5) var(--space-5);align-items:center;gap:var(--space-3);border-bottom:1px solid var(--border-default);min-height:var(--topbar-height);display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));border-radius:var(--radius-md);color:#fff;width:36px;height:36px;font-weight:700;font-size:var(--text-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-brand{font-size:var(--text-lg);color:var(--text-primary);white-space:nowrap;font-weight:700;overflow:hidden}.sidebar-brand span{color:var(--primary-500)}.sidebar-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.nav-section-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:var(--space-4) var(--space-3) var(--space-2);font-weight:600}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--primary-50);color:var(--primary-600);font-weight:600}[data-theme=dark] .nav-item.active{color:var(--primary-400);background:#e67e221a}.nav-item .nav-icon{flex-shrink:0;width:20px;height:20px}.nav-item .nav-badge{background:var(--danger-500);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:20px;margin-left:auto;padding:1px 7px;font-size:.6875rem;font-weight:600}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--border-default)}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);display:flex}.sidebar-user:hover{background:var(--bg-tertiary)}.sidebar-user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary-400), var(--primary-600));color:#fff;width:36px;height:36px;font-weight:600;font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{overflow:hidden}.sidebar-user-name{font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:capitalize}.app-main{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-base);flex-direction:column;flex:1;display:flex}.app-topbar{height:var(--topbar-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-default);padding:0 var(--space-6);z-index:var(--z-sticky);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:var(--space-4);display:flex}.topbar-title{font-size:var(--text-lg);font-weight:600}.topbar-right{align-items:center;gap:var(--space-3);display:flex}.topbar-icon-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.topbar-icon-btn .notification-dot{background:var(--danger-500);border-radius:var(--radius-full);border:2px solid var(--bg-secondary);width:8px;height:8px;position:absolute;top:8px;right:8px}.app-content{padding:var(--space-6);max-width:var(--container-max);flex:1;width:100%;margin:0 auto}.mobile-nav{height:var(--mobile-nav-height);background:var(--bg-secondary);border-top:1px solid var(--border-default);z-index:var(--z-fixed);padding:0 var(--space-2);display:none;position:fixed;bottom:0;left:0;right:0}.mobile-nav-items{height:100%;display:flex}.mobile-nav-item{color:var(--text-tertiary);transition:color var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-size:.625rem;font-weight:500;text-decoration:none;display:flex}.mobile-nav-item.active{color:var(--primary-500)}.mobile-nav-item .mobile-nav-icon{width:22px;height:22px}.card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stats-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);align-items:flex-start;gap:var(--space-4);transition:all var(--transition-base);display:flex;position:relative;overflow:hidden}.stats-card:before{content:"";background:var(--stats-accent,var(--primary-500));opacity:0;height:3px;transition:opacity var(--transition-fast);position:absolute;top:0;left:0;right:0}.stats-card:hover:before{opacity:1}.stats-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stats-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stats-icon.orange{background:var(--primary-100);color:var(--primary-600)}.stats-icon.green{background:var(--success-100);color:var(--success-600)}.stats-icon.red{background:var(--danger-100);color:var(--danger-600)}.stats-icon.blue{background:var(--info-100);color:var(--info-600)}.stats-icon.yellow{background:var(--warning-100);color:var(--warning-600)}[data-theme=dark] .stats-icon.orange{background:#e67e2226}[data-theme=dark] .stats-icon.green{background:#22c55e26}[data-theme=dark] .stats-icon.red{background:#ef444426}[data-theme=dark] .stats-icon.blue{background:#3b82f626}[data-theme=dark] .stats-icon.yellow{background:#f59e0b26}.stats-content{flex:1;min-width:0}.stats-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1);font-weight:500}.stats-value{font-size:var(--text-3xl);color:var(--text-primary);font-weight:700;line-height:1}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-weight:600;line-height:1.5;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-primary{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;box-shadow:0 1px 3px #e67e224d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--primary-600), var(--primary-700));transform:translateY(-1px);box-shadow:0 4px 12px #e67e2259}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--border-default)}.btn-danger{background:linear-gradient(135deg, var(--danger-500), var(--danger-600));color:#fff}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg, var(--danger-600), var(--danger-700));transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg, var(--success-500), var(--success-600));color:#fff}.btn-success:hover:not(:disabled){background:linear-gradient(135deg, var(--success-600), var(--success-700));transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-outline{color:var(--primary-500);border-color:var(--primary-500);background:0 0}.btn-outline:hover:not(:disabled){background:var(--primary-50)}[data-theme=dark] .btn-outline:hover:not(:disabled){background:#e67e221a}.btn-whatsapp{color:#fff;background:linear-gradient(135deg,#25d366,#128c7e)}.btn-whatsapp:hover:not(:disabled){background:linear-gradient(135deg,#128c7e,#075e54);transform:translateY(-1px)}.btn-icon{padding:var(--space-2)}.btn-icon.btn-sm{padding:var(--space-1)}.btn-loading .spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.form-group{gap:var(--space-1);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.form-label .required{color:var(--danger-500);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-fast);line-height:1.5}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #e67e221f}input[type=date].form-input{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}input[type=date].form-input::-webkit-calendar-picker-indicator{filter:invert()brightness(1.5);cursor:pointer;opacity:.8}input[type=date].form-input::-webkit-calendar-picker-indicator:hover{opacity:1}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--danger-500)}.form-input.error:focus,.form-textarea.error:focus{box-shadow:0 0 0 3px #ef44441f}.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' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394A3B8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}.form-helper{font-size:var(--text-xs);color:var(--text-tertiary)}.form-error{font-size:var(--text-xs);color:var(--danger-500)}.form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}@media (width<=640px){.form-row{grid-template-columns:1fr}}.form-checkbox{align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--text-sm);display:flex}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-500);cursor:pointer}.badge{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);white-space:nowrap;padding:2px 10px;font-size:.6875rem;font-weight:600;line-height:1.6;display:inline-flex}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:var(--success-100);color:var(--success-700)}.badge-danger{background:var(--danger-100);color:var(--danger-700)}.badge-warning{background:var(--warning-100);color:var(--warning-700)}.badge-info{background:var(--info-100);color:var(--info-700)}.badge-neutral{background:var(--neutral-200);color:var(--neutral-700)}[data-theme=dark] .badge-primary{color:var(--primary-300);background:#e67e2226}[data-theme=dark] .badge-success{color:var(--success-500);background:#22c55e26}[data-theme=dark] .badge-danger{color:var(--danger-500);background:#ef444426}[data-theme=dark] .badge-warning{color:var(--warning-500);background:#f59e0b26}[data-theme=dark] .badge-info{color:var(--info-500);background:#3b82f626}[data-theme=dark] .badge-neutral{color:var(--neutral-400);background:#64748b26}.badge-dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.progress-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);height:8px;position:relative;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative}.progress-bar-fill.green{background:linear-gradient(90deg, var(--success-500), var(--success-600))}.progress-bar-fill.orange{background:linear-gradient(90deg, var(--primary-500), var(--primary-600))}.progress-bar-fill.red{background:linear-gradient(90deg, var(--danger-500), var(--danger-600))}.progress-bar-fill.blue{background:linear-gradient(90deg, var(--info-500), var(--info-600))}.progress-label{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-1);justify-content:space-between;align-items:center;display:flex}.progress-ring{transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--bg-tertiary)}.progress-ring-fill{fill:none;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.4,0,.2,1)}.table-container{border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-secondary);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--bg-tertiary);border-bottom:1px solid var(--border-default);white-space:nowrap;font-weight:600}.table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border-bottom:1px solid var(--border-default);color:var(--text-primary);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg-tertiary)}.modal-overlay{background:var(--bg-overlay);z-index:var(--z-modal);padding:var(--space-4);animation:fadeIn var(--transition-fast) ease-out;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:90vh;animation:slideUp var(--transition-base) ease-out;overflow-y:auto}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:600}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-tertiary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-default);display:flex}.toast-container{top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);gap:var(--space-2);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:320px;max-width:480px;animation:slideInRight var(--transition-base) ease-out;pointer-events:auto;display:flex}.toast-success{border-left:3px solid var(--success-500)}.toast-error{border-left:3px solid var(--danger-500)}.toast-warning{border-left:3px solid var(--warning-500)}.toast-info{border-left:3px solid var(--info-500)}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-message{font-size:var(--text-sm);flex:1;font-weight:500}.toast-close{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-tertiary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-close:hover{background:var(--bg-tertiary)}.tabs{border-bottom:2px solid var(--border-default);scrollbar-width:none;gap:0;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-2px;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-500);font-weight:600}[data-theme=dark] .tab.active{color:var(--primary-400)}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{border-radius:var(--radius-2xl);background:var(--bg-tertiary);width:80px;height:80px;margin-bottom:var(--space-5);color:var(--text-tertiary);justify-content:center;align-items:center;display:flex}.empty-state-title{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:600}.empty-state-description{font-size:var(--text-sm);color:var(--text-secondary);max-width:400px;margin-bottom:var(--space-6)}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--border-default) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-title{width:60%;height:24px;margin-bottom:var(--space-3)}.skeleton-circle{border-radius:var(--radius-full)}.skeleton-card{height:120px}.avatar{border-radius:var(--radius-full);width:40px;height:40px;font-weight:600;font-size:var(--text-sm);background:linear-gradient(135deg, var(--primary-400), var(--primary-600));color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--text-lg)}.avatar-xl{width:72px;height:72px;font-size:var(--text-xl)}.site-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;transition:all var(--transition-base);gap:var(--space-4);flex-direction:column;display:flex}.site-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-200);transform:translateY(-2px)}[data-theme=dark] .site-card:hover{border-color:var(--primary-800)}.site-card-header{justify-content:space-between;align-items:flex-start;display:flex}.site-card-title{font-size:var(--text-lg);margin-bottom:var(--space-1);font-weight:600}.site-card-location{font-size:var(--text-sm);color:var(--text-secondary);align-items:center;gap:var(--space-1);display:flex}.site-card-stats{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.site-card-stat{text-align:center;padding:var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-md)}.site-card-stat-value{font-size:var(--text-lg);font-weight:700}.site-card-stat-label{font-size:var(--text-xs);color:var(--text-secondary)}.task-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-base);cursor:pointer;position:relative;overflow:hidden}.task-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.task-card-priority{width:4px;position:absolute;top:0;bottom:0;left:0}.task-card-priority.high{background:var(--danger-500)}.task-card-priority.medium{background:var(--warning-500)}.task-card-priority.low{background:var(--info-500)}.task-card-header{margin-bottom:var(--space-2);padding-left:var(--space-3);justify-content:space-between;align-items:flex-start;display:flex}.task-card-id{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:600;font-family:var(--font-mono)}.task-card-title{font-size:var(--text-sm);color:var(--text-primary);padding-left:var(--space-3);margin-bottom:var(--space-3);font-weight:600}.task-card-footer{padding-left:var(--space-3);justify-content:space-between;align-items:center;display:flex}.task-card-meta{align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);display:flex}.task-card-meta .overdue{color:var(--danger-500);font-weight:600}.kanban-board{gap:var(--space-4);padding-bottom:var(--space-4);flex-wrap:wrap;justify-content:stretch;min-height:400px;display:flex}.kanban-column{flex-direction:column;flex:300px;min-width:260px;max-width:100%;display:flex}.kanban-column-header{padding:var(--space-3) var(--space-4);margin-bottom:var(--space-3);border-radius:var(--radius-lg);background:var(--bg-tertiary);justify-content:space-between;align-items:center;display:flex}.kanban-column-title{font-size:var(--text-sm);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.kanban-column-count{font-size:var(--text-xs);background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-full);padding:1px 8px;font-weight:600}.kanban-column-body{gap:var(--space-3);padding:var(--space-1);border-radius:var(--radius-lg);min-height:100px;transition:background var(--transition-fast);flex-direction:column;flex:1;display:flex}.kanban-column-body.drag-over{background:var(--primary-50);border:2px dashed var(--primary-300)}[data-theme=dark] .kanban-column-body.drag-over{border-color:var(--primary-700);background:#e67e220d}.calendar{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.calendar-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;display:flex}.calendar-title{font-size:var(--text-lg);font-weight:600}.calendar-nav{gap:var(--space-2);display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);display:grid}.calendar-day-header{padding:var(--space-2) var(--space-1);text-align:center;font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;border-bottom:1px solid var(--border-default);font-weight:600}.calendar-day{min-height:100px;padding:var(--space-2);border-right:1px solid var(--border-default);border-bottom:1px solid var(--border-default);transition:background var(--transition-fast);cursor:pointer}.calendar-day:nth-child(7n){border-right:none}.calendar-day:hover{background:var(--bg-tertiary)}.calendar-day.other-month{opacity:.4}.calendar-day.today{background:var(--primary-50)}[data-theme=dark] .calendar-day.today{background:#e67e220f}.calendar-day-number{font-size:var(--text-sm);margin-bottom:var(--space-1);font-weight:500}.calendar-day.today .calendar-day-number{background:var(--primary-500);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;width:26px;height:26px;display:flex}.calendar-event{border-radius:var(--radius-sm);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;padding:2px 6px;font-size:.625rem;font-weight:500;overflow:hidden}.calendar-event.completed{background:var(--success-100);color:var(--success-700)}.calendar-event.in-progress{background:var(--warning-100);color:var(--warning-700)}.calendar-event.delayed{background:var(--danger-100);color:var(--danger-700)}.calendar-event.upcoming{background:var(--info-100);color:var(--info-700)}[data-theme=dark] .calendar-event.completed{color:var(--success-500);background:#22c55e26}[data-theme=dark] .calendar-event.in-progress{color:var(--warning-500);background:#f59e0b26}[data-theme=dark] .calendar-event.delayed{color:var(--danger-500);background:#ef444426}[data-theme=dark] .calendar-event.upcoming{color:var(--info-500);background:#3b82f626}.filter-bar{gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.filter-bar .form-input,.filter-bar .form-select{width:auto;min-width:160px}.search-input-wrapper{flex:1;min-width:200px;max-width:400px;position:relative}.search-input-wrapper .search-icon{color:var(--text-tertiary);pointer-events:none;width:18px;height:18px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 36px;font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-fast)}.search-input:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #e67e221f}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{font-size:var(--text-3xl);font-weight:700}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.page-actions{gap:var(--space-3);flex-wrap:wrap;display:flex}.review-section{margin-bottom:var(--space-6)}.review-section-title{font-size:var(--text-lg);align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);font-weight:600;display:flex}.review-task-row{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-3);transition:all var(--transition-fast)}.review-task-row:hover{box-shadow:var(--shadow-sm)}.review-task-row.delayed{border-left:4px solid var(--danger-500)}.charts-grid{gap:var(--space-5);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));display:grid}.chart-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.chart-title{font-size:var(--text-base);margin-bottom:var(--space-4);font-weight:600}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;overflow:hidden}.login-bg-shape{opacity:.08;border-radius:50%;animation:20s ease-in-out infinite float;position:absolute}.login-bg-shape:first-child{background:var(--primary-500);width:500px;height:500px;animation-delay:0s;top:-200px;right:-100px}.login-bg-shape:nth-child(2){background:var(--info-500);width:400px;height:400px;animation-delay:-5s;bottom:-150px;left:-100px}.login-bg-shape:nth-child(3){background:var(--success-500);width:300px;height:300px;animation-delay:-10s;top:40%;left:60%}.login-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);width:100%;max-width:420px;padding:var(--space-10);box-shadow:var(--shadow-xl);z-index:1;animation:.5s ease-out fadeInUp;position:relative}.login-logo{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));border-radius:var(--radius-lg);width:56px;height:56px;margin:0 auto var(--space-5);color:#fff;justify-content:center;align-items:center;display:flex}.login-title{text-align:center;font-size:var(--text-2xl);margin-bottom:var(--space-1);font-weight:700}.login-subtitle{text-align:center;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-8)}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.slider-wrapper{align-items:center;gap:var(--space-3);display:flex}.slider{appearance:none;background:var(--bg-tertiary);border-radius:var(--radius-full);outline:none;flex:1;height:6px}.slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary-500);cursor:pointer;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #e67e224d}.slider-value{font-size:var(--text-sm);text-align:right;min-width:36px;font-weight:600}.theme-toggle{background:var(--neutral-300);border-radius:var(--radius-full);cursor:pointer;width:40px;height:22px;transition:background var(--transition-fast);position:relative}[data-theme=dark] .theme-toggle{background:var(--primary-500)}.theme-toggle-knob{width:18px;height:18px;transition:transform var(--transition-fast);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}[data-theme=dark] .theme-toggle-knob{transform:translate(18px)}.detail-grid{gap:var(--space-6);grid-template-columns:1fr 360px;display:grid}.detail-main,.detail-sidebar{gap:var(--space-5);flex-direction:column;display:flex}@media (width<=1024px){.detail-grid{grid-template-columns:1fr}}.detail-field{margin-bottom:var(--space-4)}.detail-field-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:var(--space-1);font-weight:600}.detail-field-value{font-size:var(--text-sm);color:var(--text-primary)}.activity-feed{flex-direction:column;display:flex}.activity-item{gap:var(--space-3);padding:var(--space-4) 0;border-bottom:1px solid var(--border-default);display:flex;position:relative}.activity-item:last-child{border-bottom:none}.activity-dot{background:var(--primary-500);border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:5px;position:relative}.activity-dot:after{content:"";background:var(--border-default);width:2px;height:calc(100% + 20px);position:absolute;top:14px;left:4px}.activity-item:last-child .activity-dot:after{display:none}.activity-content{flex:1}.activity-user{font-weight:600;font-size:var(--text-sm)}.activity-text{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.activity-time{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.ai-summary{background:linear-gradient(135deg, var(--primary-50), var(--info-50));border:1px solid var(--primary-200);border-radius:var(--radius-lg);padding:var(--space-5);position:relative;overflow:hidden}[data-theme=dark] .ai-summary{border-color:var(--primary-800);background:linear-gradient(135deg,#e67e220d,#3b82f60d)}.ai-summary:before{content:"✨";opacity:.2;font-size:2rem;position:absolute;top:-5px;right:10px}.ai-summary-title{font-size:var(--text-base);margin-bottom:var(--space-3);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.ai-summary-content{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-secondary)}.ai-summary-content h4{font-size:var(--text-sm);margin:var(--space-3) 0 var(--space-1)}.ai-summary-content ul{padding-left:var(--space-5);list-style:outside}.ai-summary-content li{margin-bottom:var(--space-1)}.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-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.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)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-lg{font-size:var(--text-lg)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-danger{color:var(--danger-500)}.text-success{color:var(--success-500)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-mono{font-family:var(--font-mono)}.w-full{width:100%}.h-full{height:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mr-2{margin-right:var(--space-2)}.ml-auto{margin-left:auto}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.hidden{display:none}.relative{position:relative}.overflow-hidden{overflow:hidden}.stats-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.sites-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-30px)rotate(5deg)}50%{transform:translateY(10px)rotate(-3deg)}75%{transform:translateY(-15px)rotate(2deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-fade-in-up{animation:fadeInUp var(--transition-base) ease-out}.animate-slide-up{animation:slideUp var(--transition-base) ease-out}.stagger-children>*{opacity:0;animation:.4s ease-out forwards fadeInUp}.stagger-children>:first-child{animation-delay:50ms}.stagger-children>:nth-child(2){animation-delay:.1s}.stagger-children>:nth-child(3){animation-delay:.15s}.stagger-children>:nth-child(4){animation-delay:.2s}.stagger-children>:nth-child(5){animation-delay:.25s}.stagger-children>:nth-child(6){animation-delay:.3s}.stagger-children>:nth-child(7){animation-delay:.35s}.stagger-children>:nth-child(8){animation-delay:.4s}.review-task-grid{gap:var(--space-4);grid-template-columns:1fr 300px;display:grid}@media (width<=768px){.review-task-grid{grid-template-columns:1fr}.app-sidebar{transform:translate(-100%)}.app-sidebar.open{box-shadow:var(--shadow-xl);transform:translate(0)}.app-main{padding-bottom:var(--mobile-nav-height);margin-left:0}.mobile-nav{display:block}.topbar-title{font-size:var(--text-base)}.app-content{padding:var(--space-4)}.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.stats-grid{grid-template-columns:repeat(2,1fr)}.sites-grid{grid-template-columns:1fr}.kanban-board{flex-flow:column wrap;display:flex}.kanban-column{min-width:unset;max-width:unset}.calendar-day{min-height:60px}.calendar-event{padding:1px 3px;font-size:.5625rem}.filter-bar{flex-direction:column}.filter-bar .form-input,.filter-bar .form-select{width:100%;min-width:unset}.search-input-wrapper{max-width:unset}.detail-grid,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.modal-content{margin:var(--space-4);max-width:calc(100% - var(--space-8))}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.site-card-stats{grid-template-columns:repeat(3,1fr)}.page-title{font-size:var(--text-2xl)}.login-card{padding:var(--space-6);margin:var(--space-4)}}@media (width>=769px){.mobile-only{display:none}}@media (width<=768px){.desktop-only{display:none}}
