/** Tibia Multi-Guild - Global Styles | Centralized and reusable CSS */
:root{--primary:#3498db;--primary-dark:#2980b9;--secondary:#95a5a6;--success:#2ecc71;--warning:#f39c12;--danger:#e74c3c;--dark:#2c3e50;--light:#ecf0f1;--white:#fff;--online:#2ecc71;--offline:#95a5a6;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 3px rgba(0,0,0,.12);--shadow-md:0 4px 6px rgba(0,0,0,.1);--shadow-lg:0 10px 25px rgba(0,0,0,.15);--sidebar-width:250px;--header-height:70px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.6;color:var(--dark);background:var(--light)}.dashboard-container{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--dark);color:var(--white);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:1000}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}.user-info{color:var(--secondary);font-size:var(--font-size-sm)}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.nav-item{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);color:var(--white);text-decoration:none;transition:background .2s}.nav-item:hover{background:rgba(255,255,255,.1)}.nav-item.active{background:var(--primary)}.nav-item .icon{margin-right:var(--spacing-md);font-size:var(--font-size-lg)}.sidebar-footer{padding:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1)}.main-content{margin-left:var(--sidebar-width);flex:1;padding:var(--spacing-xl);max-width:calc(100vw - var(--sidebar-width))}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.content-header h1{font-size:var(--font-size-xl);color:var(--dark)}.header-actions{display:flex;gap:var(--spacing-md);align-items:center}.btn{padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-md);cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;font-weight:500}.btn-primary{background:var(--primary);color:var(--white)}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--secondary);color:var(--white)}.btn-secondary:hover,.btn-danger:hover{opacity:.9}.btn-danger{background:var(--danger);color:var(--white)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.badge.success{background:var(--success);color:var(--white)}.badge.warning{background:var(--warning);color:var(--white)}.badge.danger{background:var(--danger);color:var(--white)}.badge.secondary{background:var(--secondary);color:var(--white)}.status-indicator{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm)}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot.online{background:var(--online);box-shadow:0 0 8px var(--online)}.dot.offline{background:var(--offline)}.stat-card,.domain-card,.content-section{background:var(--white);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:box-shadow .2s}.stat-card:hover,.domain-card:hover{box-shadow:var(--shadow-md)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{display:flex;align-items:center;gap:var(--spacing-md)}.stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--light);border-radius:var(--radius-md)}.stat-content{flex:1}.stat-label{color:var(--secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--dark)}.content-section{margin-bottom:var(--spacing-lg)}.content-section h2{margin-bottom:var(--spacing-md);font-size:var(--font-size-lg)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.domains-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.domain-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.domain-header h3{font-size:var(--font-size-md)}.domain-info p{margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.data-table{width:100%;border-collapse:collapse;background:var(--white)}.data-table thead{background:var(--light)}.data-table th{padding:var(--spacing-md);text-align:left;font-weight:600;color:var(--dark)}.data-table td{padding:var(--spacing-md);border-top:1px solid var(--light)}.data-table tbody tr:hover{background:var(--light)}.form-input,.form-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--secondary);border-radius:var(--radius-sm);font-size:var(--font-size-md);width:100%;font-family:var(--font-family)}.form-input:focus,.form-select:focus{outline:0;border-color:var(--primary)}.filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.filters>*{flex:1;min-width:200px}.loading,.empty-state,.info-text{text-align:center;padding:var(--spacing-xl);color:var(--secondary)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%)}.login-box{background:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px}.login-box h1{text-align:center;margin-bottom:var(--spacing-xl);color:var(--dark)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-sm);color:var(--dark);font-weight:500}.btn-block{width:100%;padding:var(--spacing-md)}.alert{padding:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}.alert.error{background:#ffe6e6;color:var(--danger);border:1px solid var(--danger)}.alert.success{background:#e6ffe6;color:var(--success);border:1px solid var(--success)}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .3s}.sidebar.active{transform:translateX(0)}.main-content{margin-left:0;max-width:100vw}.stats-grid,.domains-list,.filters{grid-template-columns:1fr;flex-direction:column}.filters>*{min-width:100%}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.flex{display:flex}.flex-center{display:flex;justify-content:center;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}

/* ==================== MODALS ==================== */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  animation: fadeIn 0.2s;
}

.modal {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  width: 90%;
  max-width: 600px;
  max-height: 90vh;
  overflow-y: auto;
  animation: slideUp 0.3s;
}

.modal-small {
  max-width: 400px;
}

.modal-header {
  padding: var(--spacing-lg);
  border-bottom: 1px solid var(--light);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.modal-header h2 {
  margin: 0;
  font-size: var(--font-size-lg);
}

.modal-close {
  background: none;
  border: none;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  color: var(--secondary);
  transition: color 0.2s;
}

.modal-close:hover {
  color: var(--danger);
}

.modal-body {
  padding: var(--spacing-lg);
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-md);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--light);
  margin-top: var(--spacing-lg);
}

/* ==================== FORM STYLES ==================== */
.form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-md);
}

.form-group {
  margin-bottom: var(--spacing-md);
}

.form-group label {
  display: block;
  margin-bottom: var(--spacing-sm);
  font-weight: 600;
  color: var(--dark);
}

.form-group small {
  display: block;
  margin-top: var(--spacing-xs);
  color: var(--secondary);
  font-size: var(--font-size-sm);
}

.form-group input[type="text"],
.form-group input[type="password"],
.form-group input[type="number"],
.form-group input[type="date"],
.form-group select,
.form-group textarea {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--secondary);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-md);
  font-family: var(--font-family);
  transition: border-color 0.2s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

.form-group input[readonly] {
  background: var(--light);
  cursor: not-allowed;
}

.checkbox-label {
  display: flex !important;
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  font-weight: 400 !important;
}

.checkbox-label input[type="checkbox"] {
  width: auto;
  cursor: pointer;
}

/* ==================== NOTIFICATIONS/TOASTS ==================== */
.notification {
  position: fixed;
  top: 20px;
  right: 20px;
  background: var(--white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: var(--spacing-md) var(--spacing-lg);
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  min-width: 300px;
  max-width: 500px;
  transform: translateX(120%);
  transition: transform 0.3s ease-in-out;
  z-index: 10000;
}

.notification.show {
  transform: translateX(0);
}

.notification-icon {
  font-size: 1.5rem;
}

.notification-message {
  flex: 1;
  font-size: var(--font-size-md);
}

.notification-success {
  border-left: 4px solid var(--success);
}

.notification-error {
  border-left: 4px solid var(--danger);
}

.notification-warning {
  border-left: 4px solid var(--warning);
}

.notification-info {
  border-left: 4px solid var(--primary);
}

/* ==================== ANIMATIONS ==================== */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ==================== ADDITIONAL COMPONENTS ==================== */
.action-buttons {
  display: flex;
  gap: var(--spacing-xs);
}

.action-buttons .btn {
  padding: var(--spacing-xs) var(--spacing-sm);
}

.domain-actions {
  display: flex;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-md);
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--light);
}

.player-online {
  background: rgba(46, 204, 113, 0.05);
}

.info-box {
  padding: var(--spacing-xl);
  background: var(--light);
  border-radius: var(--radius-md);
  text-align: center;
}

.info-box h3 {
  margin-bottom: var(--spacing-md);
  color: var(--dark);
}

.info-box p {
  color: var(--secondary);
  margin-bottom: var(--spacing-sm);
}

.loading-spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 3px solid var(--light);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

code {
  background: var(--light);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  font-family: 'Courier New', monospace;
  font-size: 0.9em;
}

/* ==================== RESPONSIVE ==================== */
@media (max-width: 768px) {
  .modal {
    width: 95%;
    max-height: 95vh;
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .notification {
    min-width: auto;
    max-width: calc(100% - 40px);
    left: 20px;
    right: 20px;
  }

  .action-buttons {
    flex-direction: column;
  }

  .domain-actions {
    flex-direction: column;
  }
}
