.login-container{display:flex;min-height:100vh;background-image:url(/portada.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}.login-left{flex:1;display:flex;justify-content:center;align-items:center;padding:var(--space-8)}.login-logo-left{max-width:400px;width:100%;height:auto;object-fit:contain}.login-right{flex:1;display:flex;justify-content:center;align-items:center;padding:var(--space-8);background:#fff}.login-box{background:transparent;padding:var(--space-6);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:none}.login-box h1{text-align:center;color:var(--color-brand);margin-bottom:var(--space-2);font-size:2rem;font-weight:700}.login-box h2{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-6);font-size:var(--text-lg);font-weight:var(--font-normal)}.login-form .form-group{margin-bottom:var(--space-4)}.login-form .form-group label{display:block;margin-bottom:var(--space-2);color:var(--color-text-secondary);font-weight:var(--font-medium);font-size:var(--text-sm);text-align:left}.login-form .form-group input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--text-base);box-sizing:border-box;background:#fff;transition:all var(--transition-fast)}.login-form .form-group input:focus{outline:none;border-color:var(--color-brand);box-shadow:0 0 0 3px #47162a1a}.login-button-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);margin-top:var(--space-6)}.login-back-link{color:var(--color-brand);font-size:var(--text-sm);transition:color var(--transition-fast)}.login-back-link:hover{color:var(--color-brand-light)}.login-box button{width:100%;max-width:200px;padding:var(--space-3) var(--space-8);background:var(--color-brand);color:var(--color-text-inverse);border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.login-box button:hover:not(:disabled){background:var(--color-brand-light)}.login-box button:disabled{background:var(--color-text-muted);cursor:not-allowed;opacity:.6}.login-error{background:var(--color-error-bg);color:var(--color-error);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4);text-align:center;font-size:var(--text-sm);border:1px solid rgba(196,60,60,.15)}@media (max-width: 768px){.login-container{flex-direction:column}.login-left{padding:var(--space-4)}.login-logo-left{max-width:200px}.login-right{padding:var(--space-4)}}:root{--color-brand: #47162a;--color-brand-light: #6b2340;--color-brand-dark: #2e0f1c;--color-gold: #b49b57;--color-gold-light: #d4bc7d;--color-gold-dark: #8a7340;--color-gray: #ded6bf;--color-white: #ded6bf;--color-black: #1C1C1C;--primary: #47162a;--secondary: #b49b57;--white: #ffffff;--accent: #b49b57;--color-text: #1C1C1C;--border: #ccc;--background: #ded6bf;--color-bg-page: #ded6bf;--color-bg-surface: #ffffff;--color-bg-surface-raised: #fcfbf9;--color-bg-input: #f5f3ef;--color-bg-sidebar: #3d1223;--color-text-primary: #1C1C1C;--color-text-secondary: #4a4a4a;--color-text-tertiary: #6b6b6b;--color-text-muted: #9a9a9a;--color-text-inverse: #ffffff;--color-border-subtle: rgba(71, 22, 42, .06);--color-border-default: rgba(71, 22, 42, .12);--color-border-emphasis: rgba(71, 22, 42, .2);--color-border-focus: #b49b57;--color-success: #2d7a4e;--color-success-bg: rgba(45, 122, 78, .08);--color-warning: #b8860b;--color-warning-bg: rgba(184, 134, 11, .08);--color-error: #c43c3c;--color-error-bg: rgba(196, 60, 60, .08);--color-info: #3a6ea5;--color-info-bg: rgba(58, 110, 165, .08);--font-family: "Prometo", "Arial Narrow", "Arial", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", 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.625;--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;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(71, 22, 42, .04);--shadow-md: 0 2px 4px rgba(71, 22, 42, .06), 0 1px 2px rgba(71, 22, 42, .04);--shadow-lg: 0 4px 8px rgba(71, 22, 42, .08), 0 2px 4px rgba(71, 22, 42, .04);--shadow-xl: 0 8px 16px rgba(71, 22, 42, .1), 0 4px 8px rgba(71, 22, 42, .06);--sidebar-width: 260px;--header-height: 64px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}@font-face{font-family:Prometo;src:url(/Prometo.ttf) format("truetype");font-weight:400;font-style:normal}*{box-sizing:border-box}body{margin:0;font-family:var(--font-family);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-brand);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-brand-light)}h1,h2,h3,h4,h5,h6{margin:0;font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--color-text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{margin:0 0 var(--space-4)}button{font-family:inherit;font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;border:none;border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}button:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}input,select,textarea{font-family:inherit;font-size:var(--text-base);border:1px solid var(--color-border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);background:var(--color-bg-input);color:var(--color-text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #b49b571f}input::placeholder{color:var(--color-text-muted)}input:disabled,select:disabled,textarea:disabled{background:var(--color-bg-surface);color:var(--color-text-muted);cursor:not-allowed}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}th,td{text-align:left;padding:var(--space-3) var(--space-4)}.card{background:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.card:hover{border-color:var(--color-border-default);box-shadow:var(--shadow-md)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-muted{color:var(--color-text-muted)}.text-brand{color:var(--color-brand)}.text-gold{color:var(--color-gold)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.bg-surface{background:var(--color-bg-surface)}.bg-page{background:var(--color-bg-page)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--color-text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--color-border-default);border-top-color:var(--color-brand);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-12);color:var(--color-text-secondary)}.empty-state p{font-size:var(--text-lg);margin-bottom:var(--space-2)}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.alert-error{background:var(--color-error-bg);color:var(--color-error);border:1px solid rgba(196,60,60,.15)}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid rgba(45,122,78,.15)}@media (max-width: 768px){.container{padding:0 var(--space-4)}}
