@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.page-header{margin-bottom:var(--spacing-xl);display:flex;justify-content:space-between;align-items:center}.page-header h1{margin-bottom:var(--spacing-xs)}.required{color:var(--color-danger);margin-left:var(--spacing-xs)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);line-height:1.5;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:var(--font-family)}.form-hint{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--text-secondary)}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-gray-200)}.location-status{text-align:center;padding:var(--spacing-lg)}.status-badge{display:inline-block;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-weight:600;font-size:var(--font-size-lg)}.status-success{background:#d1fae5;color:#065f46}.status-warning{background:#fef3c7;color:#92400e}.attendance-methods{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--spacing-lg);align-items:center}.method-card{text-align:center;padding:var(--spacing-xl);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.method-icon{font-size:4rem;margin-bottom:var(--spacing-md)}.method-card h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-sm)}.method-card p{margin-bottom:var(--spacing-lg);min-height:3em}.method-divider{font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:var(--font-size-sm)}.report-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.report-item{padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:4px solid transparent;display:flex;justify-content:space-between;align-items:center;transition:all var(--transition-fast)}.report-item:hover{background:var(--bg-secondary)}.report-item.active{background:var(--bg-tertiary);border-left-color:var(--color-primary)}.report-info{flex:1}.report-student,.report-date,.report-facility{margin:var(--spacing-xs) 0}.report-student{font-weight:600;color:var(--text-primary)}.report-date,.report-facility{font-size:var(--font-size-sm);color:var(--text-secondary)}.report-detail{margin-bottom:var(--spacing-xl)}.report-section{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.report-section:last-child{border-bottom:none}.report-section h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--text-primary)}.report-section p{color:var(--text-secondary);line-height:1.8;white-space:pre-wrap}.report-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.meta-item{display:flex;flex-direction:column}.meta-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.meta-value{font-weight:500;color:var(--text-primary)}.approval-section{background:var(--bg-tertiary);padding:var(--spacing-lg);border-radius:var(--radius-md);margin-top:var(--spacing-xl)}.approval-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}.user-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.user-form-grid .form-group-full{grid-column:1 / -1}.filter-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.filter-bar .form-group{margin:0;flex:1}.filter-bar .form-label{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.filter-bar .form-input,.filter-bar .form-select{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.evaluation-grid{display:grid;gap:var(--spacing-lg)}.evaluation-item{padding:var(--spacing-lg);background:var(--bg-tertiary);border-radius:var(--radius-md)}.evaluation-item h4{margin-bottom:var(--spacing-md);font-size:var(--font-size-lg)}.rating-group{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.rating-option{flex:1}.rating-option input[type=radio]{display:none}.rating-label{display:block;padding:var(--spacing-sm);text-align:center;background:var(--bg-primary);border:2px solid var(--color-gray-300);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.rating-option input[type=radio]:checked+.rating-label{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary)}.rating-label:hover{border-color:var(--color-primary)}.rating-description{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.modal-header h2{margin:0;font-size:var(--font-size-xl)}.modal-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:var(--text-secondary);padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-gray-200)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary)}.empty-state p{margin:0;font-size:var(--font-size-lg)}@media (max-width: 768px){.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}.attendance-methods{grid-template-columns:1fr}.method-divider{display:none}.user-form-grid{grid-template-columns:1fr}.filter-bar,.rating-group{flex-direction:column}.page-header{flex-direction:column;align-items:flex-start}font-size: var(--font-size-lg)}.filter-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-gray-200)}.filter-tab{padding:var(--spacing-sm) var(--spacing-lg);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast);margin-bottom:-2px}.filter-tab:hover{color:var(--text-primary)}.filter-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.text-warning{color:var(--color-warning)}.schedule-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.schedule-card{background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border-left:4px solid var(--color-gray-300);transition:all var(--transition-fast)}.schedule-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.schedule-today{border-left-color:var(--color-primary);background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(99,102,241,.05) 100%)}.schedule-header{display:flex;gap:var(--spacing-lg);align-items:flex-start}.schedule-date{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-primary);color:var(--text-inverse);border-radius:var(--radius-md);padding:var(--spacing-sm);min-width:60px;text-align:center}.date-day{font-size:2rem;font-weight:700;line-height:1}.date-month{font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.schedule-info{flex:1}.schedule-info h3{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-lg);color:var(--text-primary)}.schedule-time,.schedule-location,.schedule-notes{margin:var(--spacing-xs) 0;color:var(--text-secondary);font-size:var(--font-size-sm)}.schedule-badges{display:flex;flex-direction:column;gap:var(--spacing-xs);align-items:flex-end}.schedule-footer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-gray-200)}.schedule-contact{margin:0;font-size:var(--font-size-sm);color:var(--text-secondary)}@media (max-width: 768px){.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}.attendance-methods{grid-template-columns:1fr}.method-divider{display:none}.user-form-grid{grid-template-columns:1fr}.filter-bar,.rating-group{flex-direction:column}.page-header{flex-direction:column;align-items:flex-start}.schedule-header{flex-direction:column}.schedule-badges{align-items:flex-start;flex-direction:row;flex-wrap:wrap}}.tabs{display:flex;gap:var(--spacing-sm);border-bottom:1px solid var(--color-gray-200);margin-bottom:var(--spacing-lg)}.tab-item{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--spacing-sm)}.tab-item:hover{color:var(--text-primary);background:var(--bg-tertiary)}.tab-item.active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:var(--bg-tertiary)}.tab-icon{font-size:1.2em}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:var(--spacing-md)}.login-card{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-2xl);width:100%;max-width:420px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.login-header h1{color:var(--color-primary);margin-bottom:var(--spacing-sm);font-size:var(--font-size-2xl)}.login-header p{color:var(--text-secondary);font-size:var(--font-size-sm);margin:0}.login-form{margin-bottom:var(--spacing-lg)}.login-footer{text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--color-gray-200)}.login-footer p{font-size:var(--font-size-sm);margin:0}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);color:var(--text-secondary)}.dashboard{min-height:100vh;background:var(--bg-secondary)}.navbar{background:var(--bg-primary);box-shadow:var(--shadow-sm);padding:var(--spacing-md) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:var(--z-dropdown)}.navbar-brand{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary)}.navbar-menu{display:flex;align-items:center;gap:var(--spacing-lg)}.navbar-user{color:var(--text-secondary);font-size:var(--font-size-sm)}.dashboard-content{padding:var(--spacing-xl) 0}.dashboard-header{margin-bottom:var(--spacing-xl)}.dashboard-header h1{margin-bottom:var(--spacing-xs)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.card-full-width{grid-column:1 / -1}.card-highlight{border-left:4px solid var(--color-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stats-grid-4{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stats-grid-5{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;box-shadow:var(--shadow-md);border-left:4px solid var(--color-gray-300);transition:transform var(--transition-base)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card.stat-primary{border-left-color:var(--color-primary)}.stat-card.stat-success{border-left-color:var(--color-success)}.stat-card.stat-warning{border-left-color:var(--color-warning)}.stat-card.stat-danger{border-left-color:var(--color-danger)}.stat-card.stat-info{border-left-color:var(--color-info)}.stat-card.stat-secondary{border-left-color:var(--color-secondary)}.stat-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.schedule-info{margin-bottom:var(--spacing-lg)}.info-row{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-gray-200)}.info-row:last-child{border-bottom:none}.info-label{font-weight:500;color:var(--text-secondary)}.info-value{color:var(--text-primary);font-weight:500}.action-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-md)}.quick-action-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg);background:var(--bg-tertiary);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-base);border:2px solid transparent}.quick-action-item:hover{background:var(--color-primary);color:var(--text-inverse);transform:translateY(-2px);box-shadow:var(--shadow-md)}.quick-action-icon{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm)}.quick-action-label{font-size:var(--font-size-sm);font-weight:500;text-align:center}.report-list,.student-list,.pending-list,.user-list,.activity-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.report-item,.student-item,.pending-item,.user-item,.activity-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);transition:background var(--transition-fast)}.report-item:hover,.student-item:hover,.pending-item:hover,.user-item:hover{background:var(--color-gray-200)}.report-date,.pending-date{font-size:var(--font-size-sm);color:var(--text-secondary)}.report-facility{flex:1;margin-left:var(--spacing-md);font-weight:500}.student-info,.pending-info,.user-info{flex:1}.student-name,.pending-student,.user-name{font-weight:500;margin-bottom:var(--spacing-xs)}.student-number,.user-email{font-size:var(--font-size-sm);color:var(--text-secondary)}.activity-item{align-items:flex-start}.activity-icon{font-size:var(--font-size-2xl);margin-right:var(--spacing-md)}.activity-content{flex:1}.activity-text{margin-bottom:var(--spacing-xs)}.activity-time{font-size:var(--font-size-xs);color:var(--text-tertiary)}.admin-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.admin-action-card{display:flex;align-items:center;padding:var(--spacing-lg);background:var(--bg-tertiary);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-base);border:2px solid transparent}.admin-action-card:hover{border-color:var(--color-primary);background:var(--bg-primary);box-shadow:var(--shadow-md)}.admin-action-icon{font-size:var(--font-size-3xl);margin-right:var(--spacing-md)}.admin-action-content{flex:1}.admin-action-title{font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.admin-action-desc{font-size:var(--font-size-sm);color:var(--text-secondary)}.system-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.table-responsive{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-tertiary)}.data-table th,.data-table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-gray-200)}.data-table th{font-weight:600;color:var(--text-secondary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px}.data-table tbody tr:hover{background:var(--bg-tertiary)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.empty-state p{margin:0}.view-all-link{display:block;text-align:center;margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-gray-200);color:var(--color-primary);font-weight:500;text-decoration:none;transition:color var(--transition-fast)}.view-all-link:hover{color:var(--color-primary-dark)}.info-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-gray-200)}.tab{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all var(--transition-fast);margin-bottom:-2px}.tab:hover{color:var(--color-primary);background:var(--bg-tertiary)}.tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.hamburger-btn{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:var(--spacing-sm);color:var(--text-primary);z-index:1001}.hamburger-btn:hover{color:var(--color-primary)}.mobile-menu-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}.mobile-menu-overlay.open{display:block}.mobile-menu{display:none;position:fixed;top:0;right:-280px;width:280px;height:100vh;background:var(--bg-primary);box-shadow:var(--shadow-lg);z-index:1000;transition:right .3s ease-in-out;overflow-y:auto}.mobile-menu.open{right:0}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.mobile-menu-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary)}.mobile-menu-close:hover{color:var(--color-danger)}.mobile-menu-user{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);font-weight:500;color:var(--text-primary)}.mobile-menu-items{padding:var(--spacing-md) 0}.mobile-menu-item{display:block;width:100%;padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;text-align:left;font-size:var(--font-size-base);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.mobile-menu-item:hover{background:var(--bg-tertiary);color:var(--color-primary)}.mobile-menu-divider{height:1px;background:var(--color-gray-200);margin:var(--spacing-sm) 0}@media (max-width: 768px){.hamburger-btn,.mobile-menu{display:block}.navbar-menu{display:none}.navbar{flex-direction:row;justify-content:space-between}.stats-grid,.stats-grid-4,.stats-grid-5{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,1fr)}.admin-actions{grid-template-columns:1fr}.data-table{font-size:var(--font-size-sm)}.data-table th,.data-table td{padding:var(--spacing-sm)}}@media (max-width: 480px){.stats-grid,.stats-grid-4,.stats-grid-5,.quick-actions{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}:root{--color-primary: #2563eb;--color-primary-dark: #1e40af;--color-primary-light: #60a5fa;--color-secondary: #10b981;--color-secondary-dark: #059669;--color-secondary-light: #34d399;--color-accent: #8b5cf6;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-success: var(--color-secondary);--color-error: var(--color-danger);--bg-primary: #ffffff;--bg-secondary: var(--color-gray-50);--bg-tertiary: var(--color-gray-100);--text-primary: var(--color-gray-900);--text-secondary: var(--color-gray-600);--text-tertiary: var(--color-gray-500);--text-inverse: #ffffff;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--z-dropdown: 1000;--z-modal: 1050;--z-toast: 1100}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.container-sm{max-width:640px}.container-lg{max-width:1400px}.card{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-gray-200)}.card-title{font-size:var(--font-size-xl);font-weight:600;margin:0}.card-body{padding:var(--spacing-md) 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:500;line-height:1.5;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-secondary);color:var(--text-inverse)}.btn-secondary:hover:not(:disabled){background:var(--color-secondary-dark)}.btn-outline{background:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover:not(:disabled){background:var(--color-primary);color:var(--text-inverse)}.btn-danger{background:var(--color-danger);color:var(--text-inverse)}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}.btn-block{width:100%}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-primary)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);line-height:1.5;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-textarea{min-height:100px;resize:vertical}.form-error{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.badge-primary{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-success{background:var(--color-secondary-light);color:var(--color-secondary-dark)}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.alert-success{background:#d1fae5;color:#065f46;border-left:4px solid var(--color-success)}.alert-error{background:#fee2e2;color:#991b1b;border-left:4px solid var(--color-error)}.alert-warning{background:#fef3c7;color:#92400e;border-left:4px solid var(--color-warning)}.alert-info{background:#dbeafe;color:#1e40af;border-left:4px solid var(--color-info)}.loading{display:inline-block;width:20px;height:20px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mt-4{margin-top:var(--spacing-xl)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}.gap-3{gap:var(--spacing-lg)}@media (max-width: 768px){:root{--font-size-4xl: 1.875rem;--font-size-3xl: 1.5rem;--font-size-2xl: 1.25rem}.container{padding:0 var(--spacing-sm)}.card{padding:var(--spacing-md)}}
