.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border-light);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition-base)}.sidebar-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-sm);color:var(--color-primary)}.sidebar-unit-name{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text);line-height:1.3}.sidebar-subtitle{font-size:var(--font-size-xs);color:var(--color-text-muted)}.sidebar-nav{flex:1;padding:var(--space-md) var(--space-sm);overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:.6rem .875rem;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);margin-bottom:2px;text-decoration:none}.nav-item:hover{background:var(--color-bg);color:var(--color-text)}.nav-item.active{background:var(--color-primary-bg);color:var(--color-primary);font-weight:600}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light)}.sidebar-user{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.user-info{flex:1;min-width:0}.user-name{font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--font-size-xs);color:var(--color-text-muted)}.logout-btn{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);padding:.3rem 0;transition:color var(--transition-fast)}.logout-btn:hover{color:var(--color-danger)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-xl);min-height:100vh}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border-light);padding:0 var(--space-md);align-items:center;justify-content:space-between;z-index:99}.mobile-title{font-size:var(--font-size-base);font-weight:600}.menu-toggle{padding:var(--space-xs);color:var(--color-text)}.header-avatar img{width:32px;height:32px;border-radius:50%;object-fit:cover}.sidebar-overlay{display:none}@media (max-width: 768px){.mobile-header{display:flex}.sidebar{transform:translate(-100%);width:280px;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99}.main-content{margin-left:0;padding:calc(var(--header-height) + var(--space-md)) var(--space-md) var(--space-md)}}.dashboard{max-width:1200px}.page-header{margin-bottom:var(--space-xl)}.page-title{font-size:var(--font-size-2xl);font-weight:700;line-height:1.2}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-primary:after{background:var(--color-primary)}.stat-info:after{background:var(--color-info)}.stat-warning:after{background:var(--color-warning)}.stat-muted:after{background:var(--color-text-muted)}.stat-icon{margin-bottom:var(--space-sm);opacity:.6}.stat-value{font-size:var(--font-size-3xl);font-weight:700;line-height:1;margin-bottom:var(--space-xs)}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.status-bars{display:flex;flex-direction:column;gap:var(--space-sm)}.status-bar-row{display:flex;align-items:center;gap:var(--space-sm)}.status-bar-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);min-width:100px;white-space:nowrap}.status-bar-track{flex:1;height:8px;background:var(--color-bg);border-radius:4px;overflow:hidden}.status-bar-fill{height:100%;background:var(--color-primary-light);border-radius:4px;min-width:4px;transition:width .5s ease}.status-bar-count{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text);min-width:24px;text-align:right}.event-list-mini{display:flex;flex-direction:column;gap:1px}.event-mini-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-light);color:var(--color-text);text-decoration:none;transition:background var(--transition-fast)}.event-mini-item:last-child{border-bottom:none}.event-mini-item:hover{background:var(--color-primary-bg);margin:0 calc(-1 * var(--space-lg));padding-left:var(--space-lg);padding-right:var(--space-lg)}.event-mini-name{font-size:var(--font-size-sm);font-weight:500}.event-mini-meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:2px;font-size:var(--font-size-xs);color:var(--color-text-muted)}.event-mini-att{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.type-stats{display:flex;flex-direction:column;gap:var(--space-md)}.type-stat-header{display:flex;justify-content:space-between;margin-bottom:4px}.type-stat-name{font-size:var(--font-size-sm);font-weight:500}.type-stat-rate{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary)}.type-stat-bar{height:6px;background:var(--color-bg);border-radius:3px;overflow:hidden}.type-stat-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));border-radius:3px;transition:width .5s ease}.type-stat-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}@media (max-width: 768px){.stat-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}@media (max-width: 480px){.stat-grid{grid-template-columns:1fr 1fr;gap:var(--space-sm)}.stat-card{padding:var(--space-md)}.stat-value{font-size:var(--font-size-xl)}}.member-page{max-width:1200px}.th-name{min-width:160px}.th-wrap{white-space:normal!important;min-width:80px;max-width:150px}.td-recent-events{max-width:180px}.filter-bar{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.filter-search{flex:1;min-width:200px;display:flex;align-items:center;gap:var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-md);transition:border-color var(--transition-fast)}.filter-search:focus-within{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #2980b926}.filter-search input{border:none;outline:none;background:none;padding:.6rem 0;width:100%;font-size:var(--font-size-sm)}.filter-search .material-icons-outlined{color:var(--color-text-muted)}.member-detail{max-width:800px}.member-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md) var(--space-lg)}.member-form-grid .form-group.full-width{grid-column:1 / -1}.back-link{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-md)}.back-link:hover{color:var(--color-primary)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle;background:var(--color-text-muted)}.dot-success{background:var(--color-success)}.dot-info{background:var(--color-primary)}.dot-muted{background:var(--color-text-muted)}.dot-danger{background:var(--color-danger)}.event-history-list{list-style:none;padding:0;margin:0}.event-history-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-sm)}.event-history-item:last-child{border-bottom:none}.event-history-name{flex:1;font-weight:500;cursor:pointer}.event-history-name:hover{color:var(--color-primary)}.event-history-date{font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:100px}.event-history-type{font-size:var(--font-size-xs)}.event-history-controls{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}.th-event-col{white-space:normal!important;min-width:50px;max-width:80px;font-size:var(--font-size-xs)!important;text-align:center!important}.th-event-count{min-width:70px;text-align:center!important}.td-event-cell{text-align:center;padding:.3rem!important}.td-event-count{text-align:center;white-space:nowrap}.attendance-count{font-weight:600;font-size:var(--font-size-base);margin-right:2px}.ev-mark{font-weight:600;font-size:var(--font-size-sm)}.ev-attended{color:var(--color-success)}.ev-pre{color:var(--color-primary)}.ev-absent{color:var(--color-danger)}.ev-late{color:var(--color-warning);font-size:var(--font-size-xs)}.ev-none{color:var(--color-text-muted)}@media (max-width: 768px){.hide-mobile{display:none}.member-form-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column}.filter-bar .form-select{max-width:100%!important}.event-history-controls{flex-direction:column;align-items:flex-start}}.events-page{max-width:1200px}.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-md)}.event-card{cursor:pointer;transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.event-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.event-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.event-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.event-name{font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--space-sm)}.event-location{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.event-attendance-bar{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-secondary);padding-top:var(--space-sm);border-top:1px solid var(--color-border-light)}.event-rate{font-weight:600;color:var(--color-primary)}.event-detail{max-width:900px}.attendance-controls{display:flex;gap:var(--space-md);align-items:center;flex-wrap:wrap;margin-bottom:var(--space-md)}.bulk-modal{width:500px;max-width:95vw;max-height:80vh;display:flex;flex-direction:column}.bulk-modal .modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.bulk-list{flex:1;overflow-y:auto;max-height:400px;border:1px solid var(--color-border-light);border-radius:var(--radius-md)}.bulk-check-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background var(--transition-fast)}.bulk-check-item:hover{background:var(--color-bg-hover)}.bulk-check-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.bulk-select-header{margin-bottom:0}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light)}.check-mode-hint{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-sm)}.check-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md);border:2px solid var(--color-border-light);border-radius:var(--radius-lg);background:var(--color-bg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.check-card:hover{border-color:var(--color-primary);background:var(--color-bg-hover)}.check-card.checked{border-color:var(--color-success);background:var(--color-success-bg, #f0fdf4)}.check-card .check-icon{color:var(--color-text-muted)}.check-card.checked .check-icon{color:var(--color-success)}.check-card .check-name{font-weight:600;font-size:var(--font-size-sm)}.check-card .check-status{font-size:var(--font-size-xs);color:var(--color-text-muted)}.check-card.checked .check-status{color:var(--color-success)}.form-mapping .mapping-table{display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-xs)}.mapping-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:var(--color-bg-secondary);border-radius:var(--radius-sm)}.mapping-form-col{flex:1;font-size:var(--font-size-sm);font-weight:500;min-width:120px}.mapping-member-col{flex:1;min-width:150px}.preview-summary{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.summary-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm)}.summary-count{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary)}.diff-section{margin-top:var(--space-md)}.diff-card{border:1px solid var(--color-border-light);border-radius:var(--radius-md);margin-bottom:var(--space-sm);overflow:hidden}.diff-card-header{font-weight:600;font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border-light)}.diff-row{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-light)}.diff-row:last-child{border-bottom:none}.diff-field{display:block;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.diff-options{display:flex;flex-direction:column;gap:4px}.diff-option{display:flex;align-items:center;gap:var(--space-xs);padding:4px var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast)}.diff-option:hover{background:var(--color-bg-hover)}.diff-option.selected{background:var(--color-primary-bg, #eff6ff)}.diff-option input[type=radio]{accent-color:var(--color-primary)}.diff-label{font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:50px}.diff-value{font-size:var(--font-size-sm);word-break:break-all}.diff-edit{flex-wrap:wrap}.diff-edit-input{flex:1;min-width:150px;padding:2px 6px;font-size:var(--font-size-sm)}.badge-success{background:var(--color-success-bg, #f0fdf4);color:var(--color-success);padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}@media (max-width: 768px){.event-grid{grid-template-columns:1fr}.check-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.bulk-modal{width:100%}}.settings-page{max-width:900px}.settings-tabs{display:flex;gap:2px;margin-bottom:var(--space-lg);border-bottom:2px solid var(--color-border-light);overflow-x:auto;-webkit-overflow-scrolling:touch}.settings-tab{display:flex;align-items:center;gap:var(--space-xs);padding:.65rem 1rem;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast);white-space:nowrap}.settings-tab:hover{color:var(--color-text);background:var(--color-bg)}.settings-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.settings-section-title{font-size:var(--font-size-base);font-weight:600}.settings-help{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-lg);line-height:1.7}.option-list{display:flex;flex-direction:column;gap:1px;margin-bottom:var(--space-md)}.option-item{display:flex;align-items:center;gap:var(--space-sm);padding:.5rem .75rem;background:var(--color-bg);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.option-item:hover{background:var(--color-primary-bg)}.option-order{font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:24px;text-align:center}.option-name{flex:1;font-size:var(--font-size-sm);font-weight:500}.add-option-row{display:flex;gap:var(--space-sm);align-items:center}.cf-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg)}.cf-item{border:1px solid var(--color-border-light);border-radius:var(--radius-md);overflow:hidden}.cf-item-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;background:var(--color-bg);transition:background var(--transition-fast)}.cf-item-header:hover{background:var(--color-primary-bg)}.cf-item-name{font-weight:600;font-size:var(--font-size-sm)}.cf-item-body{padding:var(--space-md);border-top:1px solid var(--color-border-light)}@media (max-width: 768px){.settings-tabs{gap:0}.settings-tab{padding:.5rem .75rem;font-size:var(--font-size-xs)}.add-option-row{flex-direction:column;align-items:stretch}}.help-page{max-width:1000px}.help-layout{display:grid;grid-template-columns:220px 1fr;gap:var(--space-lg);align-items:start}.help-nav{display:flex;flex-direction:column;gap:2px;position:sticky;top:var(--space-lg)}.help-nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:.5rem .75rem;font-size:var(--font-size-sm);color:var(--color-text-secondary);border-radius:var(--radius-md);text-align:left;transition:all var(--transition-fast)}.help-nav-item:hover{background:var(--color-bg);color:var(--color-text)}.help-nav-item.active{background:var(--color-primary-bg);color:var(--color-primary);font-weight:600}.help-section-title{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-lg);color:var(--color-primary)}.help-text{font-size:var(--font-size-sm);line-height:1.8;color:var(--color-text)}.help-text strong{display:block;margin-top:var(--space-md);margin-bottom:var(--space-xs);font-size:var(--font-size-base);color:var(--color-text)}.help-text ul{padding-left:1.5rem;margin:var(--space-xs) 0 var(--space-md)}.help-text li{margin-bottom:var(--space-xs)}@media (max-width: 768px){.help-layout{grid-template-columns:1fr}.help-nav{flex-direction:row;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:0;position:static;border-bottom:1px solid var(--color-border-light);padding-bottom:var(--space-sm);margin-bottom:var(--space-md)}.help-nav-item{white-space:nowrap;padding:.4rem .6rem;font-size:var(--font-size-xs)}.help-nav-item span{display:none}}:root{--color-primary: #1a5276;--color-primary-light: #2980b9;--color-primary-dark: #0e3651;--color-primary-bg: #eaf2f8;--color-accent: #c0392b;--color-accent-light: #e74c3c;--color-success: #27ae60;--color-success-bg: #eafaf1;--color-warning: #f39c12;--color-warning-bg: #fef9e7;--color-danger: #e74c3c;--color-danger-bg: #fdedec;--color-info: #3498db;--color-info-bg: #ebf5fb;--color-bg: #f5f6fa;--color-surface: #ffffff;--color-surface-hover: #f8f9fc;--color-border: #dce1e8;--color-border-light: #edf0f5;--color-text: #2c3e50;--color-text-secondary: #7f8c8d;--color-text-muted: #bdc3c7;--color-text-inverse: #ffffff;--font-primary: "Zen Kaku Gothic New", "Noto Sans JP", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.375rem;--font-size-2xl: 1.75rem;--font-size-3xl: 2.25rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--sidebar-width: 260px;--header-height: 56px;--transition-fast: .15s ease;--transition-base: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-primary);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}button{font-family:var(--font-primary);cursor:pointer;border:none;background:none;font-size:inherit}input,select,textarea{font-family:var(--font-primary);font-size:var(--font-size-base)}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.5rem 1.25rem;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-size-sm);transition:all var(--transition-fast);white-space:nowrap;line-height:1.4}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-md)}.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-primary-light)}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse)}.btn-danger:hover{background:var(--color-accent)}.btn-sm{padding:.3rem .75rem;font-size:var(--font-size-xs)}.btn-icon{padding:.4rem;border-radius:var(--radius-sm)}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.form-input{width:100%;padding:.6rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #2980b926}.form-select{width:100%;padding:.6rem 2rem .6rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);outline:none;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='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237f8c8d' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.form-select:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #2980b926}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.card-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between}.card-body{padding:var(--space-lg)}.badge{display:inline-flex;align-items:center;padding:.15rem .6rem;border-radius:9999px;font-size:var(--font-size-xs);font-weight:500;white-space:nowrap}.badge-primary{background:var(--color-primary-bg);color:var(--color-primary)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.data-table{width:100%;border-collapse:collapse}.data-table th{background:var(--color-bg);padding:.65rem .75rem;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--color-border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.data-table th:hover{color:var(--color-primary)}.data-table th .sort-icon{font-size:14px;vertical-align:middle;margin-left:2px;opacity:.4}.data-table th .sort-icon.active{opacity:1;color:var(--color-primary)}.data-table td{padding:.65rem .75rem;border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-sm);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast);cursor:pointer}.data-table tbody tr:hover{background:var(--color-primary-bg)}.inline-select{padding:.2rem .5rem;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;font-size:var(--font-size-xs);font-weight:500;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:all var(--transition-fast)}.inline-select:hover,.inline-select:focus{border-color:var(--color-border);background:var(--color-surface)}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:9999;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{padding:.75rem 1.25rem;border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-lg);border-left:4px solid var(--color-primary);font-size:var(--font-size-sm);animation:slideIn .3s ease;max-width:380px}.toast-success{border-left-color:var(--color-success)}.toast-error{border-left-color:var(--color-danger)}.toast-warning{border-left-color:var(--color-warning)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);animation:fadeIn .2s ease}.modal-content{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:scaleIn .2s ease}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:var(--space-lg)}.modal-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light);display:flex;justify-content:flex-end;gap:var(--space-sm)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--color-text-muted)}.empty-state .material-icons-outlined{font-size:48px;margin-bottom:var(--space-md);opacity:.5}@media (max-width: 768px){:root{--sidebar-width: 0px;--header-height: 56px}.data-table{font-size:var(--font-size-xs)}.data-table th,.data-table td{padding:.5rem}.modal-content{max-width:100%;margin:var(--space-md);border-radius:var(--radius-lg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}
