.navbar[data-v-ab3c5519]{background-color:var(--color-background);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:var(--z-fixed);box-shadow:var(--shadow-sm)}.navbar-container[data-v-ab3c5519]{max-width:1280px;margin:0 auto;padding:var(--spacing-sm) var(--spacing-sm);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);width:100%;box-sizing:border-box}@media(min-width:640px){.navbar-container[data-v-ab3c5519]{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-md)}}@media(min-width:768px){.navbar-container[data-v-ab3c5519]{padding:var(--spacing-sm) var(--spacing-lg);gap:var(--spacing-lg)}}.navbar-brand[data-v-ab3c5519]{flex-shrink:0}.brand-link[data-v-ab3c5519]{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:var(--color-primary);font-weight:var(--font-bold);font-size:var(--text-lg);transition:all var(--transition-base)}.brand-link[data-v-ab3c5519]:hover{color:var(--color-secondary)}.brand-icon[data-v-ab3c5519]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-md);color:#fff}.brand-icon svg[data-v-ab3c5519]{width:20px;height:20px}.brand-text[data-v-ab3c5519]{display:none;word-break:break-word}@media(min-width:768px){.brand-text[data-v-ab3c5519]{display:inline}}@media(max-width:480px){.brand-icon[data-v-ab3c5519]{width:28px;height:28px}.brand-icon svg[data-v-ab3c5519]{width:16px;height:16px}}.navbar-toggle[data-v-ab3c5519]{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--spacing-xs);margin:0;flex-shrink:0}.navbar-toggle span[data-v-ab3c5519]{width:24px;height:2px;background-color:var(--color-text);border-radius:var(--radius-full);transition:all var(--transition-base)}.navbar-toggle.active span[data-v-ab3c5519]:nth-child(1){transform:rotate(45deg) translateY(10px)}.navbar-toggle.active span[data-v-ab3c5519]:nth-child(2){opacity:0}.navbar-toggle.active span[data-v-ab3c5519]:nth-child(3){transform:rotate(-45deg) translateY(-10px)}@media(min-width:768px){.navbar-toggle[data-v-ab3c5519]{display:none}}.navbar-menu[data-v-ab3c5519]{display:flex;align-items:center;gap:var(--spacing-lg);flex:1;justify-content:space-between}.navbar-links[data-v-ab3c5519]{display:flex;gap:var(--spacing-lg);align-items:center}@media(max-width:767px){.navbar-menu[data-v-ab3c5519]{position:absolute;top:100%;left:0;right:0;background-color:var(--color-background);flex-direction:column;align-items:stretch;justify-content:flex-start;border-bottom:1px solid var(--color-border);border-top:1px solid var(--color-border);padding:0;gap:0;max-height:0;overflow:hidden;transition:max-height .3s ease;z-index:999}.navbar-menu.active[data-v-ab3c5519]{max-height:calc(100vh - 70px);padding:var(--spacing-sm);gap:var(--spacing-sm)}.navbar-links[data-v-ab3c5519]{flex-direction:column;gap:var(--spacing-sm);width:100%}}.nav-link[data-v-ab3c5519]{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text);text-decoration:none;font-weight:var(--font-medium);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;font-size:var(--text-sm)}@media(max-width:480px){.nav-link[data-v-ab3c5519]{padding:var(--spacing-xs) var(--spacing-sm);font-size:13px}}.nav-link svg[data-v-ab3c5519]{width:20px;height:20px}.nav-link[data-v-ab3c5519]:hover,.nav-link.router-link-active[data-v-ab3c5519]{background-color:#1e40af1a;color:var(--color-primary);transform:translateY(-2px)}@media(max-width:768px){.nav-link[data-v-ab3c5519]:hover,.nav-link.router-link-active[data-v-ab3c5519]{transform:none}}.nav-link.admin-link[data-v-ab3c5519]{color:var(--color-accent)}.nav-link.admin-link[data-v-ab3c5519]:hover{background-color:#dc26261a}.navbar-actions[data-v-ab3c5519]{display:flex;gap:var(--spacing-sm);align-items:center}@media(max-width:767px){.navbar-actions[data-v-ab3c5519]{width:100%;flex-direction:row;gap:var(--spacing-sm);justify-content:flex-start}}.btn-action[data-v-ab3c5519],.btn-user[data-v-ab3c5519]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all var(--transition-base);flex-shrink:0}@media(max-width:480px){.btn-action[data-v-ab3c5519],.btn-user[data-v-ab3c5519]{width:36px;height:36px}}.btn-action[data-v-ab3c5519]:hover,.btn-user[data-v-ab3c5519]:hover{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media(max-width:768px){.btn-action[data-v-ab3c5519]:hover,.btn-user[data-v-ab3c5519]:hover{transform:none}}.btn-action svg[data-v-ab3c5519],.btn-user svg[data-v-ab3c5519]{width:20px;height:20px}@media(max-width:480px){.btn-action svg[data-v-ab3c5519],.btn-user svg[data-v-ab3c5519]{width:18px;height:18px}}.user-menu[data-v-ab3c5519]{position:relative}.user-dropdown[data-v-ab3c5519]{position:absolute;top:100%;right:0;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:250px;box-shadow:0 4px 20px #0000001a;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-base);z-index:1000;margin-top:8px;max-height:80vh;overflow-y:auto}@media(max-width:480px){.user-dropdown[data-v-ab3c5519]{position:fixed;inset:auto 0 0;min-width:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.user-menu.active .user-dropdown[data-v-ab3c5519]{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-header[data-v-ab3c5519]{padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.user-name[data-v-ab3c5519]{margin:0 0 4px;font-weight:var(--font-bold);color:var(--color-text);font-size:var(--text-base)}.user-email[data-v-ab3c5519]{margin:0;color:var(--color-text-muted);font-size:var(--text-sm)}.dropdown-divider[data-v-ab3c5519]{height:1px;background-color:var(--color-border)}.dropdown-item[data-v-ab3c5519]{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md);background:none;border:none;color:var(--color-text);text-decoration:none;cursor:pointer;font-size:var(--text-base);transition:all var(--transition-base);text-align:left}.dropdown-item svg[data-v-ab3c5519]{width:18px;height:18px;flex-shrink:0}.dropdown-item[data-v-ab3c5519]:hover{background-color:var(--color-bg);color:var(--color-primary)}.dropdown-item.admin-item[data-v-ab3c5519]{border-bottom:1px solid var(--color-border)}.dropdown-item.logout-item[data-v-ab3c5519]:hover{color:#dc3545}.theme-dropdown[data-v-ab3c5519]{position:absolute;top:100%;right:var(--spacing-lg);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);min-width:250px;margin-top:var(--spacing-sm);animation:slideDown var(--transition-base) var(--easing);max-height:80vh;overflow-y:auto}@media(max-width:480px){.theme-dropdown[data-v-ab3c5519]{position:fixed;inset:auto 0 0;min-width:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.theme-header[data-v-ab3c5519]{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border)}.theme-header h4[data-v-ab3c5519]{margin:0;font-size:var(--text-sm)}.btn-close[data-v-ab3c5519]{background:none;border:none;cursor:pointer;color:var(--color-textLight);font-size:var(--text-lg);padding:0;transition:color var(--transition-base)}.btn-close[data-v-ab3c5519]:hover{color:var(--color-text)}.theme-list[data-v-ab3c5519]{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.theme-item[data-v-ab3c5519]{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-surface);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-medium);transition:all var(--transition-base)}.theme-item[data-v-ab3c5519]:hover{border-color:var(--color-primary);background-color:var(--color-background)}.theme-item.active[data-v-ab3c5519]{border-color:var(--color-primary);color:var(--color-primary);background-color:#1e40af0d}.theme-preview[data-v-ab3c5519]{display:flex;gap:4px}.theme-color[data-v-ab3c5519]{width:20px;height:20px;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.toast-container[data-v-ac306a33]{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast[data-v-ac306a33]{display:flex;align-items:flex-start;gap:12px;min-width:320px;max-width:420px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;cursor:pointer;pointer-events:all;animation:slideInRight-ac306a33 .3s ease-out;border-left:4px solid;transition:all .3s ease}.toast[data-v-ac306a33]:hover{transform:translate(-4px);box-shadow:0 12px 32px #0003}.toast-success[data-v-ac306a33]{border-left-color:#4caf50}.toast-error[data-v-ac306a33]{border-left-color:#f44336}.toast-warning[data-v-ac306a33]{border-left-color:#ff9800}.toast-info[data-v-ac306a33]{border-left-color:#2196f3}.toast-icon[data-v-ac306a33]{font-size:24px;flex-shrink:0;margin-top:2px;line-height:1}.toast-content[data-v-ac306a33]{flex:1;min-width:0}.toast-title[data-v-ac306a33]{font-weight:600;font-size:15px;color:#333;margin-bottom:4px;word-break:break-word}.toast-message[data-v-ac306a33]{font-size:13px;color:#666;line-height:1.4;word-break:break-word}.toast-close[data-v-ac306a33]{background:transparent;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:24px;height:24px;min-width:24px;min-height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;flex-shrink:0;line-height:1}.toast-close[data-v-ac306a33]:hover{background:#0000000d;color:#333}@keyframes slideInRight-ac306a33{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-enter-active[data-v-ac306a33],.toast-leave-active[data-v-ac306a33]{transition:all .3s ease}.toast-enter-from[data-v-ac306a33],.toast-leave-to[data-v-ac306a33]{transform:translate(100%);opacity:0}.toast-move[data-v-ac306a33]{transition:transform .3s ease}@media(max-width:768px){.toast-container[data-v-ac306a33]{top:10px;right:10px;left:10px;max-width:calc(100vw - 20px)}.toast[data-v-ac306a33]{min-width:auto;max-width:100%;width:100%;padding:12px 16px;border-radius:8px}.toast-icon[data-v-ac306a33]{font-size:20px}.toast-title[data-v-ac306a33]{font-size:14px}.toast-message[data-v-ac306a33]{font-size:12px}.toast-close[data-v-ac306a33]{width:20px;height:20px;min-width:20px;min-height:20px;font-size:20px}}@media(max-width:480px){.toast-container[data-v-ac306a33]{top:8px;right:8px;left:8px;gap:8px;max-width:calc(100vw - 16px)}.toast[data-v-ac306a33]{padding:10px 12px;gap:10px;border-radius:6px}.toast-icon[data-v-ac306a33]{font-size:18px;margin-top:1px}.toast-title[data-v-ac306a33]{font-size:13px;margin-bottom:2px}.toast-message[data-v-ac306a33]{font-size:11px}.toast-close[data-v-ac306a33]{width:18px;height:18px;min-width:18px;min-height:18px;font-size:18px}}.confirm-overlay[data-v-c213277e]{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:10000;padding:20px;overflow-y:auto}.confirm-dialog[data-v-c213277e]{background:#fff;border-radius:20px;padding:35px;max-width:420px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center;margin:auto}.confirm-icon[data-v-c213277e]{font-size:64px;margin-bottom:20px;line-height:1}.confirm-title[data-v-c213277e]{margin:0 0 15px;font-size:22px;font-weight:700;color:#333;word-break:break-word}.confirm-message[data-v-c213277e]{margin:0 0 30px;font-size:15px;color:#666;line-height:1.6;word-break:break-word}.confirm-actions[data-v-c213277e]{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn-cancel-confirm[data-v-c213277e],.btn-confirm-ok[data-v-c213277e]{padding:12px 24px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:100px;white-space:nowrap}.btn-cancel-confirm[data-v-c213277e]{background:#f5f5f5;color:#666;border:2px solid #e0e0e0}.btn-cancel-confirm[data-v-c213277e]:hover{background:#e9ecef;transform:translateY(-2px)}.btn-confirm-ok[data-v-c213277e]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-confirm-ok[data-v-c213277e]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-confirm-ok.btn-danger[data-v-c213277e]{background:linear-gradient(135deg,#f44336,#c62828);box-shadow:0 4px 15px #f4433666}.btn-confirm-ok.btn-danger[data-v-c213277e]:hover{box-shadow:0 6px 20px #f4433680}.modal-enter-active[data-v-c213277e],.modal-leave-active[data-v-c213277e]{transition:opacity .2s ease}.modal-enter-active .confirm-dialog[data-v-c213277e],.modal-leave-active .confirm-dialog[data-v-c213277e]{transition:transform .2s ease}.modal-enter-from[data-v-c213277e],.modal-leave-to[data-v-c213277e]{opacity:0}.modal-enter-from .confirm-dialog[data-v-c213277e],.modal-leave-to .confirm-dialog[data-v-c213277e]{transform:scale(.95)}@media(max-width:480px){.confirm-overlay[data-v-c213277e]{padding:16px}.confirm-dialog[data-v-c213277e]{padding:25px;border-radius:16px;max-width:100%}.confirm-icon[data-v-c213277e]{font-size:48px;margin-bottom:16px}.confirm-title[data-v-c213277e]{font-size:18px;margin-bottom:12px}.confirm-message[data-v-c213277e]{font-size:13px;margin-bottom:24px}.confirm-actions[data-v-c213277e]{gap:8px}.btn-cancel-confirm[data-v-c213277e],.btn-confirm-ok[data-v-c213277e]{padding:10px 16px;font-size:14px;min-width:auto;flex:1}}@media(max-width:360px){.confirm-overlay[data-v-c213277e]{padding:12px}.confirm-dialog[data-v-c213277e]{padding:20px}.confirm-icon[data-v-c213277e]{font-size:40px}.confirm-title[data-v-c213277e]{font-size:16px}.confirm-message[data-v-c213277e]{font-size:12px}.btn-cancel-confirm[data-v-c213277e],.btn-confirm-ok[data-v-c213277e]{padding:8px 12px;font-size:12px}}#app[data-v-29bc804b]{min-height:100vh;display:flex;flex-direction:column}[data-v-29bc804b]{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #1e40af;--color-secondary: #0f766e;--color-accent: #dc2626;--color-background: #ffffff;--color-surface: #f8fafc;--color-border: #e2e8f0;--color-text: #1e293b;--color-textLight: #64748b;--color-success: #16a34a;--color-warning: #d97706;--color-error: #dc2626;--color-info: #0284c7;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--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);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .05);--radius-none: 0;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--transition-fast: .15s;--transition-base: .2s;--transition-slow: .3s;--transition-slower: .5s;--easing: cubic-bezier(.4, 0, .2, 1);--easing-in: cubic-bezier(.4, 0, 1, 1);--easing-out: cubic-bezier(0, 0, .2, 1);--easing-in-out: cubic-bezier(.4, 0, .2, 1);--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--z-hide: -1;--z-base: 0;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-background);transition:background-color var(--transition-base) var(--easing)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--color-text);margin-bottom:var(--spacing-md)}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);font-weight:var(--font-medium)}p{line-height:var(--leading-relaxed);color:var(--color-text);margin-bottom:var(--spacing-md)}small{font-size:var(--text-sm);color:var(--color-textLight)}strong{font-weight:var(--font-semibold)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast) var(--easing)}a:hover{color:var(--color-secondary);text-decoration:underline}ul,ol{margin-left:var(--spacing-lg);margin-bottom:var(--spacing-md)}li{margin-bottom:var(--spacing-sm)}#app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-background)}.container{max-width:1280px;margin:0 auto;padding:var(--spacing-md);width:100%}@media(min-width:768px){.container{padding:var(--spacing-lg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:2px solid transparent;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base) var(--easing);white-space:nowrap;text-decoration:none;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){background-color:var(--color-secondary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-border);border-color:var(--color-primary)}.btn-outline{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.btn-danger{background-color:var(--color-error);color:#fff;box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){background-color:#b91c1c;box-shadow:var(--shadow-lg)}.btn-success{background-color:var(--color-success);color:#fff;box-shadow:var(--shadow-md)}.btn-success:hover:not(:disabled){background-color:#15803d;box-shadow:var(--shadow-lg)}.btn-icon{padding:var(--spacing-sm);border-radius:var(--radius-md)}.btn-large{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--text-base);font-weight:var(--font-semibold)}.btn-small{padding:4px 8px;font-size:var(--text-xs)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}label{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:var(--font-medium);color:var(--color-text);font-size:var(--text-sm)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text);background-color:var(--color-background);transition:all var(--transition-base) var(--easing)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e40af1a}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:var(--color-surface);color:var(--color-textLight);cursor:not-allowed}.form-textarea{resize:vertical;min-height:100px}.alert{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);animation:slideDown var(--transition-base) var(--easing)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-icon{flex-shrink:0;font-size:var(--text-xl)}.alert-success{background-color:#16a34a1a;border-left:4px solid var(--color-success);color:#15803d}.alert-error{background-color:#dc26261a;border-left:4px solid var(--color-error);color:#b91c1c}.alert-warning{background-color:#d977061a;border-left:4px solid var(--color-warning);color:#92400e}.alert-info{background-color:#0284c71a;border-left:4px solid var(--color-info);color:#0c4a6e}.card{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base) var(--easing)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.card-body{flex:1}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);white-space:nowrap}.badge-primary{background-color:#1e40af1a;color:#1e40af}.badge-success{background-color:#16a34a1a;color:#15803d}.badge-error{background-color:#dc26261a;color:#991b1b}.badge-warning{background-color:#d977061a;color:#92400e}.badge-info{background-color:#0284c71a;color:#0c4a6e}.badge-secondary{background-color:var(--color-surface);color:var(--color-text)}.table{width:100%;border-collapse:collapse;margin-bottom:var(--spacing-lg)}.table th{background-color:var(--color-surface);color:var(--color-text);font-weight:var(--font-semibold);text-align:left;padding:var(--spacing-md);border:1px solid var(--color-border);font-size:var(--text-sm)}.table td{padding:var(--spacing-md);border:1px solid var(--color-border);font-size:var(--text-sm)}.table tbody tr:hover{background-color:var(--color-surface)}.grid{display:grid;gap:var(--spacing-lg)}.grid-cols-1,.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}@media(min-width:640px){.grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-col{flex-direction:column}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg);color:var(--color-textLight)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;color:var(--color-textLight)}.empty-icon{font-size:64px;margin-bottom:var(--spacing-md);opacity:.5}@media(max-width:639px){.hidden-sm{display:none}}@media(min-width:640px){.hidden-md{display:none}}@media(min-width:1024px){.hidden-lg{display:none}}.table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg)}@media(max-width:768px){.table-wrapper{border:1px solid var(--color-border)}.table{font-size:var(--text-xs)}.table th,.table td{padding:var(--spacing-sm)}.table th{background-color:var(--color-primary);color:#fff}.table td:before{content:attr(data-label);font-weight:var(--font-bold);color:var(--color-primary);margin-right:var(--spacing-md)}}@media(max-width:640px){.modal-overlay{padding:var(--spacing-md)!important}.modal-content{max-width:100%!important;max-height:90vh!important;overflow-y:auto!important}.confirm-dialog{max-width:100%!important;padding:var(--spacing-lg)!important;border-radius:var(--radius-lg)!important}.confirm-actions{flex-direction:column!important}.btn-cancel-confirm,.btn-confirm-ok{width:100%!important}}@media(max-width:768px){.page-header{padding:var(--spacing-md)!important}.header-content{flex-direction:column!important;gap:var(--spacing-md)!important}.page-title{font-size:var(--text-2xl)!important}.page-subtitle{font-size:var(--text-base)!important}}@media(max-width:768px){.form-row{flex-direction:column!important;gap:var(--spacing-md)!important}.form-row>*{width:100%!important}.form-group{margin-bottom:var(--spacing-md)}.horario-selector-row{flex-direction:column!important}.horario-input-group{width:100%!important}.modal-form{max-height:80vh;overflow-y:auto}}@media(max-width:640px){.modal-actions{flex-direction:column!important;gap:var(--spacing-md)!important}.modal-actions button{width:100%!important}.action-buttons{flex-direction:column!important;gap:var(--spacing-sm)!important}.action-buttons button{width:100%!important}}@media(max-width:768px){.admin-tabs{flex-wrap:wrap!important;gap:var(--spacing-sm)!important}.tab-btn{flex:1 1 calc(50% - var(--spacing-xs))!important;font-size:var(--text-xs)!important;padding:var(--spacing-sm)!important}.tab-icon{display:none}}@media(max-width:480px){.tab-btn{flex:1 1 100%!important}}@media(max-width:768px){.nav-wrapper{padding:0 var(--spacing-md)!important}.logo{font-size:24px!important}.nav-links{gap:var(--spacing-sm)!important}.nav-link{font-size:var(--text-sm)!important}.nav-btn{padding:6px 12px!important;font-size:var(--text-sm)!important}}@media(max-width:768px){.card{padding:var(--spacing-md)!important}.card-header{flex-direction:column!important;align-items:flex-start!important}.stat-card{flex-direction:column!important;text-align:center!important}.stat-icon{width:50px!important;height:50px!important}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
