:root {
  --page-bg: #f7f9fc;
  --page-bg-2: #eef3fb;
  --panel: #ffffff;
  --panel-soft: #f3f6fc;
  --border: #d8e1f2;
  --border-strong: #b8c7e6;
  --primary: #0c63ff;
  --primary-strong: #0849c9;
  --accent: #12b3ff;
  --text: #0f1b35;
  --muted: #4f5b75;
  --shadow: 0 18px 50px rgba(12, 35, 78, 0.08);
  --shadow-soft: 0 10px 28px rgba(12, 35, 78, 0.06);
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 20px;
  --radius-pill: 999px;
  --transition: 160ms ease;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }

body {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  color: var(--text);
  background:
    radial-gradient(1200px circle at 12% 15%, rgba(12, 99, 255, 0.08), transparent 35%),
    radial-gradient(900px circle at 82% 5%, rgba(18, 179, 255, 0.08), transparent 32%),
    linear-gradient(140deg, var(--page-bg), var(--page-bg-2));
  line-height: 1.6;
  letter-spacing: 0.01em;
}

a { color: var(--primary-strong); text-decoration: none; transition: color var(--transition), opacity var(--transition); }
a:hover { color: var(--accent); }
img { max-width: 100%; display: block; }

h1, h2, h3 { margin: 0 0 0.5rem; letter-spacing: 0.01em; }
h1 { font-size: clamp(2.2rem, 3.4vw, 3rem); color: var(--primary-strong); }
h2 { font-size: clamp(1.5rem, 2.2vw, 2rem); color: #12203e; }
p { color: var(--muted); margin: 0 0 1rem; }

.navbar {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 0.85rem 1.3rem;
  max-width: 1200px;
  margin: 18px auto;
  position: sticky;
  top: 18px;
  z-index: 20;
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-soft);
}

.navbar .logo { font-weight: 700; color: var(--primary-strong); letter-spacing: 0.06em; display: flex; align-items: center; }
.navbar .logo img { height: 38px; width: auto; display: block; }

.navbar .nav-links {
  list-style: none;
  display: flex;
  gap: 0.4rem;
  margin: 0 0 0 auto;
  padding: 0;
}

.navbar .nav-links a {
  color: var(--text);
  padding: 0.45rem 0.9rem;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  font-weight: 600;
  transition: color var(--transition), border-color var(--transition), background var(--transition), transform var(--transition);
}

.navbar .nav-links a:hover { color: var(--primary-strong); border-color: var(--border); background: var(--panel-soft); transform: translateY(-1px); }

.navbar .nav-links a.active { background: var(--primary); color: #fff; border-color: transparent; box-shadow: 0 10px 30px rgba(12, 99, 255, 0.25); }
.navbar .nav-user { padding: 0.45rem 0.9rem; color: var(--muted); font-weight: 600; }

@media (max-width: 900px) {
  .navbar { flex-wrap: wrap; justify-content: center; gap: 0.6rem; }
  .navbar .nav-links { width: 100%; justify-content: center; flex-wrap: wrap; }
}

.main { max-width: 1200px; margin: 0 auto 90px; padding: 0 1.4rem 2.4rem; }
header { text-align: center; padding: 48px 0 18px; }
header .logo { width: 170px; margin: 12px auto 0; filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.12)); }

main { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: clamp(1.4rem, 3vw, 2.2rem); }
main h2 { color: var(--primary-strong); }
.text { font-size: 1.05rem; color: var(--text); }
.lead { font-size: 1.05rem; }

footer {
  max-width: 1200px;
  margin: 0 auto 28px;
  padding: 1rem 1.4rem;
  text-align: center;
  color: var(--muted);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.85);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-soft);
}

.site-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
}


button,
.btn,
.filter-btn,
.btn-submit,
.add-review-btn,
#more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  background: linear-gradient(120deg, var(--primary), #1a78ff);
  color: #fff;
  border: 1px solid var(--primary-strong);
  padding: 0.75rem 1.2rem;
  font-size: 1rem;
  font-weight: 700;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition), background var(--transition), opacity var(--transition);
  box-shadow: var(--shadow-soft);
  text-decoration: none;
}

button:hover,
.btn:hover,
.filter-btn:hover,
.btn-submit:hover,
.add-review-btn:hover,
#more:hover { transform: translateY(-2px); background: linear-gradient(120deg, #3a7dff, #0c63ff); }
button:active,
.btn:active { transform: translateY(0); box-shadow: none; }
button a { color: inherit; text-decoration: none; }
.btn-ghost {
  background: transparent;
  color: var(--primary-strong);
  border: 1px solid var(--border);
  box-shadow: none;
}
.btn-ghost:hover { background: var(--panel-soft); }

.hero {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  padding: clamp(1.4rem, 3vw, 2.4rem);
  background: linear-gradient(120deg, rgba(12, 99, 255, 0.08), rgba(12, 99, 255, 0.02)), #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  align-items: center;
}

.hero-text { display: grid; gap: 0.7rem; }
.hero-tag {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-pill);
  background: var(--panel-soft);
  border: 1px solid var(--border);
  font-weight: 700;
  width: fit-content;
}
.hero h1 { color: #0c1b3a; }
.hero-actions { display: flex; gap: 0.6rem; flex-wrap: wrap; }

.hero-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 0.7rem;
}
.hero-stats div {
  background: var(--panel-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.8rem;
  text-align: center;
}
.stat-number { display: block; font-size: 1.5rem; font-weight: 800; color: #0c1b3a; }
.stat-label { color: var(--muted); font-weight: 600; }

.hero-card {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: 1.2rem;
  text-align: center;
}
.hero-logo {
  width: 180px;
  margin: 0 auto 0.8rem;
  object-fit: contain;
  filter: drop-shadow(0 10px 30px rgba(0, 0, 0, 0.1));
}
.card-title { font-weight: 800; color: var(--primary-strong); margin: 0 0 0.2rem; }
.platform-row { display: flex; gap: 0.5rem; justify-content: center; flex-wrap: wrap; margin-top: 0.8rem; }
.platform-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.7rem;
  border-radius: var(--radius-pill);
  background: var(--panel-soft);
  border: 1px solid var(--border);
}
.platform-badge img { width: 28px; height: 28px; object-fit: contain; }

.feature-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin: 1.2rem 0;
}
.feature {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1rem;
  box-shadow: var(--shadow-soft);
}

input,
select,
textarea {
  width: 100%;
  padding: 0.9rem 1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #f9fbff;
  color: var(--text);
  font-size: 1rem;
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

input:focus,
select:focus,
textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(12, 99, 255, 0.15); background: #fff; }

form,
.review-form {
  max-width: 820px;
  margin: 28px auto;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: clamp(1.3rem, 3vw, 2rem);
  display: grid;
  gap: 0.7rem;
}

form h2 { margin-bottom: 0.2rem; }
form label { font-weight: 600; color: var(--text); }
form button,
.review-form button { width: 100%; }

.back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: 0.7rem;
  padding: 0.45rem 0.9rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  background: var(--panel-soft);
  color: var(--text);
  font-weight: 600;
  box-shadow: var(--shadow-soft);
  transition: color var(--transition), border-color var(--transition), background var(--transition), box-shadow var(--transition), transform var(--transition);
}
.back-link:hover {
  color: var(--primary-strong);
  border-color: var(--primary);
  background: #fff;
  transform: translateY(-1px);
  box-shadow: var(--shadow);
}
.back-link:active { transform: translateY(0); box-shadow: var(--shadow-soft); }

.login-link { display: inline-block; margin-top: 0.7rem; color: var(--muted); }
.login-link a { color: var(--primary-strong); }

.review-filter { margin-bottom: 1.4rem; }
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.9rem;
  padding: 1rem 1.1rem;
  background: var(--panel-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.filter-bar label { font-weight: 700; color: var(--text); }
.filter-select { max-width: 260px; }
.add-review-btn { margin: 0 0 1.4rem; }

.reviews-container { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem; }
.review-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.15rem 1.2rem;
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.review-card:hover { transform: translateY(-3px); border-color: var(--primary); box-shadow: var(--shadow); }
.review-card h3 { color: var(--text); margin-bottom: 0.35rem; }
.review-card p { margin: 0.22rem 0; color: var(--muted); }
.review-card .platform { font-size: 0.94rem; color: var(--primary-strong); }

.reviews {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(1.4rem, 3vw, 2.1rem);
  box-shadow: var(--shadow-soft);
  text-align: center;
}
.reviews.luxe { text-align: left; }
.reviews h2 { margin-bottom: 0.9rem; }
.review-platforms { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.9rem; margin-top: 1.1rem; }
.platform {
  background: var(--panel-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.05rem 1rem;
  box-shadow: var(--shadow-soft);
  display: grid;
  gap: 0.3rem;
  align-items: center;
  justify-items: center;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.platform.luxe-card { text-align: left; align-items: start; }
.platform-top { display: flex; justify-content: space-between; align-items: center; width: 100%; }
.platform-top img { width: 60px; height: 60px; }
.platform:hover { transform: translateY(-5px); border-color: var(--primary); box-shadow: var(--shadow); }
.platform img { width: 70px; height: 70px; object-fit: contain; filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.08)); }
.stars { color: var(--primary-strong); font-weight: 700; }
.platform p { color: var(--text); font-size: 1rem; }

.register-container { min-height: 68vh; display: grid; place-items: center; }
.register-box {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.9rem;
  box-shadow: var(--shadow);
  width: min(480px, 100%);
  text-align: left;
}
.register-box h2 { margin-bottom: 0.35rem; color: var(--primary-strong); }
.register-box label { margin-top: 0.45rem; }
.register-box .btn { margin-top: 0.85rem; width: 100%; }
.error-text { color: #c0392b; margin: 0 0 0.6rem; font-weight: 600; }

.faq-item {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1rem 1.05rem;
  margin: 0.55rem 0;
  box-shadow: var(--shadow-soft);
  transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.faq-item:hover { transform: translateY(-2px); border-color: var(--primary); box-shadow: var(--shadow); }
.faq-item summary { cursor: pointer; list-style: none; font-weight: 700; display: flex; align-items: center; justify-content: space-between; color: var(--text); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "\25be"; font-size: 0.95rem; color: var(--muted); transition: transform var(--transition), color var(--transition); }
.faq-item[open] summary::after { transform: rotate(-180deg); color: var(--primary-strong); }
.faq-item p { margin-top: 0.55rem; color: var(--muted); }

.table-wrapper,
.container { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1rem; box-shadow: var(--shadow-soft); }
.container { max-height: 60vh; overflow-y: auto; }

table { width: 100%; border-collapse: collapse; color: var(--text); }
th, td { text-align: left; padding: 0.8rem 0.75rem; border-bottom: 1px solid var(--border); }
th { font-weight: 700; color: var(--text); letter-spacing: 0.01em; }
tbody tr:hover { background: var(--panel-soft); }
td.fitwidth { width: 1%; white-space: nowrap; }

tr.clicked,
#clicked { background-color: rgba(12, 99, 255, 0.08); }

.dash-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.dash-grid.top {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0 0 0.2rem;
}

.muted { color: var(--muted); font-size: 0.95rem; }

.chip {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.65rem;
  border-radius: var(--radius-pill);
  background: rgba(12, 99, 255, 0.12);
  color: var(--primary-strong);
  font-weight: 700;
  font-size: 0.85rem;
}

.chip.ghost {
  background: var(--panel-soft);
  border: 1px solid var(--border);
  color: var(--text);
}

.highlight {
  background: linear-gradient(135deg, #e6f0ff, #f5f9ff);
  border-color: transparent;
}

.progress {
  width: 100%;
  height: 10px;
  background: var(--panel-soft);
  border-radius: var(--radius-pill);
  overflow: hidden;
  border: 1px solid var(--border);
}

.progress-bar {
  height: 100%;
  background: linear-gradient(120deg, var(--primary), #1a78ff);
}

.metric-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.6rem;
  margin: 0.6rem 0;
}

.metric-row strong { display: block; color: var(--text); font-size: 1.1rem; }
.metric-row span { display: block; }

.review-list {
  list-style: none;
  padding: 0;
  margin: 0.4rem 0 0;
  display: grid;
  gap: 0.5rem;
}

.review-list li {
  background: var(--panel-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.75rem 0.8rem;
  display: grid;
  gap: 0.35rem;
  overflow: hidden;
}

.review-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
}

.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.6rem;
  border-radius: var(--radius-pill);
  background: rgba(12, 99, 255, 0.12);
  color: var(--primary-strong);
  font-weight: 700;
  font-size: 0.9rem;
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.2rem 0.65rem;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 0.9rem;
}

.rating-badge { background: #e8f1ff; color: var(--primary-strong); }
.sentiment-positief { background: #e8fbe8; color: #0f9d58; }
.sentiment-neutraal { background: #fff7e6; color: #c47f00; }
.sentiment-negatief { background: #ffecec; color: #c0392b; }

.vote-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(90px, 1fr));
  gap: 0.5rem;
  margin-top: 0.35rem;
  align-items: center;
}

.vote-form {
  margin: 0;
}

.btn-like,
.btn-dislike,
.btn-reset {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 0.75rem 0.9rem;
  cursor: pointer;
  font-weight: 700;
  color: var(--text);
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
  box-shadow: 0 6px 14px rgba(12, 35, 78, 0.08);
  display: grid;
  place-items: center;
  min-height: 76px;
}

.btn-like:hover,
.btn-dislike:hover,
.btn-reset:hover {
  transform: translateY(-1px);
  border-color: var(--primary);
  box-shadow: var(--shadow-soft);
}

.btn-dislike {
  background: #fff0f0;
  border-color: #f3c4c4;
}

.btn-like.active { border-color: var(--primary); box-shadow: var(--shadow-soft); color: var(--primary-strong); }
.btn-dislike.active { border-color: #f3c4c4; box-shadow: var(--shadow-soft); color: #c0392b; }

.btn-like .emoji,
.btn-dislike .emoji { font-size: 1.4rem; }
.btn-like .count,
.btn-dislike .count { font-size: 1.2rem; font-weight: 800; color: var(--text); }

.dash-grid.charts {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.card {
  background: #fff;
  border: 1px solid var(--border);
  padding: 16px;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}

.card ul {
  padding-left: 16px;
  margin: 0.4rem 0 0;
  color: var(--muted);
}
