:root{--primary-color: #35B3BA;--primary-hover: #294560;--success-color: #10b981;--success-light: #d1fae5;--warning-color: #f59e0b;--warning-light: #fef3c7;--danger-color: #ef4444;--danger-light: #fee2e2;--info-color: #35B3BA;--gray-50: #F0F2F2;--gray-100: #F0F2F2;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #999999;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #294560;--gray-800: #294560;--gray-900: #000000;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--border-radius: 8px;--border-radius-lg: 12px;--transition: all .2s ease}*{margin:0;padding:0;box-sizing:border-box}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;background-color:var(--gray-50);color:var(--gray-900);line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}.app:has(.login-page){height:100vh;max-height:100vh;overflow:hidden}.app:has(.home-page) .main-nav{display:none}.main-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:2rem}.main-content:has(.home-page),.main-content:has(.login-page){max-width:100%;padding:0;overflow:hidden}.icon-inline{width:20px;height:20px;object-fit:contain;vertical-align:middle;margin-right:6px}.icon-inline-lg{width:32px;height:32px;object-fit:contain;vertical-align:middle;margin-right:8px}.tab .icon-inline{width:24px;height:24px}h2 .icon-inline{width:28px;height:28px}.powered-by{margin-top:1.5rem}.powered-by img{height:50px;width:auto;opacity:.85}.main-nav{background:#294560;border-bottom:none;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.nav-container{max-width:1400px;margin:0 auto;padding:.75rem 2rem;display:flex;justify-content:flex-start;align-items:center;gap:1.5rem}.nav-auth{margin-left:auto;display:flex;align-items:center;gap:.75rem}.nav-username{color:#fff;font-size:.9em;font-weight:500;padding:.5rem 1rem;border-radius:.375rem;background:#ffffff26}.nav-logout-btn{background:#35b3ba;border:none;padding:.5rem 1rem;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.9em;font-weight:500;transition:background-color .2s}.nav-brand h1{font-size:1.5rem;color:#fff;font-weight:700}.nav-brand{position:relative;display:inline-flex;align-items:center}.nav-brand-logo{height:54px;width:auto;display:block}.version-badge{position:absolute;top:-4px;right:-4px;font-size:.6rem;font-weight:500;color:#ffffffe6;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:4px;padding:1px 4px;letter-spacing:.02em;line-height:1.4;pointer-events:none}.nav-links{display:flex;gap:1rem;align-items:center}.nav-links a{text-decoration:none;color:#ffffffd9;padding:.5rem 1rem;border-radius:var(--border-radius);font-weight:500;transition:var(--transition)}.nav-links a:hover{background:#ffffff26;color:#fff}.nav-links a.active{background:#ffffff1a;color:#fff;border-bottom:2px solid #35B3BA;border-radius:var(--border-radius) var(--border-radius) 0 0}.home-page,.login-page{max-width:100%;margin:0;background:url(/images/bg-home.png) center center / cover no-repeat fixed;display:flex;flex-direction:column;align-items:center;padding:2rem}.home-page{min-height:100vh;justify-content:flex-start;padding-top:4rem}.login-page{min-height:calc(100vh - 60px);height:calc(100vh - 60px);justify-content:center;overflow:hidden;padding:1rem;box-sizing:border-box}.home-card{background:#fffffff2;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);padding:3rem;max-width:900px;width:100%;margin-bottom:2rem}.home-logo{display:block;height:90px;margin:0 auto 1.5rem}.hero{text-align:center;padding:1rem 0 2rem;margin-bottom:0}.hero h1{font-size:1.5rem;color:var(--gray-900);margin-bottom:.5rem}.hero-subtitle{font-size:1rem;color:var(--gray-500);max-width:700px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.feature-card{background:#fff;padding:2rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow);text-align:center;transition:var(--transition);border:1px solid #999999}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.feature-icon{margin-bottom:1rem}.feature-icon img{height:48px;width:auto}.feature-card h3{color:var(--gray-900);margin-bottom:.75rem;font-size:1.25rem}.feature-card p{color:var(--gray-500);margin-bottom:1.5rem;line-height:1.6;font-size:.9rem}.info-section{display:none}.info-carousel-card{text-align:center;padding:2rem 3rem}.info-carousel-title{font-size:1.25rem;font-weight:700;color:var(--gray-900);margin-bottom:1.5rem}.info-carousel{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:130px}.carousel-arrow{background:none;border:none;font-size:2.5rem;color:var(--gray-400);cursor:pointer;padding:0 .5rem;line-height:1;transition:color .2s;flex-shrink:0}.carousel-arrow:hover{color:var(--primary-color)}.carousel-slide{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:fadeIn .25s ease}.carousel-icon{width:48px;height:48px;object-fit:contain;margin-bottom:.25rem}.carousel-feature-title{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.carousel-feature-desc{font-size:.9rem;color:var(--gray-500);max-width:480px;margin:0 auto;line-height:1.5}.tech-stack{background:var(--gray-100);padding:2rem;border-radius:var(--border-radius-lg);text-align:center}.tech-stack h3{margin-bottom:1rem;color:var(--gray-900)}.tech-badges{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.tech-badge{background:#fff;padding:.5rem 1rem;border-radius:var(--border-radius);color:var(--primary-color);font-weight:600;font-size:.9rem;box-shadow:var(--shadow-sm)}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2.5rem;color:var(--gray-900);margin-bottom:.5rem}.subtitle{color:var(--gray-600);font-size:1.1rem}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid var(--gray-200)}.tab{background:none;border:none;padding:1rem 1.5rem;font-size:1rem;font-weight:500;color:var(--gray-600);cursor:pointer;border-bottom:3px solid transparent;transition:var(--transition);position:relative;top:2px}.tab:hover{color:var(--gray-900);background:var(--gray-50)}.tab.active{color:#35b3ba;border-bottom-color:#35b3ba}.tab-badge{display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;line-height:1;min-width:1.25rem;height:1.25rem;padding:0 .35rem;border-radius:999px;margin-left:.4rem;vertical-align:middle}.tab-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.card{background:#fff;padding:2rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.75rem;color:var(--gray-900)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:var(--border-radius);box-shadow:var(--shadow);text-align:center;border-left:4px solid var(--gray-300)}.stat-card.libre{border-left-color:var(--success-color)}.stat-card.ocupado{border-left-color:var(--warning-color)}.stat-card.mantenimiento{border-left-color:var(--danger-color)}.stat-label{color:var(--gray-600);font-size:.9rem;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--gray-900)}.filters{background:#fff;padding:1.5rem;border-radius:var(--border-radius);box-shadow:var(--shadow);margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.filter-group{display:flex;gap:.5rem;flex-wrap:wrap}.filter-group button{padding:.5rem 1rem;border:1px solid var(--gray-300);background:#fff;color:var(--gray-700);border-radius:var(--border-radius);cursor:pointer;font-size:.9rem;font-weight:500;transition:var(--transition)}.filter-group button:hover{background:var(--gray-50);border-color:var(--gray-400)}.filter-group button.active{background:#35b3ba;color:#fff;border-color:#35b3ba}.search-input{padding:.75rem 1rem;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:1rem;width:100%;transition:var(--transition)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.table-container{overflow-x:auto;background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse}thead{background:var(--gray-50)}th{text-align:left;padding:1rem;font-weight:600;color:var(--gray-700);border-bottom:2px solid var(--gray-200);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}td{padding:1rem;border-bottom:1px solid var(--gray-100);color:var(--gray-800)}tbody tr{transition:var(--transition)}tbody tr:hover{background:var(--gray-50)}.licenses-table{font-size:.95rem}.text-muted{color:var(--gray-400)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.85rem;font-weight:600;text-transform:capitalize}.badge.libre,.badge.active{background:var(--success-light);color:#047857}.badge.ocupado{background:var(--warning-light);color:#92400e}.badge.mantenimiento{background:var(--danger-light);color:#991b1b}.badge.expirado,.badge.expired,.badge.cancelado,.badge.cancelled{background:var(--gray-200);color:var(--gray-700)}.badge.upcoming{background:#dbeafe;color:#1e40af}.badge.pending,.badge.pendiente{background:var(--warning-light);color:#92400e}button{cursor:pointer;font-family:inherit;font-weight:500;transition:var(--transition);border:none}.btn-primary{background:#35b3ba;color:#fff;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:1rem;display:inline-block;text-decoration:none;text-align:center}.btn-primary:hover{background:#294560}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--gray-100);color:var(--gray-700);padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:1rem}.btn-secondary:hover{background:var(--gray-200)}.btn-danger{background:var(--danger-color);color:#fff;padding:.5rem 1rem;border-radius:var(--border-radius);font-size:.9rem}.btn-danger:hover{background:#dc2626}.btn-small{padding:.375rem .75rem;font-size:.875rem;background:var(--gray-100);color:var(--gray-700);border-radius:var(--border-radius)}.table-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:.5rem}.table-actions .icon-inline{margin-right:0}.table-actions [data-tooltip]:after{left:auto;right:0;transform:none}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#1e1e1ed9;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .12s ease;transition-delay:0s;z-index:200}[data-tooltip]:hover:after{opacity:1}.btn-small:hover{background:var(--gray-200)}.btn-refresh{background:var(--info-color);color:#fff;padding:.5rem 1rem;border-radius:var(--border-radius);font-size:.9rem}.btn-refresh:hover{background:#2563eb}.btn-details{background:transparent;border:none;padding:2px 4px;cursor:pointer;opacity:.65;transition:opacity .15s}.btn-details:hover:not(:disabled){opacity:1}.btn-details:disabled{cursor:default;opacity:.4}.btn-link{background:none;border:none;padding:0;color:var(--primary-color, #2563eb);cursor:pointer;text-decoration:underline}.btn-link:hover{color:var(--primary-dark, #1d4ed8)}.assign-license-form{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.license-select{padding:.375rem .625rem;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:.875rem;font-family:inherit;background:#fff;color:var(--gray-700);min-width:200px;transition:var(--transition);cursor:pointer}.license-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.license-select:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.assign-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.assign-modal-header h3{margin:0;font-size:1.25rem;color:var(--gray-900)}.assign-modal-info{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--border-radius);padding:1rem;margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.5rem}.assign-modal-info-row{display:flex;gap:.75rem;font-size:.9rem;color:var(--gray-700)}.assign-modal-label{font-weight:600;color:var(--gray-500);min-width:80px}.assign-modal-subtitle{font-weight:500;color:var(--gray-700);margin-bottom:.75rem;font-size:.95rem}.assign-modal-empty{text-align:center;color:var(--gray-500);padding:1.5rem;background:var(--gray-50);border-radius:var(--border-radius);font-size:.9rem;margin-bottom:1.25rem}.assign-license-list{display:flex;flex-direction:column;gap:.5rem;max-height:260px;overflow-y:auto;margin-bottom:1.25rem;padding-right:2px}.assign-license-card{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;border:1.5px solid var(--gray-200);border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);background:#fff}.assign-license-card:hover{border-color:var(--primary-color);background:#2563eb0a}.assign-license-card.selected{border-color:var(--primary-color);background:#2563eb14}.assign-license-card-check{font-size:1.1rem;color:var(--gray-400);flex-shrink:0}.assign-license-card.selected .assign-license-card-check{color:var(--primary-color)}.assign-license-card-email{font-weight:500;color:var(--gray-900);font-size:.9rem}.assign-license-card-user{font-size:.8rem;color:var(--gray-500);margin-top:.15rem}.assign-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--gray-200)}.form-description{color:var(--gray-600);margin-bottom:2rem}.form-section{margin-bottom:2rem}.form-section h3{font-size:1.25rem;color:var(--gray-900);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--gray-200)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--gray-700);font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:1rem;font-family:inherit;transition:var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.radio-group{display:flex;flex-direction:column;gap:1rem}.radio-option{display:flex;align-items:center;padding:1rem;border:2px solid var(--gray-300);border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);background-color:#fff}.radio-option:hover{border-color:var(--primary-color);background-color:#2563eb05}.radio-option input[type=radio]{width:auto;margin-right:.75rem;cursor:pointer;accent-color:var(--primary-color)}.radio-option input[type=radio]:checked+span{font-weight:600;color:var(--primary-color)}.radio-option span{flex:1;font-size:1rem;color:var(--gray-700)}.form-hint{display:block;margin-top:.5rem;font-size:.85rem;color:var(--gray-500)}.form-actions{display:flex;gap:1rem;margin-top:2rem}.assignment-form{max-width:800px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:#fff;padding:2rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal h3{margin-bottom:1.5rem;color:var(--gray-900);font-size:1.5rem}.modal-user-info{background:var(--gray-50);padding:1rem;border-radius:var(--border-radius);margin-bottom:1.5rem}.modal-user-info p{margin-bottom:.5rem;color:var(--gray-700)}.password-display{background:var(--gray-900);color:#fff;padding:1rem;border-radius:var(--border-radius);font-family:Courier New,monospace;font-size:1.25rem;text-align:center;letter-spacing:2px;margin:1rem 0;-webkit-user-select:all;user-select:all}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.modal-content{background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);max-width:900px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.modal-header h3{margin:0;color:var(--gray-900);font-size:1.5rem;display:flex;align-items:center;gap:.5rem}.close-button{background:none;border:none;font-size:2rem;color:var(--gray-500);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition)}.close-button:hover{background:var(--gray-200);color:var(--gray-900)}.modal-body{padding:2rem;overflow-y:auto;flex:1}.details-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--gray-200)}.details-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.details-section h4{color:var(--primary-color);font-size:1.1rem;margin-bottom:1rem;font-weight:600}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item.full-width{grid-column:1 / -1}.detail-item label{font-weight:600;color:var(--gray-700);font-size:.875rem}.detail-item span{color:var(--gray-900);font-size:1rem;word-break:break-word}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--gray-200);background:var(--gray-50)}.loading{text-align:center;padding:3rem;color:var(--gray-600);font-size:1.1rem}.error{background:var(--danger-light);color:var(--danger-color);padding:1rem;border-radius:var(--border-radius);border-left:4px solid var(--danger-color);margin-bottom:1rem}.warning{background:var(--warning-light);color:#92400e;padding:1rem;border-radius:var(--border-radius);border-left:4px solid var(--warning-color);margin-bottom:1rem}.success{background:var(--success-light);color:#047857;padding:1rem;border-radius:var(--border-radius);border-left:4px solid var(--success-color);margin-bottom:1rem}.success-message{background:var(--success-light);padding:2rem;text-align:center}.success-message h3{color:#047857;margin-bottom:1rem}.empty-state{text-align:center;padding:3rem;color:var(--gray-500);background:var(--gray-50);border-radius:var(--border-radius);margin:1rem 0}.license-selection{background:var(--gray-50);padding:1.5rem;border-radius:var(--border-radius)}.license-selection p.success{margin-bottom:1rem;font-weight:500}@media (max-width: 768px){.main-content{padding:1rem}.nav-container{flex-direction:column;gap:1rem}.nav-links{width:100%;justify-content:center}.hero h1{font-size:2rem}.hero-subtitle{font-size:1rem}.features-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-row,.assignments-grid{grid-template-columns:1fr}.filters{flex-direction:column}.dashboard-header h1{font-size:1.75rem}.modal{width:95%;padding:1.5rem}.modal-content{width:95%;max-height:95vh}.modal-header,.modal-footer{padding:1rem 1.5rem}.modal-body{padding:1.5rem}.details-grid{grid-template-columns:1fr}.table-container{overflow-x:auto}table{font-size:.85rem}th,td{padding:.75rem .5rem}}.settings-container{padding:0}.settings-header{margin-bottom:2rem}.settings-header h2{font-size:1.75rem;color:var(--gray-900);margin-bottom:.5rem}.settings-section{margin-bottom:2rem}.section-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--border-radius-lg);padding:0;box-shadow:var(--shadow-sm);overflow:hidden}.section-card-title{font-size:1.25rem;color:var(--gray-900);margin:0;padding:1.5rem;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-bottom:2px solid var(--gray-200);font-weight:600}.section-card-subtitle{padding:1rem 1.5rem;margin:0;color:var(--gray-600);font-size:.875rem;background:#fafbfc;border-bottom:1px solid var(--gray-100)}.settings-table{display:grid;grid-template-columns:1fr 1fr}.setting-row{display:flex;flex-direction:column;align-items:flex-start;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100);border-right:1px solid var(--gray-100);transition:background-color .15s ease}.setting-row:nth-child(2n){border-right:none}.setting-row--full{grid-column:1 / -1;border-right:none}.setting-row:hover{background:var(--gray-50)}.setting-label{width:100%;margin-bottom:.5rem}.label-text{display:block;font-size:.9375rem;font-weight:500;color:var(--gray-900);margin-bottom:.2rem}.label-description{display:block;font-size:.8125rem;color:var(--gray-600);line-height:1.4}.setting-value{display:flex;align-items:center;gap:.75rem;width:100%}.setting-input{padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:.875rem;width:100%;max-width:100%;transition:var(--transition);background:#fff}.setting-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.setting-input:disabled{background-color:var(--gray-100);cursor:not-allowed}.saving-indicator{color:var(--primary-color);font-size:1rem;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.toggle-switch{position:relative;display:inline-block;width:60px;height:34px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--gray-300);transition:var(--transition);border-radius:34px}.slider:before{position:absolute;content:"";height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;transition:var(--transition);border-radius:50%}.toggle-switch input:checked+.slider{background-color:var(--success-color)}.toggle-switch input:focus+.slider{box-shadow:0 0 0 3px #10b9811a}.toggle-switch input:checked+.slider:before{transform:translate(26px)}.toggle-switch input:disabled+.slider{opacity:.5;cursor:not-allowed}.settings-info{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--border-radius-lg);padding:2rem;margin-bottom:2rem}.settings-info h3{font-size:1.25rem;color:var(--gray-900);margin-bottom:1rem}.info-box p{margin-bottom:1rem;line-height:1.6}.info-box p:last-child{margin-bottom:0}.info-box strong{color:var(--gray-900);font-weight:600}.test-email-section{margin-top:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-top:2px solid #bae6fd;border-radius:0 0 var(--border-radius-lg) var(--border-radius-lg)}.test-email-section h4{font-size:1.125rem;color:var(--gray-900);margin-bottom:.5rem}.test-email-description{color:var(--gray-600);font-size:.875rem;margin-bottom:1rem}.test-email-controls{display:flex;gap:1rem;align-items:stretch}.test-email-input{flex:1;padding:.75rem 1rem;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:.875rem;transition:var(--transition);background:#fff}.test-email-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.test-email-input:disabled{background-color:var(--gray-100);cursor:not-allowed}.test-email-button{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.test-email-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.test-email-button:disabled{background:var(--gray-300);cursor:not-allowed;opacity:.6}@media (max-width: 768px){.setting-row{flex-direction:column;align-items:flex-start;gap:1rem}.setting-label{padding-right:0}.setting-value{width:100%}.setting-input{width:100%;min-width:0}.test-email-controls{flex-direction:column}.test-email-button{width:100%}}.history-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.history-viewer{display:flex;flex-direction:column;gap:1.25rem}.history-filters{margin-bottom:0}.history-table{font-size:.875rem}.history-ts{white-space:nowrap;color:var(--gray-500);font-size:.8rem}.history-entity{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--gray-700);font-size:.85rem}.history-actor{color:var(--gray-500);font-size:.85rem;white-space:nowrap}.history-empty{text-align:center;padding:2rem;color:var(--gray-400);font-size:.95rem}.history-error{color:var(--danger-color);text-align:center}.hbadge{display:inline-block;padding:.2rem .6rem;border-radius:9999px;font-size:.75rem;font-weight:600;white-space:nowrap}.hbadge-license{background:#e0f7f8;color:#1a7e84}.hbadge-assignment{background:#e8eef8;color:#3a5a99}.hbadge-create{background:#dcfce7;color:#166534}.hbadge-update{background:#e0f7f8;color:#1a7e84}.hbadge-delete{background:#fee2e2;color:#991b1b}.hbadge-assign{background:#dbeafe;color:#1e40af}.hbadge-unassign{background:#fff7ed;color:#9a3412}.hbadge-status{background:#f3e8ff;color:#6b21a8}.hchanges{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.hchanges li{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px;font-size:.8rem}.hchange-field{font-weight:600;color:var(--gray-700)}.hchange-old{color:var(--danger-color);text-decoration:line-through;word-break:break-word}.hchange-arrow{color:var(--gray-400)}.hchange-new{color:#166534;font-weight:500;word-break:break-word}.analytics-dashboard{padding:0;max-width:1400px;margin:0 auto}.period-selector{padding:.5rem 1rem;border:1px solid var(--gray-300);border-radius:8px;background:#fff;color:var(--gray-700);font-size:.875rem;cursor:pointer;transition:var(--transition)}.period-selector:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.btn-export,.btn-refresh{padding:.5rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-export{background:var(--success);color:#fff}.btn-export:hover{background:var(--success-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-refresh{background:var(--gray-100);color:var(--gray-700)}.btn-refresh:hover{background:var(--gray-200);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:var(--transition);display:flex;gap:1rem;align-items:flex-start}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.stat-card.clickable:active{transform:translateY(-1px)}.stat-icon{font-size:2rem;flex-shrink:0}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--gray-600);margin-bottom:.5rem;font-weight:500}.stat-value{font-size:2rem;font-weight:700;color:var(--gray-900);line-height:1}.stat-progress{margin-top:.75rem;height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.stat-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-dark));border-radius:3px;transition:width .5s ease}.analytics-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:2rem}.analytics-section h3{margin:0 0 1.25rem;color:var(--gray-900);font-size:1.25rem;font-weight:600}.trends-chart{padding:1rem 0}.chart-container{display:flex;align-items:flex-end;justify-content:space-between;height:200px;padding:1rem;border:1px solid var(--gray-200);border-radius:8px;background:var(--gray-50);margin-bottom:1rem;overflow-x:auto}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;min-width:30px;max-width:50px}.chart-bar-container{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;gap:2px;position:relative}.chart-bar{width:35%;border-radius:4px 4px 0 0;transition:all .3s ease;cursor:pointer}.chart-bar.assignments{background:linear-gradient(180deg,var(--primary),var(--primary-dark))}.chart-bar.returns{background:linear-gradient(180deg,#10b981,#059669)}.chart-bar:hover{opacity:.8;transform:scaleY(1.02)}.chart-label{font-size:.7rem;color:var(--gray-600);margin-top:.5rem;text-align:center}.chart-legend{display:flex;justify-content:center;gap:1.5rem;padding:.75rem;background:#fff;border-radius:6px;border:1px solid var(--gray-200)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--gray-700)}.legend-color{width:16px;height:16px;border-radius:3px}.legend-color.assignments{background:var(--primary)}.legend-color.returns{background:#10b981}.analytics-table{overflow-x:auto;border-radius:8px;border:1px solid var(--gray-200)}.analytics-table table{width:100%;border-collapse:collapse;background:#fff}.analytics-table thead{background:var(--gray-50);border-bottom:2px solid var(--gray-200)}.analytics-table th{padding:.875rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--gray-700);white-space:nowrap}.analytics-table td{padding:.875rem 1rem;border-bottom:1px solid var(--gray-100);font-size:.875rem;color:var(--gray-700)}.analytics-table tr:last-child td{border-bottom:none}.analytics-table tr:hover{background:var(--gray-50)}.license-name,.teacher-name{font-weight:500;color:var(--gray-900)}.teacher-email{color:var(--gray-600);font-size:.8125rem}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8125rem;font-weight:500;white-space:nowrap}.badge-assigned{background:var(--warning-light);color:var(--warning-dark)}.badge-available{background:var(--success-light);color:var(--success-dark)}.badge-count{background:var(--primary-light);color:var(--primary-dark)}.badge-current{background:var(--info-light);color:var(--info-dark)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-card{background:var(--gray-50);border-radius:8px;padding:1.25rem;border:1px solid var(--gray-200);text-align:center}.summary-label{font-size:.875rem;color:var(--gray-600);margin-bottom:.5rem;font-weight:500}.summary-value{font-size:1.75rem;font-weight:700;color:var(--gray-900)}.analytics-dashboard .loading,.analytics-dashboard .error-message{text-align:center;padding:3rem;font-size:1.125rem;color:var(--gray-600)}.analytics-dashboard .error-message{color:var(--danger)}@media (max-width: 768px){.period-selector,.btn-export,.btn-refresh{flex:1}.overview-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.chart-container{height:150px}.analytics-table{font-size:.8125rem}.analytics-table th,.analytics-table td{padding:.625rem .75rem}.summary-grid{grid-template-columns:1fr}}.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;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;padding:0;max-width:500px;width:90%;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--gray-200)}.modal-header h3{margin:0;color:var(--gray-900);font-size:1.25rem}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;padding:.25rem .5rem;transition:var(--transition);line-height:1}.modal-close:hover{color:var(--gray-700);background:var(--gray-100);border-radius:6px}.modal-body{padding:1.5rem}.modal-body p{margin:0;color:var(--gray-700);line-height:1.6}.modal-body strong{color:var(--primary);font-weight:600}.modal-wide{max-width:900px}.modal-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--gray-500);font-weight:400}.clickable-badge{cursor:pointer;transition:var(--transition)}.clickable-badge:hover{filter:brightness(.9);transform:scale(1.08);box-shadow:var(--shadow-sm)}.badge-active{background:var(--success-light);color:var(--success-dark)}.badge-expired{background:var(--warning-light, #fef3c7);color:var(--warning-dark, #92400e)}.badge-cancelled{background:var(--danger-light, #fee2e2);color:var(--danger-dark, #991b1b)}.badge-pending{background:var(--gray-100);color:var(--gray-600)}.badge-nueva{background:#dbeafe;color:#1e40af;padding:2px 8px;border-radius:99px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-extension{background:#fef3c7;color:#92400e;padding:2px 8px;border-radius:99px;font-size:.75rem;font-weight:600;white-space:nowrap}.license-cell{display:flex;flex-direction:column;gap:2px}.license-email{font-size:.8rem;font-weight:600;color:var(--gray-800)}.license-user{font-size:.75rem;color:var(--gray-500)}.license-account{font-size:.7rem;color:var(--gray-400)}tr.row-failed td{background:#fff5f5}.email-log-subject{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
