/* public/style.css */
/* Styling voor het Rechtspraak Content Dashboard. */
/* Tabs, stoplicht-kleuren, kaarten, blog, instagram, archief. */
/* Gerelateerd: public/index.html, public/app.js */

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: #f5f5f5;
  color: #333;
  line-height: 1.6;
}

header {
  background: #1a2a3a;
  color: #fff;
  padding: 1.5rem 2rem;
}

header h1 { font-size: 1.5rem; font-weight: 600; }
.subtitle { color: #9ab; font-size: 0.9rem; margin-top: 0.25rem; }

/* Tabs */
.tabs {
  display: flex;
  gap: 0;
  background: #fff;
  border-bottom: 2px solid #eee;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 1rem;
}

.tab {
  padding: 0.75rem 1.5rem;
  border: none;
  background: none;
  font-size: 0.95rem;
  font-weight: 500;
  color: #888;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
}

.tab:hover { color: #333; }
.tab.active { color: #1a2a3a; border-bottom-color: #2ecc71; font-weight: 600; }

/* Tab content */
main { max-width: 900px; margin: 2rem auto; padding: 0 1rem; }
.tab-content { display: none; }
.tab-content.active { display: block; }

footer { text-align: center; padding: 2rem; color: #888; font-size: 0.85rem; }
footer a { color: #5a8; }

.loading, .no-results { text-align: center; padding: 3rem; color: #888; font-size: 1.1rem; }

/* Uitspraak kaart */
.card {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  margin-bottom: 1.5rem;
  overflow: hidden;
}

.card-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid #eee;
}

/* Stoplicht */
.stoplicht { width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0; }
.stoplicht-groen { background: #2ecc71; box-shadow: 0 0 6px rgba(46,204,113,0.4); }
.stoplicht-oranje { background: #f39c12; box-shadow: 0 0 6px rgba(243,156,18,0.4); }
.stoplicht-rood { background: #e74c3c; box-shadow: 0 0 6px rgba(231,76,60,0.4); }

.card-title { font-size: 1rem; font-weight: 600; flex: 1; }
.card-title a { color: #1a2a3a; text-decoration: none; }
.card-title a:hover { text-decoration: underline; }
.card-score { font-weight: 700; font-size: 0.95rem; color: #555; white-space: nowrap; }

.card-body { padding: 1rem 1.25rem; }
.card-meta { display: flex; gap: 1.5rem; font-size: 0.85rem; color: #777; margin-bottom: 0.75rem; flex-wrap: wrap; }
.card-samenvatting { font-size: 0.95rem; color: #444; margin-bottom: 1rem; }

/* Bewaar / Verwijder knoppen */
.btn-save, .btn-remove {
  padding: 0.35rem 0.75rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.8rem;
  cursor: pointer;
  background: #fff;
  color: #555;
  white-space: nowrap;
}

.btn-save:hover { background: #f0f4f8; border-color: #3498db; color: #3498db; }
.btn-remove:hover { background: #fef0f0; border-color: #e74c3c; color: #e74c3c; }

/* Beeldsuggestie */
.beeldsuggestie { background: #f0f4f8; padding: 0.75rem 1rem; border-radius: 6px; font-size: 0.9rem; color: #555; margin-bottom: 1rem; }
.beeldsuggestie strong { color: #333; }

/* Content blokken */
.content-block { margin-bottom: 1rem; }
.content-block label { display: block; font-weight: 600; font-size: 0.85rem; color: #555; margin-bottom: 0.4rem; }
.content-block textarea {
  width: 100%; min-height: 150px; padding: 0.75rem; border: 1px solid #ddd;
  border-radius: 6px; font-family: inherit; font-size: 0.9rem; line-height: 1.5; resize: vertical; color: #333;
}
.content-block textarea:focus { outline: none; border-color: #5a8; }

/* Kopieer knop */
.btn-copy {
  display: inline-block; margin-top: 0.4rem; padding: 0.4rem 0.9rem;
  background: #1a2a3a; color: #fff; border: none; border-radius: 4px; font-size: 0.8rem; cursor: pointer;
}
.btn-copy:hover { background: #2a3a4a; }
.btn-copy.copied { background: #2ecc71; }

/* Afbeelding */
.content-image { margin-bottom: 1rem; }
.content-image img { width: 100%; max-width: 512px; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.1); }

/* Dagwinnaar */
.card-dagwinnaar { border: 2px solid #2ecc71; box-shadow: 0 2px 12px rgba(46,204,113,0.2); }

/* Ranking blok */
.ranking-block { background: #f8faf8; border: 1px solid #d4e8d4; border-radius: 6px; padding: 0.75rem 1rem; margin-bottom: 1rem; }
.ranking-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.5rem; }
.ranking-label { font-weight: 700; font-size: 0.85rem; padding: 0.2rem 0.6rem; border-radius: 4px; }
.ranking-dagwinnaar { background: #2ecc71; color: #fff; }
.ranking-inplannen { background: #3498db; color: #fff; }
.ranking-bewaren { background: #95a5a6; color: #fff; }
.ranking-score { font-size: 0.85rem; font-weight: 600; color: #555; }
.ranking-hook { font-style: italic; font-size: 0.95rem; color: #333; margin-bottom: 0.5rem; }
.ranking-details { display: flex; gap: 1rem; font-size: 0.8rem; color: #777; flex-wrap: wrap; }
.ranking-actions { margin-top: 0.5rem; font-size: 0.85rem; }
.ranking-actions strong { color: #333; }
.ranking-actions ul { margin-top: 0.25rem; padding-left: 1.2rem; }
.ranking-actions li { margin-bottom: 0.15rem; color: #444; }

/* Blog tab */
.blog-post {
  background: #fff; border-radius: 8px; box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  margin-bottom: 2rem; overflow: hidden;
}

.blog-header { padding: 1.5rem 1.5rem 0; }
.blog-header h2 { font-size: 1.3rem; color: #1a2a3a; margin-bottom: 0.5rem; }
.blog-meta { display: flex; gap: 1.5rem; font-size: 0.85rem; color: #777; margin-bottom: 1rem; }
.blog-meta a { color: #3498db; text-decoration: none; }
.blog-meta a:hover { text-decoration: underline; }
.blog-image { padding: 0 1.5rem; }
.blog-image img { width: 100%; max-width: 600px; border-radius: 8px; margin-bottom: 1rem; }
.blog-body { padding: 0 1.5rem 1.5rem; }
.blog-body p { margin-bottom: 1rem; font-size: 0.95rem; line-height: 1.7; color: #444; }

/* Instagram tab */
.insta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}

.insta-card {
  background: #fff; border-radius: 8px; box-shadow: 0 1px 3px rgba(0,0,0,0.1); overflow: hidden;
}

.insta-card img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.insta-placeholder { width: 100%; aspect-ratio: 1; background: #f0f0f0; }
.insta-body { padding: 1rem; }
.insta-date { font-size: 0.8rem; color: #999; margin-bottom: 0.5rem; }
.insta-text { font-size: 0.9rem; color: #333; line-height: 1.5; white-space: pre-wrap; margin-bottom: 0.5rem; max-height: 200px; overflow-y: auto; }

/* Toast notificatie */
.toast {
  position: fixed; bottom: 2rem; left: 50%; transform: translateX(-50%);
  background: #1a2a3a; color: #fff; padding: 0.75rem 1.5rem; border-radius: 8px;
  font-size: 0.9rem; opacity: 0; transition: opacity 0.3s; z-index: 1000;
}
.toast.show { opacity: 1; }

/* Login pagina */
.login-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 50vh;
}

.login-form {
  background: #fff;
  padding: 2rem;
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  width: 100%;
  max-width: 360px;
}

.login-form h2 {
  font-size: 1.2rem;
  color: #1a2a3a;
  margin-bottom: 1.5rem;
  text-align: center;
}

.form-group {
  margin-bottom: 1rem;
}

.form-group label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: #555;
  margin-bottom: 0.3rem;
}

.form-group input {
  width: 100%;
  padding: 0.6rem 0.75rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.95rem;
  font-family: inherit;
}

.form-group input:focus {
  outline: none;
  border-color: #5a8;
}

.btn-login {
  width: 100%;
  padding: 0.7rem;
  background: #1a2a3a;
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  margin-top: 0.5rem;
}

.btn-login:hover { background: #2a3a4a; }

.login-error {
  color: #e74c3c;
  font-size: 0.85rem;
  text-align: center;
  margin-top: 0.75rem;
}

/* Logout knop in header */
.header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.btn-logout {
  background: none;
  border: 1px solid rgba(255,255,255,0.3);
  color: #fff;
  padding: 0.35rem 0.75rem;
  border-radius: 4px;
  font-size: 0.8rem;
  cursor: pointer;
  text-decoration: none;
}

.btn-logout:hover { border-color: #fff; }
