@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap";.sidebar{width:260px;background:var(--color-bg-elevated);border-right:1px solid var(--color-border);padding:var(--space-lg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100}.sidebar-header{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border)}.logo{display:flex;align-items:center;gap:var(--space-sm);font-size:1.25rem;font-weight:700;color:var(--color-text)}.logo-icon{color:var(--color-primary)}.logo-subtitle{font-size:.75rem;color:var(--color-text-subtle);margin-top:var(--space-xs);text-transform:uppercase;letter-spacing:.1em}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-xs);flex:1}.nav-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:var(--color-text-muted);border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;transition:all var(--transition-fast);text-decoration:none}.nav-link:hover{background:var(--color-bg-hover);color:var(--color-text)}.nav-link.active{background:var(--color-primary-muted);color:var(--color-primary)}.nav-link.active svg{color:var(--color-primary)}.sidebar-footer{margin-top:auto;padding-top:var(--space-lg);border-top:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-sm)}.user-info{display:flex;align-items:center;gap:var(--space-sm);flex:1;min-width:0}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:var(--color-bg);flex-shrink:0}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.875rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:var(--color-text-subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{padding:var(--space-sm);color:var(--color-text-muted);border-radius:var(--radius-md);flex-shrink:0}.logout-btn:hover{background:var(--color-error-muted);color:var(--color-error)}.main-content{flex:1;margin-left:260px;padding:var(--space-xl);min-height:100vh;background:var(--color-bg)}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.auth-background{position:absolute;inset:0;z-index:0}.bg-gradient{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(20,184,166,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(245,158,11,.1) 0%,transparent 50%),var(--color-bg)}.bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%);mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%)}.auth-container{position:relative;z-index:1;width:100%;max-width:420px;padding:var(--space-xl)}.auth-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-lg);animation:fadeIn .4s ease}.auth-header{text-align:center;margin-bottom:var(--space-xl)}.auth-logo{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:1.25rem;font-weight:700;color:var(--color-text);margin-bottom:var(--space-lg)}.auth-logo .logo-icon{color:var(--color-primary)}.auth-header h1{font-size:1.5rem;margin-bottom:var(--space-xs)}.auth-header p{color:var(--color-text-muted);font-size:.9375rem}.auth-error{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-error-muted);color:var(--color-error);border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--space-lg)}.auth-info-message{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:#3b82f61a;color:#60a5fa;border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--space-lg);border:1px solid rgba(59,130,246,.2)}.auth-info-message svg{flex-shrink:0}.auth-warning{display:flex;gap:var(--space-sm);padding:var(--space-md);background:var(--color-warning-muted);color:var(--color-warning);border-radius:var(--radius-md);font-size:.8125rem;margin-bottom:var(--space-lg)}.auth-warning>svg{flex-shrink:0;margin-top:2px}.auth-warning>div{display:flex;flex-direction:column;gap:var(--space-xs)}.auth-warning strong{font-size:.875rem}.auth-warning span{opacity:.9}.auth-warning code{font-family:var(--font-mono);font-size:.75rem}.auth-warning .env-example{display:block;background:#0003;padding:var(--space-sm);border-radius:var(--radius-sm);margin-top:var(--space-xs);line-height:1.6}.auth-success{text-align:center;padding:var(--space-lg)}.auth-success svg{color:var(--color-success);margin-bottom:var(--space-lg)}.auth-success h2{margin-bottom:var(--space-md)}.auth-success p{margin-bottom:var(--space-xl);line-height:1.6}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.input-wrapper{position:relative}.input-wrapper .input-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--color-text-subtle);pointer-events:none}.input-wrapper input{padding-left:calc(var(--space-md) * 2 + 18px)}.auth-submit{margin-top:var(--space-md);padding:var(--space-md);font-size:1rem}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-submit .spinner{width:18px;height:18px;border-width:2px}.auth-footer{text-align:center;margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.auth-footer p{font-size:.875rem}.auth-footer a{color:var(--color-primary);font-weight:500}.forgot-link{display:inline-block;margin-top:var(--space-sm);font-size:.8125rem;color:var(--color-text-muted)}.forgot-link:hover{color:var(--color-primary)}.auth-info{text-align:center;margin-top:var(--space-xl)}.auth-info p{font-size:.75rem;color:var(--color-text-subtle)}.table-wrapper{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.table-container{overflow-x:auto}.table-loading,.table-error,.table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-2xl);color:var(--color-text-muted);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center}.table-loading .spinner{width:32px;height:32px}.table-error{color:var(--color-error)}.table-empty svg{opacity:.3}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border-top:1px solid var(--color-border)}.record-count{font-size:.8125rem;color:var(--color-text-subtle)}.dashboard{padding:var(--space-lg);max-width:1400px}.dashboard-header{margin-bottom:var(--space-xl)}.dashboard-header h1{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-xs)}.dashboard-header p{color:var(--color-text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-fast)}.stat-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff}.stat-icon.clients{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.stat-icon.domains{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.hostings{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon.emails{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-icon.tickets{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-icon.invoices{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2}.stat-label{font-size:.8125rem;color:var(--color-text-muted)}.dashboard-section{margin-bottom:var(--space-xl)}.section-header h2{display:flex;align-items:center;gap:var(--space-sm);font-size:1.125rem;font-weight:600}.section-link{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem;color:var(--color-primary);text-decoration:none}.section-link:hover{text-decoration:underline}.tickets-overview{display:grid;grid-template-columns:auto 1fr;gap:var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}@media(max-width:900px){.tickets-overview{grid-template-columns:1fr}}.ticket-mini-stats{display:flex;flex-direction:column;gap:var(--space-sm);min-width:140px}.mini-stat{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--color-bg-elevated)}.mini-stat.open{border-left:3px solid #3b82f6}.mini-stat.progress{border-left:3px solid #f59e0b}.mini-stat.pending{border-left:3px solid #8b5cf6}.mini-stat.urgent{border-left:3px solid #ef4444;color:#ef4444}.mini-value{font-size:1.25rem;font-weight:700}.mini-label{font-size:.75rem;color:var(--color-text-muted)}.tickets-chart{flex:1}.tickets-chart h3{font-size:.875rem;font-weight:600;color:var(--color-text-muted);margin-bottom:var(--space-md)}.category-bars{display:flex;flex-direction:column;gap:var(--space-md)}.category-bar-item{display:flex;flex-direction:column;gap:var(--space-xs)}.category-bar-header{display:flex;justify-content:space-between;align-items:center}.category-name{font-size:.8125rem;color:var(--color-text)}.category-count{font-size:.875rem;font-weight:600;color:var(--color-text)}.category-bar-track{height:8px;background:var(--color-bg-elevated);border-radius:4px;overflow:hidden}.category-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.dashboard-lists{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}@media(max-width:900px){.dashboard-lists{grid-template-columns:1fr}}.dashboard-list{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.list-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-elevated)}.list-header h3{display:flex;align-items:center;gap:var(--space-sm);font-size:.9375rem;font-weight:600}.list-header a{font-size:.8125rem;color:var(--color-primary);text-decoration:none}.list-header a:hover{text-decoration:underline}.list-content{padding:var(--space-sm);max-height:280px;overflow-y:auto}.list-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast)}.list-item:hover{background:var(--color-bg-hover)}.item-main{display:flex;flex-direction:column;min-width:0}.item-title{font-size:.875rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-sub{font-size:.75rem;color:var(--color-text-muted)}.item-badge{padding:2px 8px;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase}.item-badge.danger{background:var(--color-error-muted);color:var(--color-error)}.item-badge.warning{background:var(--color-warning-muted);color:var(--color-warning)}.item-badge.info{background:#3b82f626;color:#3b82f6}.item-badge.priority-baja{background:var(--color-success-muted);color:var(--color-success)}.item-badge.priority-media{background:#3b82f626;color:#3b82f6}.item-badge.priority-alta{background:var(--color-warning-muted);color:var(--color-warning)}.item-badge.priority-urgente{background:var(--color-error-muted);color:var(--color-error)}.item-amount{font-size:.875rem;font-weight:600;color:var(--color-primary)}.empty-message{text-align:center;padding:var(--space-lg);color:var(--color-text-subtle);font-size:.875rem}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);animation:fadeIn .2s ease}.modal-container{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-sm{max-width:400px}.modal-md{max-width:560px}.modal-lg{max-width:720px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-close{background:transparent;color:var(--color-text-muted);padding:var(--space-xs);border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--color-bg-hover);color:var(--color-text)}.modal-content{padding:var(--space-lg);overflow-y:auto}.confirm-modal{text-align:center}.confirm-message{color:var(--color-text-muted);margin-bottom:var(--space-xl);line-height:1.6}.confirm-actions{display:flex;gap:var(--space-md);justify-content:center}.confirm-actions .btn{min-width:120px}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{background:#16a34a}.client-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-section{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg)}.form-section h3{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media(max-width:600px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.form-group:last-child{margin-bottom:0}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text)}.form-group .required{color:var(--color-error)}.form-group input,.form-group select,.form-group textarea{padding:var(--space-sm) var(--space-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.9375rem;transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--color-error)}.form-group input.error:focus,.form-group select.error:focus,.form-group textarea.error:focus{box-shadow:0 0 0 3px var(--color-error-muted)}.form-group textarea{resize:vertical;min-height:60px}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238899a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.error-message{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem;color:var(--color-error)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.form-actions .btn{min-width:140px}.checkbox-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;padding:var(--space-sm) 0;margin-top:var(--space-lg)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.checkbox-text{font-size:.9375rem;color:var(--color-text)}.field-hint{font-size:.75rem;color:var(--color-text-subtle);margin-top:var(--space-xs)}.portal-section{background:linear-gradient(135deg,var(--color-bg-elevated),rgba(99,102,241,.05));border-color:#6366f133}.portal-section h3{display:flex;align-items:center;gap:var(--space-sm);color:var(--color-primary)}.portal-section .checkbox-label{margin-top:0;padding:var(--space-sm) 0}.portal-section .checkbox-label span{font-size:.9375rem;color:var(--color-text)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{flex:1;padding-right:48px}.password-toggle{position:absolute;right:8px;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.password-toggle:hover{background:var(--color-bg-hover);color:var(--color-primary)}.page{animation:fadeIn .4s ease}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-xl);gap:var(--space-lg)}.page-header p{color:var(--color-text-muted);font-size:.9375rem}.actions-cell{display:flex;gap:var(--space-xs)}.btn-icon{background:transparent;border:none;padding:var(--space-xs);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--color-bg-hover);color:var(--color-primary)}.btn-icon.btn-danger:hover,.btn-icon-danger:hover{background:var(--color-error-muted);color:var(--color-error)}.form-error-banner{background:var(--color-error-muted);color:var(--color-error);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-lg);font-size:.875rem;display:flex;align-items:center;gap:var(--space-sm)}.invoice-stats{display:flex;gap:var(--space-lg);margin-bottom:var(--space-xl)}.invoice-stat{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs)}.invoice-stat .stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.invoice-stat .stat-value{font-size:1.25rem;font-weight:700;font-family:var(--font-mono);color:var(--color-text)}.invoice-stat .stat-value.pending{color:var(--color-warning)}.invoice-stat .stat-value.paid{color:var(--color-success)}.ticket-stats{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg)}.ticket-stat{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);cursor:pointer;transition:all var(--transition-fast);min-width:100px}.ticket-stat:hover{border-color:var(--color-primary);background:var(--color-bg-hover)}.ticket-stat .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text)}.ticket-stat .stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.ticket-stat.urgent{border-color:var(--color-error-muted)}.ticket-stat.urgent .stat-value{color:var(--color-error)}.ticket-filters{display:flex;gap:var(--space-lg);align-items:center;margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--color-bg-elevated);border-radius:var(--radius-md)}.filter-group{display:flex;align-items:center;gap:var(--space-sm)}.filter-group label{font-size:.8125rem;color:var(--color-text-muted)}.filter-group select{padding:var(--space-xs) var(--space-sm);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:.875rem}.priority-indicator{width:4px;height:32px;border-radius:2px;flex-shrink:0}.priority-indicator.priority-baja{background:var(--color-success)}.priority-indicator.priority-media{background:var(--color-info, #3b82f6)}.priority-indicator.priority-alta{background:var(--color-warning)}.priority-indicator.priority-urgente{background:var(--color-error)}.ticket-link{cursor:pointer;transition:color var(--transition-fast)}.ticket-link:hover{color:var(--color-primary)}.priority-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:3px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.priority-badge.priority-baja{background:var(--color-success-muted);color:var(--color-success)}.priority-badge.priority-media{background:#3b82f626;color:#3b82f6}.priority-badge.priority-alta{background:var(--color-warning-muted);color:var(--color-warning)}.priority-badge.priority-urgente{background:var(--color-error-muted);color:var(--color-error)}.category-tag{font-size:.8125rem;color:var(--color-text-muted)}.section-hint{font-size:.8125rem;color:var(--color-text-subtle);margin-top:calc(var(--space-xs) * -1);margin-bottom:var(--space-md)}@media(max-width:768px){.form-row-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.form-row-3{grid-template-columns:1fr}}.email-stats{display:flex;gap:var(--space-lg);margin-bottom:var(--space-lg)}.email-stat{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.email-stat svg{color:var(--color-primary)}.email-stat>div{display:flex;flex-direction:column}.email-stat .stat-value{font-size:1.25rem;font-weight:700;color:var(--color-text)}.email-stat .stat-label{font-size:.75rem;color:var(--color-text-muted)}.stat-dot{width:12px;height:12px;border-radius:50%}.stat-dot.active{background:var(--color-success)}.stat-dot.suspended{background:var(--color-warning)}.password-cell{display:flex;align-items:center;gap:var(--space-sm)}.password-value{font-family:var(--font-mono);font-size:.8125rem;color:var(--color-text-muted);min-width:70px}.password-actions{display:flex;gap:2px}.btn-icon-sm{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--color-text-subtle);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-icon-sm:hover{background:var(--color-bg-hover);color:var(--color-primary)}.text-success{color:var(--color-success)!important}.cell-icon{color:var(--color-primary);flex-shrink:0}.product-stats{display:flex;gap:var(--space-lg);margin-bottom:var(--space-lg)}.product-stat{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.product-stat svg{color:var(--color-primary)}.product-stat>div{display:flex;flex-direction:column}.product-stat .stat-value{font-size:1.25rem;font-weight:700;color:var(--color-text)}.product-stat .stat-label{font-size:.75rem;color:var(--color-text-muted)}.checkbox-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;height:44px}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.cell-primary{display:flex;align-items:center;gap:var(--space-sm)}.cell-icon{color:var(--color-text-muted);flex-shrink:0}.cell-main{font-weight:500;color:var(--color-text);display:block}.cell-sub{font-size:.8125rem;color:var(--color-text-muted);display:flex;align-items:center;gap:4px;margin-top:2px}.cell-secondary{display:flex;align-items:center;gap:var(--space-xs);color:var(--color-text-muted)}.cell-link{display:flex;align-items:center;gap:var(--space-xs);color:var(--color-text-muted);transition:color var(--transition-fast)}.cell-link:hover{color:var(--color-primary)}.cell-notes{color:var(--color-text-muted);font-size:.875rem;font-style:italic}.domain-link{display:flex;align-items:center;gap:var(--space-xs);color:var(--color-primary);font-weight:500}.domain-link:hover{text-decoration:underline}.expiry-cell{display:flex;align-items:flex-start;gap:var(--space-sm)}.expiry-icon{margin-top:2px}.expiry-icon.active{color:var(--color-success)}.expiry-icon.expiring_soon{color:var(--color-warning)}.expiry-icon.expired{color:var(--color-error)}.expiry-days{font-size:.75rem;display:block;margin-top:2px}.expiry-days.active{color:var(--color-success)}.expiry-days.expiring_soon{color:var(--color-warning)}.expiry-days.expired{color:var(--color-error)}.auto-renew-cell{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem}.auto-renew-cell svg.active{color:var(--color-success)}.auto-renew-cell svg.inactive{color:var(--color-text-subtle)}.price-cell{display:flex;align-items:center;gap:var(--space-xs)}.price-icon{color:var(--color-success)}.price-value{font-weight:600;color:var(--color-text);font-family:var(--font-mono)}.status-cell{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem}.status-cell.active{color:var(--color-success)}.status-cell.inactive{color:var(--color-text-subtle)}.amount-cell{display:flex;flex-direction:column;gap:4px}.amount-row{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem}.amount-label{color:var(--color-text-subtle)}.amount-value{font-family:var(--font-mono);font-weight:500;color:var(--color-text-muted)}.amount-row.final .amount-value{color:var(--color-success)}.dates-cell{display:flex;flex-direction:column;gap:4px}.date-row{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem;color:var(--color-text-muted)}.role-cell{display:flex;align-items:center;gap:var(--space-sm)}.role-icon{flex-shrink:0}.role-icon.role-admin{color:var(--color-error)}.role-icon.role-editor{color:var(--color-warning)}.user-avatar-img{width:36px;height:36px;border-radius:var(--radius-full);object-fit:cover;flex-shrink:0}.user-avatar-placeholder{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:var(--color-bg);flex-shrink:0}.uid-cell{background:var(--color-bg-hover);padding:2px 6px;border-radius:var(--radius-sm);font-size:.75rem}.portal-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.portal-badge.portal-active{color:var(--color-success);background:var(--color-success-muted)}.portal-badge.portal-inactive{color:var(--color-text-subtle);background:var(--color-bg-hover)}.alert{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-lg);font-size:.9375rem}.alert-info{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:#60a5fa}.alert-error{background:var(--color-error-muted);border:1px solid rgba(239,68,68,.3);color:var(--color-error)}.alert-success{background:var(--color-success-muted);border:1px solid rgba(34,197,94,.3);color:var(--color-success)}.alert-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);color:#fbbf24}.input-with-action{display:flex;gap:var(--space-xs);align-items:center}.input-with-action input{flex:1}.input-with-action .btn-icon{padding:var(--space-sm);background:var(--color-bg-hover);border-radius:var(--radius-md)}.input-with-action .btn-icon:hover{background:var(--color-primary-muted);color:var(--color-primary)}.role-icon.role-admin{color:var(--color-primary)}.role-icon.role-viewer{color:var(--color-text-muted)}.email-account-form{display:flex;flex-direction:column;gap:var(--space-lg)}.email-account-form .form-section h3{display:flex;align-items:center;gap:var(--space-sm);font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.email-account-form .form-section h3 svg{color:var(--color-primary)}.password-input{display:flex;gap:var(--space-xs)}.password-input input{flex:1}.password-toggle,.password-generate{display:flex;align-items:center;justify-content:center;width:40px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.password-toggle:hover,.password-generate:hover{background:var(--color-bg-hover);color:var(--color-primary);border-color:var(--color-primary)}.server-config-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-md)}@media(max-width:1024px){.server-config-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.server-config-grid{grid-template-columns:1fr}}.server-block{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.server-block h4{font-size:.875rem;font-weight:600;margin-bottom:var(--space-md);color:var(--color-text)}.server-block .form-group{margin-bottom:var(--space-sm)}.server-block .form-group:last-child{margin-bottom:0}.server-block label{font-size:.75rem;color:var(--color-text-muted)}.server-block input,.server-block select{padding:var(--space-xs) var(--space-sm);font-size:.875rem}.form-row-inline{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.invoice-form{display:flex;flex-direction:column;gap:var(--space-lg)}.invoice-form .form-section{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg)}.invoice-form .form-section h3{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-md)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.section-header h3{margin-bottom:0!important}.form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.form-row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}@media(max-width:768px){.form-row-3,.form-row-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.form-row-3,.form-row-4{grid-template-columns:1fr}}.invoice-items{display:flex;flex-direction:column;gap:var(--space-md)}.invoice-item{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.item-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border)}.item-type-selector{display:flex;gap:var(--space-xs)}.type-btn{padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.type-btn:hover{background:var(--color-bg-hover);color:var(--color-text)}.type-btn.active{background:var(--color-primary-muted);border-color:var(--color-primary);color:var(--color-primary)}.item-body{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.item-body .form-group{margin-bottom:0}.item-body .form-group label{font-size:.75rem;color:var(--color-text-subtle);margin-bottom:var(--space-xs)}.item-line-total{display:flex;align-items:center;gap:var(--space-md);margin-left:auto;padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border-radius:var(--radius-md)}.total-label{font-size:.875rem;color:var(--color-text-muted)}.total-value{font-size:1rem;font-weight:600;color:var(--color-text);font-family:var(--font-mono)}.invoice-totals{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);margin-left:auto;width:100%;max-width:350px}.totals-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;font-size:.9375rem}.totals-row span:first-child{color:var(--color-text-muted)}.totals-row span:last-child{font-family:var(--font-mono);color:var(--color-text)}.totals-row.total-final{border-top:1px solid var(--color-border);margin-top:var(--space-sm);padding-top:var(--space-md)}.totals-row.total-final span:first-child{font-weight:600;color:var(--color-text)}.totals-row.total-final span:last-child{font-size:1.25rem;font-weight:700;color:var(--color-primary)}.totals-divider{height:1px;background:var(--color-border);margin:var(--space-md) 0}.totals-row.margin-row span:first-child{font-size:.8125rem}.totals-row.margin-row span:last-child{font-size:.875rem}.totals-row.margin-row.highlight span:last-child{color:var(--color-success);font-weight:600}.invoice-form .form-actions{padding-top:var(--space-md);border-top:1px solid var(--color-border)}.file-selector{display:flex;flex-direction:column;gap:var(--space-sm)}.file-selector.compact .dropzone{flex-direction:row;padding:var(--space-sm) var(--space-md);gap:var(--space-sm)}.file-selector.compact .dropzone span{font-size:.8125rem}.selected-files{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.selected-file{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);max-width:200px}.selected-file .file-preview{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-sm)}.selected-file .file-icon-wrapper{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-hover);border-radius:var(--radius-sm);color:var(--color-text-muted)}.selected-file .file-info{flex:1;min-width:0;display:flex;flex-direction:column}.selected-file .file-name{font-size:.8125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-file .file-size{font-size:.6875rem;color:var(--color-text-subtle)}.selected-file .file-remove{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.selected-file .file-remove:hover{background:var(--color-error-muted);color:var(--color-error)}.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xl);border:2px dashed var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);cursor:pointer;transition:all var(--transition-fast)}.dropzone input{display:none}.dropzone:hover,.dropzone.active{border-color:var(--color-primary);background:var(--color-primary-muted)}.dropzone.disabled{opacity:.5;cursor:not-allowed}.dropzone svg{color:var(--color-text-muted)}.dropzone-text{font-size:.9375rem;color:var(--color-text)}.dropzone-hint{font-size:.75rem;color:var(--color-text-subtle)}.attachment-list{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.attachment-list.compact{gap:var(--space-xs)}.attachment-item{position:relative}.attachment-link{display:block;text-decoration:none;color:var(--color-text);transition:all var(--transition-fast)}.attachment-link.image{width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border)}.attachment-link.image:hover{border-color:var(--color-primary);transform:scale(1.05)}.attachment-link.image img{width:100%;height:100%;object-fit:cover}.attachment-link.file{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md)}.attachment-link.file:hover{border-color:var(--color-primary);background:var(--color-bg-hover)}.attachment-link.file svg{color:var(--color-primary);flex-shrink:0}.attachment-info{display:flex;flex-direction:column;min-width:0}.attachment-name{font-size:.8125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.attachment-size{font-size:.6875rem;color:var(--color-text-subtle)}.attachment-delete{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:var(--color-error);color:#fff;border:2px solid var(--color-bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.attachment-item:hover .attachment-delete{opacity:1}.attachment-delete:disabled{cursor:wait}.file-uploader{display:flex;flex-direction:column;gap:var(--space-md)}.file-uploader .btn{align-self:flex-start}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.8125rem}.ticket-detail{display:flex;flex-direction:column;height:100%;max-height:85vh}.ticket-detail-header{display:flex;align-items:center;gap:var(--space-md);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-lg)}.btn-back{background:transparent;border:none;color:var(--color-text-muted);padding:var(--space-xs);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.btn-back:hover{background:var(--color-bg-hover);color:var(--color-text)}.ticket-title{flex:1}.ticket-number{font-size:.75rem;font-family:var(--font-mono);color:var(--color-primary);font-weight:600}.ticket-title h2{font-size:1.25rem;margin-top:var(--space-xs)}.ticket-detail-body{display:grid;grid-template-columns:1fr 280px;gap:var(--space-xl);overflow:hidden;flex:1}@media(max-width:900px){.ticket-detail-body{grid-template-columns:1fr;overflow-y:auto}.ticket-sidebar{order:-1;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-sm)}}.ticket-main{overflow-y:auto;padding-right:var(--space-md);display:flex;flex-direction:column;gap:var(--space-lg)}.ticket-section h3{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.ticket-description{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);white-space:pre-wrap;line-height:1.6}.upload-area{margin-top:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.upload-area .btn{align-self:flex-start}.section-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.tab-btn{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;font-weight:500;margin-bottom:-1px}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-content{display:flex;flex-direction:column;gap:var(--space-md)}.messages-list{display:flex;flex-direction:column;gap:var(--space-md);max-height:400px;overflow-y:auto;padding:var(--space-sm)}.message{display:flex;gap:var(--space-sm);max-width:85%}.message.incoming{align-self:flex-start}.message.outgoing{align-self:flex-end;flex-direction:row-reverse}.message-avatar{flex-shrink:0;color:var(--color-text-muted)}.message-content{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.message.outgoing .message-content{background:var(--color-primary-muted);border-color:var(--color-primary)}.message-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) var(--space-md);background:#0000001a;font-size:.75rem}.message-sender{font-weight:600;display:flex;align-items:center;gap:var(--space-xs)}.sender-badge{padding:2px 6px;background:var(--color-success-muted);color:var(--color-success);border-radius:var(--radius-sm);font-size:.625rem;text-transform:uppercase;font-weight:700}.message-time{color:var(--color-text-subtle)}.message-body{padding:var(--space-sm) var(--space-md);white-space:pre-wrap;line-height:1.5}.message-attachments{padding:var(--space-sm) var(--space-md);border-top:1px solid var(--color-border)}.message-form{display:flex;flex-direction:column;gap:var(--space-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.message-form textarea{width:100%;background:transparent;border:none;resize:none;font-size:.9375rem;color:var(--color-text)}.message-form textarea:focus{outline:none}.message-form .form-actions{display:flex;justify-content:flex-end}.notes-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:300px;overflow-y:auto}.internal-note{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md)}.note-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs);font-size:.75rem}.note-author{display:flex;align-items:center;gap:var(--space-xs);font-weight:600;color:var(--color-warning)}.note-time{color:var(--color-text-subtle)}.note-body{font-size:.875rem;white-space:pre-wrap;line-height:1.5}.note-form{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm)}.note-form textarea{width:100%;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm);resize:none;font-size:.875rem;color:var(--color-text)}.note-form textarea:focus{outline:none;border-color:var(--color-warning)}.note-form .btn{align-self:flex-start}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--color-text-muted);text-align:center}.empty-state svg{opacity:.3;margin-bottom:var(--space-sm)}.empty-state p{font-size:.875rem}.ticket-sidebar{display:flex;flex-direction:column;gap:var(--space-sm)}.sidebar-section{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.sidebar-section h4{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-subtle);margin-bottom:var(--space-sm)}.sidebar-value{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;color:var(--color-text)}.sidebar-value.small{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.sidebar-value.resolved{color:var(--color-success)}.sidebar-value+.sidebar-value{margin-top:var(--space-sm)}.priority-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:4px 10px;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500}.priority-baja{background:var(--color-success-muted);color:var(--color-success)}.priority-media{background:#3b82f626;color:#3b82f6}.priority-alta{background:var(--color-warning-muted);color:var(--color-warning)}.priority-urgente{background:var(--color-error-muted);color:var(--color-error)}.category-badge{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:.875rem;color:var(--color-text)}:root{--color-bg: #0a0f14;--color-bg-elevated: #111920;--color-bg-card: #151d26;--color-bg-hover: #1a2633;--color-border: #243040;--color-border-light: #2d3e50;--color-text: #e8eef4;--color-text-muted: #8899a8;--color-text-subtle: #5a6b7a;--color-primary: #14b8a6;--color-primary-hover: #0d9488;--color-primary-muted: rgba(20, 184, 166, .15);--color-accent: #f59e0b;--color-accent-muted: rgba(245, 158, 11, .15);--color-success: #22c55e;--color-success-muted: rgba(34, 197, 94, .15);--color-warning: #f59e0b;--color-warning-muted: rgba(245, 158, 11, .15);--color-error: #ef4444;--color-error-muted: rgba(239, 68, 68, .15);--color-info: #3b82f6;--color-info-muted: rgba(59, 130, 246, .15);--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(20, 184, 166, .3);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-text)}h1{font-size:2rem;letter-spacing:-.02em}h2{font-size:1.5rem;letter-spacing:-.01em}h3{font-size:1.25rem}h4{font-size:1.125rem}p{color:var(--color-text-muted)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}button{font-family:inherit;cursor:pointer;border:none;outline:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.btn-primary{background:var(--color-primary);color:var(--color-bg)}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--color-bg-card);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-light)}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text)}input,textarea,select{font-family:inherit;font-size:.9375rem;padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:all var(--transition-fast);width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}input::placeholder,textarea::placeholder{color:var(--color-text-subtle)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-md)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}table{width:100%;border-collapse:collapse;font-size:.875rem}th{text-align:left;padding:var(--space-md);background:var(--color-bg-elevated);color:var(--color-text-muted);font-weight:500;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}td{padding:var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--color-bg-hover)}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:.75rem;font-weight:500;border-radius:var(--radius-full);text-transform:capitalize}.badge-success{background:var(--color-success-muted);color:var(--color-success)}.badge-warning{background:var(--color-warning-muted);color:var(--color-warning)}.badge-error{background:var(--color-error-muted);color:var(--color-error)}.badge-info{background:var(--color-info-muted);color:var(--color-info)}.badge-default{background:var(--color-bg-hover);color:var(--color-text-muted)}.badge-purple{background:#a855f726;color:#a855f7}.layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--color-bg-elevated);border-right:1px solid var(--color-border);padding:var(--space-lg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;overflow-y:auto}.main-content{flex:1;margin-left:260px;padding:var(--space-xl);min-height:100vh}.page-header{margin-bottom:var(--space-xl)}.page-header h1{margin-bottom:var(--space-xs)}.page-header p{font-size:.9375rem}.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--color-text-muted)}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--color-text-muted)}.error-message{background:var(--color-error-muted);color:var(--color-error);padding:var(--space-md);border-radius:var(--radius-md);font-size:.875rem}.text-muted{color:var(--color-text-muted)}.text-subtle{color:var(--color-text-subtle)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-mono{font-family:var(--font-mono);font-size:.875em}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeIn .3s ease forwards}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.stat-card h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.stat-card .value{font-size:2rem;font-weight:700;color:var(--color-text)}.stat-card .change{font-size:.75rem;margin-top:var(--space-xs)}
