/* =========================================================
   De Hussel App – Frontend CSS
   ========================================================= */

/* ─── Reset & basis ──────────────────────────────────────── */
#hussel-app,
#hussel-portaal {
  --green: #1a7a4a;
  --green-light: #e8f5ee;
  --green-mid: #2e9d61;
  --green-dark: #0f4e2e;
  --accent: #f0c040;
  --bg: #f4f6f2;
  --card: #ffffff;
  --text: #1a2018;
  --text2: #5a6b55;
  --border: rgba(26,122,74,0.12);
  --radius: 14px;
  --shadow: 0 2px 16px rgba(26,122,74,0.08);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--text);
  max-width: 500px;
  margin: 0 auto;
}

/* ─── Scherm-navigatie ───────────────────────────────────── */
.hussel-screen { display: none; }

/* ─── Sessiekaarten ──────────────────────────────────────── */
.hussel-session-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem;
  margin-bottom: .75rem;
  box-shadow: var(--shadow);
}
.hussel-session-title { font-weight: 600; font-size: 1rem; margin-bottom: .2rem; }
.hussel-session-meta  { font-size: .8rem; color: var(--text2); margin-bottom: .6rem; }
.hussel-session-footer { display: flex; align-items: center; justify-content: space-between; }

/* ─── Knoppen ────────────────────────────────────────────── */
.hussel-btn {
  display: inline-block;
  padding: .5rem 1.1rem;
  border-radius: 8px;
  border: 1.5px solid var(--green);
  background: var(--green);
  color: #fff;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background .2s, transform .15s;
}
.hussel-btn:hover { background: var(--green-mid); transform: translateY(-1px); }
.hussel-btn--success { background: transparent; color: var(--green); border-color: var(--green); cursor: default; }
.hussel-btn--full    { background: transparent; color: var(--text2); border-color: var(--border); cursor: default; }
.hussel-btn--danger  { background: #c0392b; border-color: #c0392b; color: #fff; }

/* ─── Badges ─────────────────────────────────────────────── */
.hussel-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 20px;
  font-size: .72rem;
  font-weight: 600;
}
.hussel-badge--open     { background: var(--green-light); color: var(--green-dark); }
.hussel-badge--active   { background: #fff3cd; color: #856404; }
.hussel-badge--finished { background: #f0f0f0; color: #555; }
.hussel-badge--cancelled{ background: #fde8e8; color: #c0392b; }
.hussel-badge--success  { background: var(--green-light); color: var(--green-dark); }
.hussel-badge--full     { background: #f0f0f0; color: #888; }

/* ─── Baanindelingen ─────────────────────────────────────── */
.hussel-court-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: .75rem;
  overflow: hidden;
  box-shadow: var(--shadow);
}
.hussel-court-card--mine { border-color: var(--green); border-width: 2px; }
.hussel-court-header {
  background: var(--green);
  color: #fff;
  padding: .5rem 1rem;
  font-weight: 600;
  font-size: .9rem;
}
.hussel-court-card--mine .hussel-court-header { background: var(--green-dark); }
.hussel-court-body { padding: .75rem 1rem; }
.hussel-net {
  text-align: center;
  font-size: .7rem;
  color: var(--text2);
  letter-spacing: .08em;
  padding: .3rem 0;
  border-top: 1px dashed var(--border);
  border-bottom: 1px dashed var(--border);
  margin: .4rem 0;
}
.hussel-team { display: flex; gap: .5rem; flex-wrap: wrap; }
.hussel-court-player {
  display: flex; align-items: center; gap: 6px;
  padding: .3rem .6rem;
  background: var(--bg);
  border-radius: 8px;
  flex: 1; min-width: 120px;
}
.hussel-court-player--me { background: var(--green-light); border: 1px solid var(--green); }
.hussel-court-player-name { font-size: .85rem; font-weight: 600; }
.hussel-level-pill {
  font-size: .68rem;
  background: var(--green-light);
  color: var(--green-dark);
  padding: 1px 6px;
  border-radius: 10px;
  font-weight: 600;
  margin-left: auto;
}

/* ─── Rond-label ─────────────────────────────────────────── */
.hussel-round-label {
  font-weight: 700;
  color: var(--green-dark);
  font-size: .9rem;
  margin-bottom: .5rem;
}

/* ─── Notificaties ───────────────────────────────────────── */
#hussel-notices { position: fixed; top: 1rem; right: 1rem; z-index: 9999; max-width: 300px; }
.hussel-notice {
  padding: .75rem 1rem;
  border-radius: 10px;
  margin-bottom: .5rem;
  font-size: .85rem;
  font-weight: 600;
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
}
.hussel-notice--success { background: var(--green); color: #fff; }
.hussel-notice--error   { background: #c0392b; color: #fff; }

/* ─── Login notice ───────────────────────────────────────── */
.hussel-login-notice {
  padding: 1rem;
  background: var(--green-light);
  border: 1px solid var(--green);
  border-radius: var(--radius);
  color: var(--green-dark);
  font-size: .9rem;
}

/* ─── Lege staat ─────────────────────────────────────────── */
.hussel-empty { color: var(--text2); font-size: .88rem; font-style: italic; }

/* ─── Navigatie balk ─────────────────────────────────────── */
.hussel-nav {
  display: flex;
  background: var(--green-dark);
  border-radius: var(--radius) var(--radius) 0 0;
  overflow: hidden;
}
.hussel-bnav-item {
  flex: 1;
  padding: .65rem .5rem;
  text-align: center;
  cursor: pointer;
  color: rgba(255,255,255,.6);
  font-size: .78rem;
  font-weight: 500;
  border: none;
  background: transparent;
  transition: background .2s, color .2s;
}
.hussel-bnav-item:hover { background: rgba(255,255,255,.08); }
.hussel-bnav-item.active { color: var(--accent); font-weight: 700; }

/* ─── Portaal ────────────────────────────────────────────── */
.hussel-portaal-session {
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
  padding: .75rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  margin-bottom: .5rem;
}
