.file-uploader{display:flex;flex-direction:column;gap:.75rem}.file-preview{position:relative;width:200px;height:200px;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#f5f5f5}.file-preview img{width:100%;height:100%;object-fit:cover}.btn-remove{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;border-radius:50%;background:#000000b3;color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-remove:hover{background:#000000e6}.btn-remove:disabled{opacity:.5;cursor:not-allowed}.btn-upload{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:2px dashed #d4633f;border-radius:8px;background:#fff;color:#d4633f;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-upload:hover:not(:disabled){background:#fff5f2;border-color:#ff6b35}.btn-upload:disabled{opacity:.6;cursor:not-allowed}.btn-upload.uploading{border-style:solid;background:#f5f5f5}.upload-icon{font-size:1.2rem}.upload-spinner{display:inline-block;width:16px;height:16px;border:2px solid #d4633f;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.upload-progress{display:flex;align-items:center;gap:.75rem}.progress-bar{flex:1;height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#ff6b35,#d4633f);transition:width .3s ease}.progress-text{font-size:.875rem;font-weight:500;color:#666;min-width:40px;text-align:right}.upload-error{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff5f5;border:1px solid #ffcccc;border-radius:6px;color:#d9534f;font-size:.9rem}.error-icon{font-size:1.1rem}.upload-hint{font-size:.875rem;color:#999}.file-info{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f0f7ff;border:1px solid #d0e3f7;border-radius:6px;font-size:.9rem;color:#333}.file-info-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:250px;font-weight:500}.file-info-size{color:#666;flex-shrink:0}.video-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:.5rem;color:#666;font-size:.85rem;text-align:center;padding:1rem}.video-fallback-icon{font-size:2rem}@media (max-width: 768px){.file-preview{width:150px;height:150px}.btn-upload{width:100%;justify-content:center}}.toast-container{position:fixed;top:var(--space-4, 1rem);right:var(--space-4, 1rem);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2, .5rem);pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;min-width:300px;max-width:500px;padding:var(--space-3, .75rem) var(--space-4, 1rem);background:#fff;border-radius:var(--radius-lg, .5rem);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05));pointer-events:auto;animation:toast-slide-in .3s cubic-bezier(.4,0,.2,1);border-left:4px solid}@keyframes toast-slide-in{0%{transform:translate(calc(100% + var(--space-4, 1rem)));opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:var(--space-3, .75rem);flex:1}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast-message{font-size:var(--text-sm, .875rem);line-height:var(--leading-normal, 1.5);color:var(--color-text-primary, #111827);word-break:break-word}.toast-close{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;margin-left:var(--space-2, .5rem);background:transparent;border:none;border-radius:var(--radius-sm, .25rem);cursor:pointer;color:var(--color-text-secondary, #6b7280);transition:color var(--transition-fast, .15s cubic-bezier(.4, 0, .2, 1));flex-shrink:0}.toast-close:hover{color:var(--color-text-primary, #111827)}.toast-close:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.toast-close svg{width:16px;height:16px}.toast-success{border-left-color:var(--color-success, #10b981)}.toast-success .toast-icon{color:var(--color-success, #10b981)}.toast-error{border-left-color:var(--color-error, #ef4444)}.toast-error .toast-icon{color:var(--color-error, #ef4444)}.toast-warning{border-left-color:var(--color-warning, #f59e0b)}.toast-warning .toast-icon{color:var(--color-warning, #f59e0b)}.toast-info{border-left-color:var(--color-info, #3b82f6)}.toast-info .toast-icon{color:var(--color-info, #3b82f6)}@media (max-width: 640px){.toast-container{top:var(--space-2, .5rem);right:var(--space-2, .5rem);left:var(--space-2, .5rem)}.toast{min-width:auto;max-width:none}}.error-boundary-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--color-bg-secondary, #f9fafb);padding:1rem}.error-boundary-content{max-width:42rem;width:100%;text-align:center}.error-boundary-icon-container{display:flex;justify-content:center;margin-bottom:1.5rem}.error-boundary-icon{width:4rem;height:4rem;color:var(--color-error, #ef4444)}.error-boundary-title{font-size:1.875rem;font-weight:700;color:var(--color-text-primary, #111827);margin-bottom:1rem}.error-boundary-message{font-size:1rem;color:var(--color-text-secondary, #6b7280);margin-bottom:2rem;line-height:1.5}.error-boundary-button{background-color:var(--color-primary, #2563eb);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius-md, .375rem);border:none;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color var(--transition-base, .2s)}.error-boundary-button:hover{background-color:var(--color-primary-hover, #1d4ed8)}.error-boundary-button:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.error-boundary-details{margin-top:3rem;text-align:left}.error-boundary-details-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary, #111827);margin-bottom:1rem}.error-boundary-error-box{background-color:var(--color-bg-primary, #ffffff);border:1px solid var(--color-gray-200, #e5e7eb);border-radius:var(--radius-lg, .5rem);padding:1.5rem;box-shadow:var(--shadow-sm, 0 1px 2px 0 rgba(0, 0, 0, .05))}.error-boundary-error-name{color:var(--color-error, #ef4444);margin-bottom:1rem;font-size:.875rem}.error-boundary-stack-trace{background-color:var(--color-gray-100, #f3f4f6);padding:1rem;border-radius:var(--radius-md, .375rem);overflow:auto;font-size:.75rem;line-height:1.5;color:var(--color-gray-700, #374151);white-space:pre-wrap;word-break:break-word;font-family:var(--font-mono, monospace)}.error-boundary-component-stack-title{margin-top:1rem;margin-bottom:.5rem;font-size:.875rem;color:var(--color-text-primary, #111827)}.session-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:9998;animation:fadeIn .2s ease-out}.session-warning-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:var(--radius-lg, 8px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgba(0, 0, 0, .1));z-index:9999;max-width:480px;width:90%;animation:slideIn .2s ease-out}.session-warning-content{padding:var(--space-8, 2rem);text-align:center}.session-warning-icon{font-size:3rem;margin-bottom:var(--space-4, 1rem)}.session-warning-title{font-size:var(--text-2xl, 1.5rem);font-weight:var(--font-semibold, 600);color:var(--color-text-primary, #111827);margin:0 0 var(--space-4, 1rem) 0}.session-warning-description{font-size:var(--text-lg, 1.125rem);color:var(--color-text-secondary, #6b7280);margin:0 0 var(--space-4, 1rem) 0}.session-warning-description strong{color:var(--color-warning, #f59e0b);font-weight:var(--font-bold, 700);font-size:var(--text-xl, 1.25rem)}.session-warning-info{font-size:var(--text-sm, .875rem);color:var(--color-text-secondary, #6b7280);margin:0 0 var(--space-6, 1.5rem) 0;line-height:var(--leading-relaxed, 1.75)}.session-warning-actions{display:flex;gap:var(--space-3, .75rem);justify-content:center}.session-warning-actions button{padding:var(--space-3, .75rem) var(--space-6, 1.5rem);font-size:var(--text-base, 1rem);font-weight:var(--font-medium, 500);border-radius:var(--radius-md, 6px);border:none;cursor:pointer;transition:all var(--transition-base, .2s);min-width:140px}.session-warning-actions .btn-primary{background-color:var(--color-primary, #2563eb);color:#fff}.session-warning-actions .btn-primary:hover{background-color:var(--color-primary-hover, #1d4ed8)}.session-warning-actions .btn-primary:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.session-warning-actions .btn-secondary{background-color:var(--color-gray-200, #e5e7eb);color:var(--color-text-primary, #111827)}.session-warning-actions .btn-secondary:hover{background-color:var(--color-gray-300, #d1d5db)}.session-warning-actions .btn-secondary:focus{outline:2px solid var(--color-gray-400, #9ca3af);outline-offset:2px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (max-width: 640px){.session-warning-modal{width:95%}.session-warning-content{padding:var(--space-6, 1.5rem)}.session-warning-actions{flex-direction:column}.session-warning-actions button{width:100%}}.notification-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#dc2626;color:#fff;font-size:.75rem;font-weight:700;border-radius:10px;margin-left:8px;box-shadow:0 2px 4px #dc262666;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 2px 4px #dc262666}50%{box-shadow:0 2px 8px #dc262699}}.admin-layout{display:flex;min-height:100vh;background:#f9fafb;position:relative}.hamburger-menu{display:none;position:fixed;top:1rem;left:1rem;z-index:1100;width:44px;height:44px;background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius-md, 6px);flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:all var(--transition-base, .2s);box-shadow:var(--shadow-sm)}.hamburger-menu:hover{background:#f9fafb;border-color:var(--color-primary)}.hamburger-menu span{display:block;width:20px;height:2px;background:#374151;transition:all var(--transition-base, .2s)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}.admin-sidebar{width:280px;background:#fff;color:#111827;display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto;border-right:1px solid #e5e7eb;box-shadow:var(--shadow-sm)}.admin-logo{padding:1.5rem;border-bottom:1px solid #e5e7eb;background:#fff;display:flex;align-items:center;gap:1rem}.logo-image{width:48px;height:48px;object-fit:contain;border-radius:8px}.logo-text{flex:1}.admin-logo h2{color:var(--color-primary);font-size:1.25rem;margin:0 0 .25rem;font-weight:700}.admin-logo p{color:#6b7280;font-size:.75rem;margin:0}.admin-nav{flex:1;padding:1.5rem 0}.nav-section{margin-bottom:1.5rem}.nav-section h3{color:#9ca3af;font-size:.75rem;text-transform:uppercase;letter-spacing:1px;padding:0 1.5rem;margin:0 0 .75rem;font-weight:600}.admin-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#4b5563;text-decoration:none;transition:all var(--transition-base);position:relative;border-radius:.5rem;margin:0 .75rem}.admin-nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-primary);transform:scaleY(0);transition:transform var(--transition-base);border-radius:0 2px 2px 0}.admin-nav-item:hover{background-color:#f9fafb;color:#111827}.admin-nav-item:hover:before{transform:scaleY(1)}.admin-nav-item.active{background:#fff3f0;color:var(--color-primary);font-weight:500}.admin-nav-item.active:before{transform:scaleY(1)}.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.nav-icon svg{width:20px;height:20px;stroke:#6b7280;transition:stroke .2s}.admin-nav-item:hover .nav-icon svg,.admin-nav-item.active .nav-icon svg{stroke:var(--color-primary)}.admin-user{padding:1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.user-info{margin-bottom:1rem}.user-name{color:#111827;font-weight:600;margin:0 0 .25rem}.user-role{color:#6b7280;font-size:.85rem;margin:0;text-transform:capitalize}.user-actions{display:flex;flex-direction:column;gap:.5rem}.btn-change-password{width:100%;padding:.75rem;background-color:#fff;color:#3b82f6;border:1px solid #3b82f6;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500;text-align:center;text-decoration:none;display:block}.btn-change-password:hover{background-color:#eff6ff;border-color:#2563eb;color:#2563eb}.btn-logout{width:100%;padding:.75rem;background-color:#dc2626;color:#fff;border:1px solid #dc2626;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500}.btn-logout:hover{background-color:#b91c1c;border-color:#b91c1c;color:#fff}.admin-main{flex:1;margin-left:280px;padding:2rem;overflow-y:auto;background:#f9fafb}@media (max-width: 1024px){.admin-sidebar{width:240px}.admin-main{margin-left:240px}}@media (max-width: 768px){.hamburger-menu{display:flex}.sidebar-overlay{display:block}.admin-sidebar{position:fixed;left:-280px;z-index:1000;transition:left var(--transition-slow, .3s)}.admin-sidebar.open{left:0}.admin-main{margin-left:0;padding:4rem 1rem 1rem}}.notification-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#dc2626;color:#fff;font-size:.75rem;font-weight:600;border-radius:10px;margin-left:auto}.admin-nav-item .notification-badge{margin-left:auto}.spinner{display:inline-block;border-radius:50%;border-style:solid;border-color:var(--color-gray-300);border-top-color:var(--color-primary);border-right-color:var(--color-primary);animation:spinner-rotate .6s linear infinite}.spinner-small{width:20px;height:20px;border-width:2px}.spinner-medium{width:32px;height:32px;border-width:3px}.spinner-large{width:48px;height:48px;border-width:4px}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 0%,var(--color-gray-300) 50%,var(--color-gray-200) 100%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-table{width:100%;border-radius:var(--radius-lg);overflow:hidden}.skeleton-table-header{display:grid;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--color-gray-50);border-bottom:2px solid var(--color-gray-200)}.skeleton-table-body{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2)}.skeleton-table-row{display:grid;gap:var(--space-2);padding:var(--space-2)}.skeleton-table-cell{height:20px}.skeleton-table-header,.skeleton-table-row{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.skeleton-card{border-radius:var(--radius-lg);overflow:hidden;background-color:var(--color-bg-primary);box-shadow:var(--shadow-sm)}.skeleton-card-image{width:100%;height:200px;border-radius:0}.skeleton-card-content{padding:var(--space-4)}.skeleton-card-title{height:24px;width:60%;margin-bottom:var(--space-3)}.skeleton-card-text{height:16px;margin-bottom:var(--space-2)}.skeleton-circle{width:48px;height:48px;border-radius:50%}.skeleton-text-container{display:flex;flex-direction:column;gap:var(--space-2)}.skeleton-text-line{height:16px}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#fffc;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);border-radius:inherit}.loading-overlay-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop)}.loading-overlay-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-6);background-color:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.loading-overlay-message{margin:0;font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-primary);text-align:center}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spinner-rotate .6s linear infinite;color:inherit}.table-loading{position:relative;min-height:200px}.table-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ffffffb3;display:flex;align-items:center;justify-content:center;z-index:10}.form-loading{position:relative;pointer-events:none;opacity:.6}.form-loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:32px;height:32px;border:3px solid var(--color-gray-300);border-top-color:var(--color-primary);border-radius:50%;animation:spinner-rotate .6s linear infinite}.loading-inline{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.loading-inline .spinner{width:16px;height:16px;border-width:2px}.loading-long-operation{margin-top:var(--space-4);padding:var(--space-3);background-color:var(--color-warning-light);border-left:4px solid var(--color-warning);border-radius:var(--radius-md);font-size:var(--text-sm);color:#92400e}@media (max-width: 768px){.loading-overlay-content{padding:var(--space-4)}.skeleton-card-image{height:150px}}@media (max-width: 640px){.skeleton-table-header,.skeleton-table-row{grid-template-columns:1fr}.loading-overlay-message{font-size:var(--text-sm)}}@media (prefers-reduced-motion: reduce){.spinner,.skeleton,.btn-loading:after,.table-loading-overlay,.form-loading:after{animation-duration:2s}}@media (prefers-contrast: high){.loading-overlay,.loading-overlay-fullscreen{background-color:#fffffff2}.skeleton{background:var(--color-gray-400)}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.btn-primary{background-color:#2563eb;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#1d4ed8}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-secondary{background-color:#6b7280;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#4b5563}.btn-edit{background-color:#3b82f6;color:#fff;padding:.5rem 1rem;border:none;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s}.btn-edit:hover{background-color:#2563eb}.btn-delete{background-color:#ef4444;color:#fff;padding:.5rem 1rem;border:none;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s}.btn-delete:hover{background-color:#dc2626}.btn-publish{background-color:#10b981;color:#fff;padding:.5rem 1rem;border:none;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s}.btn-publish:hover{background-color:#059669}.btn-unpublish{background-color:#f59e0b;color:#fff;padding:.5rem 1rem;border:none;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s}.btn-unpublish:hover{background-color:#d97706}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.error-message{background-color:#fee2e2;color:#991b1b;padding:1rem;border-radius:.375rem;margin-bottom:1rem}.loading{text-align:center;padding:2rem;color:#6b7280}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.status-badge.active,.status-badge.published,.status-badge.approved{background-color:#d1fae5;color:#065f46}.status-badge.inactive,.status-badge.draft,.status-badge.pending{background-color:#fef3c7;color:#92400e}.status-badge.rejected{background-color:#fee2e2;color:#991b1b}.image-preview{margin-top:1rem}.image-preview img{max-width:300px;max-height:200px;border-radius:.375rem;border:1px solid #e5e7eb}:root{--color-primary: #ff6b35;--color-primary-hover: #e55a2b;--color-primary-light: #fff3f0;--color-secondary: #64748b;--color-secondary-hover: #475569;--color-success: #10b981;--color-success-light: #d1fae5;--color-error: #ef4444;--color-error-light: #fee2e2;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-info: #3b82f6;--color-info-light: #dbeafe;--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-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, monospace;--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;--text-4xl: 2.25rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1440px;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-secondary);min-height:100vh;overflow-x:hidden}#root{overflow-x:hidden;width:100%;max-width:100vw}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--color-text-primary);margin-bottom:var(--space-4)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin-bottom:var(--space-4);color:var(--color-text-secondary)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}strong,b{font-weight:var(--font-semibold)}small{font-size:var(--text-sm)}code{font-family:var(--font-mono);font-size:.875em;background-color:var(--color-gray-100);padding:.125rem .25rem;border-radius:var(--radius-sm)}pre{font-family:var(--font-mono);font-size:var(--text-sm);background-color:var(--color-gray-100);padding:var(--space-4);border-radius:var(--radius-md);overflow-x:auto;margin-bottom:var(--space-4)}ul,ol{margin-bottom:var(--space-4);padding-left:var(--space-6)}li{margin-bottom:var(--space-2);color:var(--color-text-secondary)}img,svg,video,canvas{display:block;max-width:100%;height:auto}button,input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}button{cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed;opacity:.6}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}::selection{background-color:var(--color-primary-light);color:var(--color-primary)}.touch-target,button,a,input[type=checkbox],input[type=radio],select{min-width:44px;min-height:44px}a:not(.btn):not(.admin-nav-item){min-width:auto;min-height:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}*{max-width:100%}img,video,iframe{max-width:100%;height:auto}table{table-layout:auto;width:100%}@media (max-width: 768px){html{font-size:14px}body{padding:0}}@media (max-width: 640px){html{font-size:14px}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}.admin-main{padding:.5rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:var(--leading-normal);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;border:1px solid transparent;white-space:nowrap;min-height:44px}.btn:disabled{cursor:not-allowed;opacity:.6}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--color-secondary-hover)}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background-color:#059669}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline{background-color:transparent;border-color:var(--color-gray-300);color:var(--color-text-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-text-primary)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);min-height:36px}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base);min-height:48px}.card{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-header{margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-gray-200)}.card-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0}.card-body{color:var(--color-text-secondary)}.card-footer{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-gray-200);display:flex;gap:var(--space-3);justify-content:flex-end}.form-group{margin-bottom:var(--space-4)}.form-row{display:flex;gap:var(--space-4);margin-bottom:var(--space-4)}.form-row .form-group{flex:1;margin-bottom:0}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.form-label-required:after{content:" *";color:var(--color-error)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:all var(--transition-base);min-height:44px}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{background-color:var(--color-gray-100);cursor:not-allowed;opacity:.6}.form-input.error,.form-textarea.error,.form-select.error{border-color:var(--color-error)}.form-input.error:focus,.form-textarea.error:focus,.form-select.error:focus{box-shadow:0 0 0 3px var(--color-error-light)}.form-textarea{min-height:120px;resize:vertical}.form-error{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-error)}.form-hint{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-text-tertiary)}.form-checkbox,.form-radio{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1;border-radius:var(--radius-full);white-space:nowrap}.badge-primary{background-color:var(--color-primary-light);color:var(--color-primary)}.badge-success{background-color:var(--color-success-light);color:var(--color-success)}.badge-error{background-color:var(--color-error-light);color:var(--color-error)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.badge-info{background-color:var(--color-info-light);color:var(--color-info)}.badge-gray{background-color:var(--color-gray-200);color:var(--color-gray-700)}.table-container{width:100%;overflow-x:auto;background-color:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table thead{background-color:var(--color-gray-50);border-bottom:2px solid var(--color-gray-200)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-semibold);color:var(--color-text-primary);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);color:var(--color-text-secondary);border-bottom:1px solid var(--color-gray-200)}.table tbody tr:hover{background-color:var(--color-gray-50)}.table tbody tr:last-child td{border-bottom:none}.table-striped tbody tr:nth-child(2n){background-color:var(--color-gray-50)}.table-striped tbody tr:nth-child(2n):hover{background-color:var(--color-gray-100)}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-4)}.modal{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;z-index:var(--z-modal)}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--color-gray-200);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0}.modal-close{padding:var(--space-2);color:var(--color-text-tertiary);border-radius:var(--radius-md);transition:all var(--transition-base)}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-text-primary)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-6);border-top:1px solid var(--color-gray-200);display:flex;gap:var(--space-3);justify-content:flex-end}.alert{padding:var(--space-4);border-radius:var(--radius-md);border-left:4px solid;display:flex;gap:var(--space-3);align-items:flex-start}.alert-success{background-color:var(--color-success-light);border-color:var(--color-success);color:#065f46}.alert-error{background-color:var(--color-error-light);border-color:var(--color-error);color:#991b1b}.alert-warning{background-color:var(--color-warning-light);border-color:var(--color-warning);color:#92400e}.alert-info{background-color:var(--color-info-light);border-color:var(--color-info);color:#1e40af}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-gray-300);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.spinner-lg{width:40px;height:40px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-300) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-circle{border-radius:50%}.empty-state{text-align:center;padding:var(--space-12) var(--space-6)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--color-gray-400)}.empty-state-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6)}@media (max-width: 1024px){.form-row{flex-direction:column}.form-group{width:100%!important}}@media (max-width: 768px){.modal{max-width:100%;max-height:100vh;border-radius:0}.card{padding:var(--space-4)}.table th,.table td{padding:var(--space-2) var(--space-3)}}@media (max-width: 640px){.btn{width:100%;justify-content:center}.card-footer,.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#000000de;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}
