/* ============================================================
   ClubManager v2 — SITE CSS (browser web)
   Import: variables.css → typography.css → site.css
   NU se folosește în PWA (app.css separat)
   ============================================================ */

@import url('variables.css');
@import url('typography.css');

/* ---- Layout principal ---- */

.site-wrapper {
  display: flex;
  min-height: 100vh;
}

.site-sidebar {
  width: var(--sidebar-w);
  background: var(--bg-sidebar);
  position: fixed;
  top: 0; left: 0; bottom: 0;
  overflow-y: auto;
  z-index: 100;
}

.site-main {
  margin-left: var(--sidebar-w);
  flex: 1;
  min-height: 100vh;
}

.site-topbar {
  height: var(--topbar-h);
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 24px;
  position: sticky;
  top: 0;
  z-index: 50;
}

.site-content {
  padding: 32px 24px;
}

/* ---- Card ---- */

.card {
  background:    var(--bg-card);
  border:        1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow:    var(--shadow-sm);
  padding:       24px;
}

.card--flat {
  box-shadow: none;
}

/* ---- Butoane ---- */

.btn {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  padding:         10px 20px;
  border-radius:   var(--radius-sm);
  font-size:       .9rem;
  font-weight:     600;
  cursor:          pointer;
  border:          none;
  transition:      background .15s, transform .1s;
  text-decoration: none;
}

.btn:active { transform: scale(.98); }

.btn-primary {
  background: var(--primary);
  color:      var(--text-inv);
}
.btn-primary:hover { background: var(--primary-hover); }

.btn-outline {
  background: transparent;
  border:     2px solid var(--primary);
  color:      var(--primary);
}
.btn-outline:hover { background: var(--primary-light); }

.btn-danger {
  background: var(--danger);
  color:      #fff;
}

.btn-sm { padding: 6px 14px; font-size: .8rem; }
.btn-lg { padding: 14px 28px; font-size: 1rem; }

/* ---- Formulare ---- */

.form-group { display: flex; flex-direction: column; gap: 6px; }

.form-label {
  font-size:   .85rem;
  font-weight: 600;
  color:       var(--text-2);
}

.form-control {
  padding:       10px 14px;
  border:        1px solid var(--border);
  border-radius: var(--radius-sm);
  background:    var(--bg-input);
  color:         var(--text-1);
  font-size:     .95rem;
  transition:    border-color .15s;
  width:         100%;
}

.form-control:focus {
  outline:      none;
  border-color: var(--border-focus);
  box-shadow:   0 0 0 3px var(--primary-light);
}

.form-control::placeholder { color: var(--text-4); }

/* ---- Badge ---- */

.badge {
  display:       inline-flex;
  align-items:   center;
  padding:       3px 10px;
  border-radius: 999px;
  font-size:     .75rem;
  font-weight:   600;
}

.badge-primary { background: var(--primary-light); color: var(--primary); }
.badge-success { background: #dcfce7; color: #15803d; }
.badge-danger  { background: #fee2e2; color: #dc2626; }
.badge-warning { background: #fef9c3; color: #b45309; }
.badge-neutral { background: var(--border); color: var(--text-3); }

[data-theme="dark"] .badge-success { background: #14532d; color: #86efac; }
[data-theme="dark"] .badge-danger  { background: #7f1d1d; color: #fca5a5; }
[data-theme="dark"] .badge-warning { background: #78350f; color: #fcd34d; }

/* ---- Tabele ---- */

.table-wrap { overflow-x: auto; }

.table {
  width:           100%;
  border-collapse: collapse;
  font-size:       .9rem;
}

.table th {
  text-align:     left;
  padding:        10px 14px;
  font-size:      .75rem;
  font-weight:    600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color:          var(--text-3);
  border-bottom:  2px solid var(--border);
}

.table td {
  padding:       12px 14px;
  border-bottom: 1px solid var(--border);
  color:         var(--text-2);
}

.table tr:hover td { background: var(--bg); }

/* ---- Responsive ---- */

@media (max-width: 768px) {
  .site-sidebar { display: none; }
  .site-main    { margin-left: 0; }
  .site-content { padding: 20px 16px; }
}
