:root{--color-primary: #4f46e5;--color-primary-dark: #3730a3;--color-primary-light: #e0e7ff;--color-primary-bg: #eef2ff;--color-text: #1e293b;--color-text-secondary: #64748b;--color-text-tertiary: #94a3b8;--color-white: #ffffff;--color-bg: #ffffff;--color-bg-alt: #f8fafc;--color-bg-hover: #f1f5f9;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-success: #10b981;--color-success-light: #d1fae5;--color-success-text: #065f46;--color-danger: #dc2626;--color-danger-light: #fee2e2;--color-danger-text: #991b1b;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-text: #92400e;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-info-text: #1e40af;--color-neutral: #6b7280;--color-neutral-light: #f3f4f6;--color-neutral-text: #374151;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--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;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: .875rem;--radius-xl: 1.25rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .05);--transition-fast: .15s ease;--transition-base: .22s ease;--sidebar-width: 232px;--sidebar-collapsed-width: 60px;--navbar-height: 60px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg-alt);line-height:1.5}button{font-family:var(--font-sans);cursor:pointer;border:none;background:none}input,select,textarea{font-family:var(--font-sans)}a{text-decoration:none;color:inherit}ul,ol{list-style:none}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);height:100vh;background:var(--color-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0;transition:width var(--transition-base);overflow:hidden;z-index:100}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar__logo-area{height:var(--navbar-height);display:flex;align-items:center;padding:0 var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0;gap:var(--space-3)}.sidebar__logo-icon{width:32px;height:32px;background:var(--color-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0}.sidebar__logo-text{font-size:var(--text-base);font-weight:700;color:var(--color-text);white-space:nowrap;overflow:hidden;opacity:1;transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar__logo-text{opacity:0;width:0}.sidebar__nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-4) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar__section-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);padding:var(--space-3) var(--space-3) var(--space-2);white-space:nowrap;overflow:hidden;opacity:1;transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar__section-label{opacity:0}.sidebar__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:500;white-space:nowrap;position:relative}.sidebar__item:hover{background:var(--color-bg-hover);color:var(--color-text)}.sidebar__item.active{background:var(--color-primary-bg);color:var(--color-primary)}.sidebar__item-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar__item-label{overflow:hidden;opacity:1;transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar__item-label{opacity:0;width:0}.sidebar__item-badge{margin-left:auto;background:var(--color-primary);color:#fff;font-size:.625rem;font-weight:700;padding:2px 6px;border-radius:var(--radius-full);line-height:1.4;opacity:1;transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar__item-badge{opacity:0}.sidebar__bottom{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border);flex-shrink:0}.sidebar__toggle{display:flex;align-items:center;justify-content:center;width:100%;padding:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.sidebar__toggle:hover{background:var(--color-bg-hover);color:var(--color-text)}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.navbar{height:var(--navbar-height);background:var(--color-bg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--space-6);gap:var(--space-4);flex-shrink:0;z-index:50}.navbar__breadcrumb{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.navbar__breadcrumb-item{font-size:var(--text-sm);color:var(--color-text-secondary)}.navbar__breadcrumb-separator{color:var(--color-text-tertiary);font-size:var(--text-sm)}.navbar__breadcrumb-current{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}.navbar__search{position:relative;width:280px}.navbar__search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.navbar__search-input{width:100%;height:36px;padding:0 var(--space-3) 0 2.25rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.navbar__search-input::placeholder{color:var(--color-text-tertiary)}.navbar__search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}.navbar__actions{display:flex;align-items:center;gap:var(--space-2)}.navbar__icon-btn{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast);position:relative}.navbar__icon-btn:hover{background:var(--color-bg-hover);color:var(--color-text)}.navbar__notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--color-danger);border-radius:50%;border:1.5px solid var(--color-bg)}.navbar__avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-primary);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;cursor:pointer;flex-shrink:0;transition:opacity var(--transition-fast)}.navbar__avatar:hover{opacity:.85}.page-content{flex:1;overflow-y:auto;padding:var(--space-6);background:var(--color-bg-alt)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4)}.page-title{font-size:var(--text-2xl);font-weight:700;color:var(--color-text);line-height:1.2}.page-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.page-actions{display:flex;align-items:center;gap:var(--space-3)}.stat-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:var(--space-3);transition:box-shadow var(--transition-base),transform var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card__header{display:flex;align-items:center;justify-content:space-between}.stat-card__label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary)}.stat-card__icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.stat-card__value{font-size:2rem;font-weight:800;color:var(--color-text);line-height:1}.stat-card__footer{display:flex;align-items:center;gap:var(--space-2)}.stat-card__change{font-size:var(--text-xs);font-weight:600;display:flex;align-items:center;gap:2px}.stat-card__change--up{color:var(--color-success)}.stat-card__change--down{color:var(--color-danger)}.stat-card__change-label{font-size:var(--text-xs);color:var(--color-text-tertiary)}.card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs)}.card__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.card__title{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.card__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:2px}.card__body{padding:var(--space-6)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;border-radius:var(--radius-md);padding:0 var(--space-4);height:36px;transition:background var(--transition-fast),box-shadow var(--transition-fast),opacity var(--transition-fast),border-color var(--transition-fast);cursor:pointer;white-space:nowrap;border:1px solid transparent}.btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn--primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:0 2px 8px #4f46e54d}.btn--secondary{background:var(--color-bg);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover{background:var(--color-bg-hover);border-color:#cbd5e1}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover{background:var(--color-bg-hover);color:var(--color-text)}.btn--danger{background:var(--color-danger-light);color:var(--color-danger-text);border-color:#fecaca}.btn--danger:hover{background:#fecaca}.btn--sm{height:30px;padding:0 var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn--lg{height:44px;padding:0 var(--space-6);font-size:var(--text-base)}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;line-height:1.4;white-space:nowrap}.badge--success{background:var(--color-success-light);color:var(--color-success-text)}.badge--danger{background:var(--color-danger-light);color:var(--color-danger-text)}.badge--warning{background:var(--color-warning-light);color:var(--color-warning-text)}.badge--info{background:var(--color-info-light);color:var(--color-info-text)}.badge--neutral{background:var(--color-neutral-light);color:var(--color-neutral-text)}.badge--primary{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);gap:var(--space-4);flex-wrap:wrap}.table-toolbar__left,.table-toolbar__right{display:flex;align-items:center;gap:var(--space-3)}.table-search{position:relative;width:240px}.table-search__icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.table-search__input{width:100%;height:34px;padding:0 var(--space-3) 0 2.25rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);outline:none;transition:border-color var(--transition-fast)}.table-search__input::placeholder{color:var(--color-text-tertiary)}.table-search__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e514}.table-filter-select{height:34px;padding:0 var(--space-3);background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);outline:none;cursor:pointer;transition:border-color var(--transition-fast)}.table-filter-select:focus{border-color:var(--color-primary)}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table thead{background:var(--color-bg-alt)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-tertiary);white-space:nowrap;border-bottom:1px solid var(--color-border)}.table__sort-btn{display:inline-flex;align-items:center;gap:var(--space-1);cursor:pointer;color:var(--color-text-tertiary);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;transition:color var(--transition-fast)}.table__sort-btn:hover,.table__sort-btn.active{color:var(--color-text)}.table td{padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text);border-bottom:1px solid var(--color-border-light);vertical-align:middle}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--color-bg-alt)}.table tbody tr.clickable{cursor:pointer}.table tbody tr:last-child td{border-bottom:none}.table__asset-name{font-weight:500;color:var(--color-text)}.table__asset-id{font-size:var(--text-xs);color:var(--color-text-tertiary);font-family:SF Mono,Fira Code,monospace;margin-top:2px}.table__user-cell{display:flex;align-items:center;gap:var(--space-2)}.table__user-avatar{width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;flex-shrink:0}.table__empty{padding:var(--space-12) var(--space-6);text-align:center;color:var(--color-text-secondary)}.table__empty-icon{width:48px;height:48px;margin:0 auto var(--space-4);color:var(--color-text-tertiary)}.table__empty-text{font-weight:500;margin-bottom:var(--space-1)}.table__empty-sub{font-size:var(--text-sm);color:var(--color-text-tertiary)}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.table-footer__count{font-size:var(--text-sm);color:var(--color-text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .15s ease}.modal{background:var(--color-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .2s cubic-bezier(.16,1,.3,1)}.modal--lg{max-width:680px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal__title{font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.modal__close{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.modal__close:hover{background:var(--color-bg-hover);color:var(--color-text)}.modal__body{overflow-y:auto;padding:var(--space-6);flex:1}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);flex-shrink:0}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:150;animation:fadeIn .15s ease}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;background:var(--color-bg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;z-index:151;animation:slideInRight .22s cubic-bezier(.16,1,.3,1)}.drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.drawer__title{font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.drawer__close{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:background var(--transition-fast)}.drawer__close:hover{background:var(--color-bg-hover);color:var(--color-text)}.drawer__body{flex:1;overflow-y:auto;padding:var(--space-6)}.drawer__section{margin-bottom:var(--space-6)}.drawer__section-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-bottom:var(--space-3)}.drawer__field{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}.drawer__field-label{font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary)}.drawer__field-value{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.drawer__field-mono{font-family:SF Mono,Fira Code,monospace;font-size:var(--text-sm);color:var(--color-text)}.drawer__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.drawer__footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.form-group:last-child{margin-bottom:0}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.form-label span{color:var(--color-danger)}.form-input,.form-select,.form-textarea{width:100%;padding:0 var(--space-3);height:38px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-textarea{height:auto;padding:var(--space-3);resize:vertical;min-height:80px}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-tertiary)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.chart-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden}.chart-card__header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-5) var(--space-6) var(--space-4)}.chart-card__title{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.chart-card__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:2px}.chart-card__body{padding:0 var(--space-6) var(--space-6)}.donut-chart-wrap{display:flex;align-items:center;gap:var(--space-8)}.donut-chart{flex-shrink:0}.donut-legend{flex:1;display:flex;flex-direction:column;gap:var(--space-3)}.donut-legend__item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.donut-legend__left{display:flex;align-items:center;gap:var(--space-2)}.donut-legend__dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.donut-legend__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.donut-legend__count{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}.bar-chart{display:flex;flex-direction:column;gap:var(--space-3)}.bar-chart__item{display:flex;align-items:center;gap:var(--space-3)}.bar-chart__label{width:72px;font-size:var(--text-xs);color:var(--color-text-secondary);text-align:right;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-chart__track{flex:1;height:8px;background:var(--color-bg-alt);border-radius:var(--radius-full);overflow:hidden}.bar-chart__fill{height:100%;border-radius:var(--radius-full);background:var(--color-primary);transition:width .8s cubic-bezier(.16,1,.3,1)}.bar-chart__value{width:28px;font-size:var(--text-xs);font-weight:600;color:var(--color-text);text-align:right;flex-shrink:0}.activity-feed{display:flex;flex-direction:column}.activity-item{display:flex;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.activity-item:hover{background:var(--color-bg-alt)}.activity-item:last-child{border-bottom:none}.activity-item__icon-wrap{flex-shrink:0;width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.activity-item__content{flex:1;min-width:0}.activity-item__header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2);margin-bottom:2px}.activity-item__title{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.activity-item__time{font-size:var(--text-xs);color:var(--color-text-tertiary);white-space:nowrap;flex-shrink:0}.activity-item__detail{font-size:var(--text-xs);color:var(--color-text-secondary)}.dashboard-lower{display:grid;grid-template-columns:1fr 380px;gap:var(--space-4)}.people-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;color:#fff;flex-shrink:0}.people-name{font-weight:500;font-size:var(--text-sm)}.people-email{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:1px}.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.location-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-base),transform var(--transition-base)}.location-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.location-card__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4)}.location-card__icon{width:44px;height:44px;border-radius:var(--radius-lg);background:var(--color-primary-bg);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.location-card__name{font-size:var(--text-lg);font-weight:700;color:var(--color-text);margin-bottom:var(--space-1)}.location-card__address{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.4}.location-card__stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.location-stat{display:flex;flex-direction:column;gap:2px}.location-stat__value{font-size:var(--text-xl);font-weight:700;color:var(--color-text)}.location-stat__label{font-size:var(--text-xs);color:var(--color-text-secondary)}.reports-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.report-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-xs)}.report-card__title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.report-card__value{font-size:var(--text-3xl);font-weight:800;color:var(--color-text);line-height:1;margin-bottom:var(--space-2)}.report-card__trend{font-size:var(--text-xs);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-1)}.report-chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.vbar-chart{display:flex;align-items:flex-end;gap:var(--space-3);height:160px;padding:0 var(--space-2)}.vbar-chart__bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);height:100%;justify-content:flex-end}.vbar-chart__bar{width:100%;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:var(--color-primary);transition:height .8s cubic-bezier(.16,1,.3,1);position:relative}.vbar-chart__bar:hover{opacity:.8}.vbar-chart__label{font-size:.625rem;color:var(--color-text-tertiary);white-space:nowrap}.settings-layout{display:grid;grid-template-columns:200px 1fr;gap:var(--space-6);align-items:start}.settings-nav{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-2);box-shadow:var(--shadow-xs)}.settings-nav__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.settings-nav__item:hover{background:var(--color-bg-hover);color:var(--color-text)}.settings-nav__item.active{background:var(--color-primary-bg);color:var(--color-primary)}.settings-panel{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden}.settings-section{padding:var(--space-6);border-bottom:1px solid var(--color-border)}.settings-section:last-child{border-bottom:none}.settings-section__title{font-size:var(--text-base);font-weight:700;color:var(--color-text);margin-bottom:var(--space-1)}.settings-section__desc{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-5)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-light)}.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row__label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.settings-row__desc{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:2px}.toggle{position:relative;width:40px;height:22px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle__track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-border);border-radius:var(--radius-full);transition:background var(--transition-base);cursor:pointer}.toggle input:checked+.toggle__track{background:var(--color-primary)}.toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--transition-base);box-shadow:0 1px 3px #00000026}.toggle input:checked+.toggle__track:after{transform:translate(18px)}.navbar__notif-wrap{position:relative}.notif-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;background:var(--color-danger);color:#fff;font-size:.625rem;font-weight:700;border-radius:var(--radius-full);border:1.5px solid var(--color-bg);display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:360px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:300;overflow:hidden;animation:fadeIn .14s ease}.notif-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}.notif-panel__title{font-size:var(--text-sm);font-weight:700;color:var(--color-text)}.notif-panel__mark-all{font-size:var(--text-xs);font-weight:600;color:var(--color-primary);cursor:pointer;background:none;border:none;padding:0;transition:opacity var(--transition-fast)}.notif-panel__mark-all:hover{opacity:.75}.notif-list{max-height:400px;overflow-y:auto}.notif-item{display:flex;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast);cursor:pointer}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--color-bg-alt)}.notif-item--unread{background:var(--color-primary-bg)}.notif-item--unread:hover{background:#e4e8fd}.notif-item__icon{width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-item__body{flex:1;min-width:0}.notif-item__title{font-size:var(--text-sm);font-weight:500;color:var(--color-text);line-height:1.4;margin-bottom:2px}.notif-item__desc{font-size:var(--text-xs);color:var(--color-text-secondary);line-height:1.4}.notif-item__time{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-top:4px}.notif-item__unread-dot{width:7px;height:7px;border-radius:50%;background:var(--color-primary);flex-shrink:0;margin-top:6px}.notif-panel__footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border);text-align:center}.notif-panel__footer-btn{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);cursor:pointer;background:none;border:none;transition:color var(--transition-fast)}.notif-panel__footer-btn:hover{color:var(--color-text)}.calendar-layout{display:grid;grid-template-columns:1fr 300px;gap:var(--space-4);align-items:start}.calendar-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden}.calendar-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.calendar-nav__title{font-size:var(--text-xl);font-weight:700;color:var(--color-text)}.calendar-nav__btn{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast);cursor:pointer}.calendar-nav__btn:hover{background:var(--color-bg-hover);color:var(--color-text)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--color-border)}.calendar-weekday{padding:var(--space-3) var(--space-2);text-align:center;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-cell{min-height:92px;padding:var(--space-2);border-right:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast);position:relative}.calendar-cell:nth-child(7n){border-right:none}.calendar-cell:hover{background:var(--color-bg-alt)}.calendar-cell--empty{background:var(--color-bg-alt);cursor:default}.calendar-cell--today .calendar-day-num{background:var(--color-primary);color:#fff}.calendar-cell--selected,.calendar-cell--selected:hover{background:var(--color-primary-bg)}.calendar-day-num{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:var(--text-sm);font-weight:500;color:var(--color-text);margin-bottom:var(--space-1)}.calendar-cell--empty .calendar-day-num{color:var(--color-text-tertiary)}.calendar-events{display:flex;flex-direction:column;gap:2px}.calendar-event-pill{font-size:.625rem;font-weight:600;padding:2px 6px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.calendar-event-pill--warranty{background:var(--color-danger-light);color:var(--color-danger-text)}.calendar-event-pill--maintenance{background:var(--color-warning-light);color:var(--color-warning-text)}.calendar-event-pill--audit{background:var(--color-info-light);color:var(--color-info-text)}.calendar-event-pill--checkin{background:var(--color-success-light);color:var(--color-success-text)}.calendar-event-pill--insurance{background:#f5f3ff;color:#5b21b6}.calendar-more{font-size:.625rem;color:var(--color-text-tertiary);font-weight:500;padding:1px 4px}.calendar-side{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden;position:sticky;top:var(--space-6)}.calendar-side__header{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--color-border)}.calendar-side__title{font-size:var(--text-base);font-weight:700;color:var(--color-text)}.calendar-side__sub{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:2px}.calendar-event-list{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.calendar-event-item{display:flex;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:background var(--transition-fast)}.calendar-event-item:hover{background:var(--color-bg-alt)}.calendar-event-item__dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;margin-top:3px}.calendar-event-item__title{font-size:var(--text-sm);font-weight:500;color:var(--color-text);line-height:1.3}.calendar-event-item__meta{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:2px}.calendar-event-empty{padding:var(--space-8) var(--space-5);text-align:center;color:var(--color-text-tertiary);font-size:var(--text-sm)}.calendar-legend{display:flex;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.calendar-legend__item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-secondary)}.calendar-legend__dot{width:10px;height:10px;border-radius:3px}.world-map-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden;margin-bottom:var(--space-6)}.world-map-card__header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.world-map-card__title{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.world-map-card__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:2px}.world-map-card__body{padding:var(--space-4) var(--space-6) var(--space-5)}.world-map-wrap{position:relative;width:100%;border-radius:var(--radius-lg);overflow:hidden;background:#d6eaf8}.world-map-svg{display:block;width:100%;height:auto}.map-bubble-group{cursor:pointer}.map-bubble-group:hover .map-bubble-circle{filter:brightness(1.1)}.map-tooltip{pointer-events:none;position:absolute;background:var(--color-text);color:#fff;font-size:var(--text-xs);font-weight:500;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);white-space:nowrap;z-index:10;transform:translate(-50%,-110%);box-shadow:var(--shadow-md)}.map-tooltip:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:8px;height:8px;background:var(--color-text);clip-path:polygon(0 0,100% 0,50% 100%)}.map-legend-row{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-4);flex-wrap:wrap;gap:var(--space-3)}.map-legend-scale{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-secondary)}.map-legend-gradient{width:80px;height:8px;border-radius:var(--radius-full);background:linear-gradient(to right,#10b981,#f59e0b,#dc2626)}.map-remote-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-neutral-light);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;color:var(--color-neutral-text)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#cbd5e1}@media (max-width: 1280px){.stat-cards-grid{grid-template-columns:repeat(2,1fr)}.dashboard-lower,.charts-grid{grid-template-columns:1fr}}@media (max-width: 1024px){.reports-grid{grid-template-columns:repeat(2,1fr)}.report-chart-grid,.settings-layout{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar__logo-text,.sidebar__item-label,.sidebar__section-label,.sidebar__item-badge,.navbar__search{display:none}.stat-cards-grid{grid-template-columns:repeat(2,1fr)}.page-content{padding:var(--space-4)}.reports-grid,.locations-grid{grid-template-columns:1fr}}
