@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-primary:#1a1f2e;--color-primary-light:#6366f1;--color-primary-lighter:#818cf8;--color-primary-dark:#111827;--color-primary-alpha:#6366f11a;--color-accent:#ec4899;--color-accent-light:#f472b6;--color-accent-dark:#db2777;--color-bg:#f8fafc;--color-surface:#fff;--color-surface-hover:#f1f5f9;--color-surface-active:#e2e8f0;--color-sidebar:#1a1f2e;--color-sidebar-text:#94a3b8;--color-sidebar-hover:#ffffff0d;--color-sidebar-active:#6366f126;--color-sidebar-active-text:#fff;--color-text:#1e293b;--color-text-secondary:#475569;--color-text-muted:#64748b;--color-text-inverse:#f8fafc;--color-text-link:#6366f1;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-border-focus:#2563eb;--color-success:#10b981;--color-success-bg:#ecfdf5;--color-warning:#f59e0b;--color-warning-bg:#fffbeb;--color-danger:#ef4444;--color-danger-bg:#fef2f2;--color-info:#3b82f6;--color-info-bg:#eff6ff;--stage-proposal:#8b5cf6;--stage-booked:#3b82f6;--stage-scheduled:#f59e0b;--stage-editing:#f97316;--stage-delivered:#10b981;--stage-lost:#ef4444;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--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 #0000000d;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-glow:0 0 20px #2563eb26;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-bg);line-height:1.6;overflow-x:hidden}a{color:var(--color-text-link);text-decoration:none}button{font-family:var(--font-family);cursor:pointer;background:0 0;border:none;outline:none}input,textarea,select{font-family:var(--font-family);font-size:var(--font-size-base)}ul,ol{list-style:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.app-layout{min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);flex:1}.app-content{padding:var(--space-lg);padding-top:calc(var(--header-height) + var(--space-lg));min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);z-index:100;height:100vh;transition:transform var(--transition-base), width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar-brand{padding:var(--space-lg);align-items:center;gap:var(--space-md);min-height:var(--header-height);border-bottom:1px solid #ffffff0f;display:flex}.sidebar-brand-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--color-primary-light), var(--color-accent));color:#fff;width:40px;height:40px;font-weight:700;font-size:var(--font-size-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-brand-text{flex-direction:column;display:flex}.sidebar-brand-name{font-size:var(--font-size-md);color:var(--color-text-inverse);letter-spacing:-.02em;font-weight:700}.sidebar-brand-sub{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.sidebar-nav{padding:var(--space-md) var(--space-sm);flex:1}.sidebar-label{color:#475569;text-transform:uppercase;letter-spacing:.1em;padding:var(--space-lg) var(--space-md) var(--space-sm);margin-top:var(--space-sm);font-size:11px;font-weight:600}.sidebar-link{align-items:center;gap:var(--space-md);padding:12px var(--space-md);border-radius:var(--radius-md);color:var(--color-sidebar-text);font-size:var(--font-size-base);transition:all var(--transition-fast);margin:0 var(--space-sm) 4px;font-weight:500;display:flex;position:relative}.sidebar-link:hover{background:var(--color-sidebar-hover);color:#fff}.sidebar-link.active{background:var(--color-sidebar-active);color:var(--color-sidebar-active-text)}.sidebar-link.active:before{content:"";background:var(--color-primary-light);border-radius:0 4px 4px 0;width:3px;height:18px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link svg{flex-shrink:0;width:20px;height:20px}.sidebar-badge{background:var(--color-primary-light);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:22px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:600}.sidebar-footer{padding:var(--space-md);border-top:1px solid #ffffff0f}.sidebar-user{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-sm);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);display:flex}.sidebar-user:hover{background:var(--color-sidebar-hover)}.sidebar-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary-lighter), var(--color-accent));color:#fff;width:36px;height:36px;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex-direction:column;min-width:0;display:flex}.sidebar-user-name{font-size:var(--font-size-sm);color:var(--color-text-inverse);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--font-size-xs);color:var(--color-text-muted)}.header{top:0;left:var(--sidebar-width);height:var(--header-height);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);padding:0 var(--space-lg);z-index:90;transition:left var(--transition-base);background:#ffffffd9;justify-content:space-between;align-items:center;display:flex;position:fixed;right:0}.header-left{align-items:center;gap:var(--space-md);display:flex}.header-title{font-size:var(--font-size-lg);color:var(--color-text);letter-spacing:-.02em;font-weight:700}.header-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted)}.header-right{align-items:center;gap:var(--space-sm);display:flex}.header-search{width:280px;position:relative}.header-search input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;font-size:var(--font-size-sm);color:var(--color-text);transition:all var(--transition-fast);padding:8px 12px 8px 36px}.header-search input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha);outline:none}.header-search input::placeholder{color:var(--color-text-muted)}.header-search svg{width:16px;height:16px;color:var(--color-text-muted);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.header-icon-btn{border-radius:var(--radius-md);width:38px;height:38px;color:var(--color-text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.header-icon-btn:hover{background:var(--color-surface-active);color:var(--color-text)}.header-icon-btn svg{width:20px;height:20px}.header-notification-dot{background:var(--color-danger);border-radius:var(--radius-full);border:2px solid var(--color-surface);width:8px;height:8px;position:absolute;top:8px;right:8px}.menu-toggle{border-radius:var(--radius-md);width:38px;height:38px;color:var(--color-text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:none}.menu-toggle:hover{background:var(--color-surface-active)}.menu-toggle svg{width:22px;height:22px}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-fast);white-space:nowrap;padding:9px 18px;font-weight:600;line-height:1.4;display:inline-flex}.btn svg{width:18px;height:18px}.btn-primary{background:var(--color-primary-light);color:#fff}.btn-primary:hover{background:var(--color-primary-lighter);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{box-shadow:var(--shadow-md);background:#dc2626}.btn-ghost{color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-surface-active);color:var(--color-text)}.btn-sm{font-size:var(--font-size-xs);padding:6px 12px}.btn-lg{font-size:var(--font-size-md);padding:12px 24px}.btn-icon{width:36px;height:36px;padding:0}.banner-header{color:#fff;background:linear-gradient(135deg,#ec4899 0%,#8b5cf6 100%);border-radius:16px;margin-bottom:24px;padding:32px;box-shadow:0 10px 25px -5px #8b5cf633}.banner-content{justify-content:space-between;align-items:center;gap:24px;display:flex}.banner-title{align-items:center;gap:12px;margin:0;font-size:28px;font-weight:800;display:flex}.banner-subtitle{color:#ffffffd9;margin-top:4px;font-size:14px}.banner-actions{gap:12px;display:flex}.banner-actions .btn{color:#1e293b;background:#fff;border:none;padding:10px 20px;font-weight:700}.banner-actions .btn:hover{background:#f1f5f9;transform:translateY(-2px)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:24px;display:grid}.kpi-card{background:#fff;border-top-style:solid;border-top-width:4px;border-radius:12px;flex-direction:column;padding:20px;display:flex;position:relative;box-shadow:0 4px 6px -1px #0000000d}.kpi-card.green{border-color:#10b981}.kpi-card.red{border-color:#ef4444}.kpi-card.blue{border-color:#3b82f6}.kpi-card.amber{border-color:#f59e0b}.kpi-card.purple{border-color:#8b5cf6}.kpi-label{color:#64748b;text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px;font-size:11px;font-weight:700}.kpi-value{margin-bottom:4px;font-size:24px;font-weight:800}.kpi-card.green .kpi-value{color:#10b981}.kpi-card.red .kpi-value{color:#ef4444}.kpi-card.blue .kpi-value{color:#3b82f6}.kpi-card.amber .kpi-value{color:#f59e0b}.kpi-card.purple .kpi-value{color:#8b5cf6}.kpi-sublabel{color:#94a3b8;font-size:11px;font-weight:500}.kpi-icon{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:absolute;top:16px;right:16px}.kpi-card.green .kpi-icon{color:#16a34a;background:#dcfce7}.kpi-card.red .kpi-icon{color:#dc2626;background:#fee2e2}.kpi-card.blue .kpi-icon{color:#3b82f6;background:#eff6ff}.kpi-card.amber .kpi-icon{color:#ca8a04;background:#fef9c3}.kpi-card.purple .kpi-icon{color:#8b5cf6;background:#f3e8ff}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);align-items:flex-start;gap:var(--space-md);transition:all var(--transition-fast);display:flex;position:relative;overflow:hidden}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-card:after{content:"";height:3px;position:absolute;top:0;left:0;right:0}.metric-card.metric-blue:after{background:var(--color-primary-light)}.metric-card.metric-green:after{background:var(--color-success)}.metric-card.metric-amber:after{background:var(--color-accent)}.metric-card.metric-purple:after{background:var(--stage-proposal)}.metric-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.metric-icon.blue{background:var(--color-info-bg);color:var(--color-primary-light)}.metric-icon.green{background:var(--color-success-bg);color:var(--color-success)}.metric-icon.amber{background:var(--color-warning-bg);color:var(--color-accent)}.metric-icon.purple{color:var(--stage-proposal);background:#f3e8ff}.metric-content{flex:1;min-width:0}.metric-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-xs);font-weight:500}.metric-value{font-size:var(--font-size-2xl);color:var(--color-text);letter-spacing:-.02em;font-weight:800;line-height:1.2}.metric-change{font-size:var(--font-size-xs);margin-top:var(--space-xs);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-weight:600;display:inline-flex}.metric-change.up{color:var(--color-success);background:var(--color-success-bg)}.metric-change.down{color:var(--color-danger);background:var(--color-danger-bg)}.badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);white-space:nowrap;align-items:center;gap:4px;padding:3px 10px;font-weight:600;display:inline-flex}.badge-blue{background:var(--color-info-bg);color:var(--color-primary-light)}.badge-green{background:var(--color-success-bg);color:var(--color-success)}.badge-amber{background:var(--color-warning-bg);color:var(--color-accent-dark)}.badge-red{background:var(--color-danger-bg);color:var(--color-danger)}.badge-purple{color:var(--stage-proposal);background:#f3e8ff}.badge-gray{background:var(--color-surface-active);color:var(--color-text-secondary)}.form-group{margin-bottom:var(--space-md)}.form-label{font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:6px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-text);font-size:var(--font-size-base);transition:all var(--transition-fast);padding:10px 14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding:var(--space-lg);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-xl);width:100%;max-width:540px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.3s slideUp;overflow-y:auto}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);color:var(--color-text);font-weight:700}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-surface-active);color:var(--color-text)}.modal-body{padding:var(--space-lg)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);display:flex}.table-container{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:12px 16px;font-weight:600}.table td{border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text);padding:14px 16px}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--color-surface-hover)}.table-name{color:var(--color-text);font-weight:600}.table-email{color:var(--color-text-secondary)}.table-actions{gap:var(--space-xs);display:flex}.page-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.page-header-left h1{font-size:var(--font-size-2xl);color:var(--color-text);letter-spacing:-.03em;font-weight:800}.page-header-left p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px}.grid-metrics{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.grid-2{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.kanban-board{gap:var(--space-md);padding-bottom:var(--space-md);min-height:500px;display:flex;overflow-x:auto}.kanban-column{background:var(--color-surface-hover);border-radius:var(--radius-lg);flex-direction:column;flex:0 0 280px;max-height:calc(100vh - 200px);display:flex}.kanban-column-header{padding:var(--space-md);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.kanban-column-title{align-items:center;gap:var(--space-sm);display:flex}.kanban-column-dot{border-radius:var(--radius-full);width:10px;height:10px}.kanban-column-name{font-size:var(--font-size-sm);color:var(--color-text);font-weight:600}.kanban-column-count{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-surface);border-radius:var(--radius-full);padding:2px 8px;font-weight:600}.kanban-column-body{padding:var(--space-sm);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.kanban-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);cursor:grab;transition:all var(--transition-fast)}.kanban-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.kanban-card:active{cursor:grabbing;box-shadow:var(--shadow-lg);transform:rotate(2deg)}.kanban-card-title{font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:var(--space-sm);font-weight:600}.kanban-card-client{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.kanban-card-footer{justify-content:space-between;align-items:center;display:flex}.kanban-card-value{font-size:var(--font-size-sm);color:var(--color-primary-light);font-weight:700}.kanban-card-date{font-size:var(--font-size-xs);color:var(--color-text-muted);align-items:center;gap:4px;display:flex}.kanban-card-date svg{width:14px;height:14px}.calendar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.calendar-header{padding:var(--space-lg);background:var(--color-surface);justify-content:space-between;align-items:center;display:flex}.calendar-nav{align-items:center;gap:var(--space-sm);display:flex}.calendar-month{font-size:var(--font-size-lg);color:var(--color-text);text-align:center;min-width:200px;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);display:grid}.calendar-weekday{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;border-bottom:1px solid var(--color-border);padding:10px;font-weight:600}.calendar-day{min-height:100px;padding:var(--space-sm);border:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast);position:relative}.calendar-day:hover{background:var(--color-surface-hover)}.calendar-day.today{background:var(--color-primary-alpha)}.calendar-day.other-month{opacity:.3}.calendar-day-number{font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:var(--space-xs);font-weight:600}.calendar-day.today .calendar-day-number{background:var(--color-primary-light);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;width:28px;height:28px;display:flex}.calendar-event{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:4px;margin-bottom:2px;padding:2px 6px;font-size:11px;font-weight:500;overflow:hidden}.calendar-event.event-session{background:var(--color-info-bg);color:var(--color-primary-light)}.calendar-event.event-deadline{background:var(--color-danger-bg);color:var(--color-danger)}.calendar-event.event-meeting{background:var(--color-success-bg);color:var(--color-success)}.calendar-event.event-other{background:var(--color-warning-bg);color:var(--color-accent-dark)}.task-item{align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast);display:flex}.task-item:hover{background:var(--color-surface-hover)}.task-item:last-child{border-bottom:none}.task-checkbox{border:2px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;width:20px;height:20px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.task-checkbox:hover{border-color:var(--color-primary-light)}.task-checkbox.checked{background:var(--color-primary-light);border-color:var(--color-primary-light);color:#fff}.task-checkbox.checked svg{width:14px;height:14px}.task-info{flex:1;min-width:0}.task-title{font-size:var(--font-size-sm);color:var(--color-text);font-weight:500}.task-item.completed .task-title{color:var(--color-text-muted);text-decoration:line-through}.task-meta{align-items:center;gap:var(--space-sm);margin-top:4px;display:flex}.task-due{font-size:var(--font-size-xs);color:var(--color-text-muted);align-items:center;gap:4px;display:flex}.task-due svg{width:12px;height:12px}.task-priority{border-radius:var(--radius-full);padding:1px 6px;font-size:11px;font-weight:600}.task-priority.high{background:var(--color-danger-bg);color:var(--color-danger)}.task-priority.medium{background:var(--color-warning-bg);color:var(--color-accent-dark)}.task-priority.low{background:var(--color-success-bg);color:var(--color-success)}.empty-state{padding:var(--space-3xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:64px;height:64px;color:var(--color-text-muted);margin-bottom:var(--space-lg);opacity:.5}.empty-state p{color:var(--color-text-muted);font-size:var(--font-size-base);margin-bottom:var(--space-lg)}.lead-status{align-items:center;gap:4px;display:flex}.lead-status-step{border-radius:var(--radius-full);background:var(--color-border);flex:1;max-width:32px;height:6px}.lead-status-step.active{background:var(--color-primary-light)}.lead-status-step.completed{background:var(--color-success)}.activity-item{gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light);display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px;margin-top:6px}.activity-dot.blue{background:var(--color-primary-light)}.activity-dot.green{background:var(--color-success)}.activity-dot.amber{background:var(--color-accent)}.activity-dot.red{background:var(--color-danger)}.activity-text{font-size:var(--font-size-sm);color:var(--color-text);line-height:1.5}.activity-time{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.auth-page{min-height:100vh;padding:var(--space-lg);background:linear-gradient(135deg,#e0ecf8 0%,#f0f4f8 50%,#fef3c7 100%);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:420px;padding:var(--space-2xl);animation:.4s slideUp}.auth-brand{margin-bottom:var(--space-xl);flex-direction:column;align-items:center;display:flex}.auth-brand-icon{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--color-primary-light), var(--color-accent));color:#fff;width:56px;height:56px;margin-bottom:var(--space-md);box-shadow:var(--shadow-glow);justify-content:center;align-items:center;display:flex}.auth-brand-icon svg{width:28px;height:28px}.auth-brand h1{font-size:var(--font-size-xl);color:var(--color-text);letter-spacing:-.03em;font-weight:800}.auth-brand p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:4px}.auth-divider{align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--color-text-muted);font-size:var(--font-size-xs);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-footer{text-align:center;margin-top:var(--space-lg);font-size:var(--font-size-sm);color:var(--color-text-muted)}.auth-footer a{color:var(--color-primary-light);font-weight:600}.auth-footer a:hover{text-decoration:underline}.settings-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.settings-section-title{font-size:var(--font-size-md);color:var(--color-text);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border-light);font-weight:700}.toolbar{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.toolbar-search{flex:1;max-width:320px;position:relative}.toolbar-search input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;font-size:var(--font-size-sm);transition:all var(--transition-fast);padding:9px 14px 9px 38px}.toolbar-search input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha);outline:none}.toolbar-search svg{width:16px;height:16px;color:var(--color-text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.toolbar-filters{gap:var(--space-sm);display:flex}.toolbar-filter{border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-surface);cursor:pointer;transition:all var(--transition-fast);padding:8px 14px;font-weight:500}.toolbar-filter:hover,.toolbar-filter.active{border-color:var(--color-primary-light);color:var(--color-primary-light);background:var(--color-primary-alpha)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@media (width<=1024px){.grid-metrics{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.app-main{margin-left:0}.header{left:0}.menu-toggle{display:flex}.grid-metrics,.form-row{grid-template-columns:1fr}.kanban-board{flex-direction:column}.kanban-column{flex:none;max-height:none}.header-search{display:none}.page-header{flex-direction:column;align-items:flex-start}.toolbar{flex-direction:column;align-items:stretch}.toolbar-search{max-width:none}}.sidebar-overlay{display:none}@media (width<=768px){.sidebar-overlay{z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition-base);background:#00000080;display:block;position:fixed;inset:0}.sidebar-overlay.visible{opacity:1;pointer-events:all}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-in{animation:.4s forwards slideUp}.animate-in-delay-1{opacity:0;animation-delay:50ms}.animate-in-delay-2{opacity:0;animation-delay:.1s}.animate-in-delay-3{opacity:0;animation-delay:.15s}.animate-in-delay-4{opacity:0;animation-delay:.2s}.effect-shimmer{position:relative;overflow:hidden}.effect-shimmer:before{content:"";background:linear-gradient(45deg,#0000,#ffffff1a,#0000);width:200%;height:200%;animation:3s linear infinite shimmer-anim;position:absolute;top:-50%;left:-50%;transform:rotate(45deg)}@keyframes shimmer-anim{0%{transform:translate(-100%)rotate(45deg)}to{transform:translate(100%)rotate(45deg)}}.effect-pulse-success{animation:2s infinite pulse-success-anim}@keyframes pulse-success-anim{0%{box-shadow:0 0 #10b98166}70%{box-shadow:0 0 0 15px #10b98100}to{box-shadow:0 0 #10b98100}}.effect-float{animation:3s ease-in-out infinite float-anim}@keyframes float-anim{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.effect-heartbeat{animation:1.5s ease-in-out infinite heartbeat-anim}@keyframes heartbeat-anim{0%{transform:scale(1)}14%{transform:scale(1.1)}28%{transform:scale(1)}42%{transform:scale(1.1)}70%{transform:scale(1)}}
