/* =============================================================
   Groupr Landing — Shared Design System
   Used by: index.html, terms.html, privacy.html
   ============================================================= */

/* ── Design tokens ── */
:root {
  --green: #1D9E75;
  --green-dark: #0F6E56;
  --green-light: #E1F5EE;
  --green-light-text: #0F6E56;
  --orange: #EF9F27;
  --orange-light: #FEF3DC;
  --red: #D85A30;
  --red-light: #FAECE7;
  --blue: #3A7FD5;
  --blue-light: #EAF2FD;
  --purple: #7F77DD;
  --purple-light: #EEEDFE;
  --bg: #f1f0ec;
  --surface: #ffffff;
  --surface2: #f7f7f5;
  --text: #1a1a18;
  --text-2: #6b6b68;
  --text-3: #a0a09d;
  --border: rgba(0,0,0,0.09);
  --border2: rgba(0,0,0,0.17);
  --radius: 8px;
  --radius-lg: 14px;
  --radius-xl: 22px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.09), 0 2px 6px rgba(0,0,0,0.06);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.12), 0 4px 14px rgba(0,0,0,0.08);
}

[data-theme="dark"] {
  --green-light: rgba(29,158,117,0.16);
  --green-light-text: #4dcca4;
  --orange-light: rgba(239,159,39,0.16);
  --red-light: rgba(216,90,48,0.16);
  --blue-light: rgba(58,127,213,0.16);
  --purple-light: rgba(127,119,221,0.16);
  --bg: #131311;
  --surface: #1f1f1d;
  --surface2: #272725;
  --text: #f0f0ec;
  --text-2: #9a9a96;
  --text-3: #56564f;
  --border: rgba(255,255,255,0.08);
  --border2: rgba(255,255,255,0.15);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.35);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.55);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --green-light: rgba(29,158,117,0.16);
    --green-light-text: #4dcca4;
    --orange-light: rgba(239,159,39,0.16);
    --red-light: rgba(216,90,48,0.16);
    --blue-light: rgba(58,127,213,0.16);
    --purple-light: rgba(127,119,221,0.16);
    --bg: #131311;
    --surface: #1f1f1d;
    --surface2: #272725;
    --text: #f0f0ec;
    --text-2: #9a9a96;
    --text-3: #56564f;
    --border: rgba(255,255,255,0.08);
    --border2: rgba(255,255,255,0.15);
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.35);
    --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
    --shadow-lg: 0 16px 48px rgba(0,0,0,0.55);
  }
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { color-scheme: light; }
[data-theme="dark"] { color-scheme: dark; }

/* ── Base ── */
body {
  font-family: system-ui, -apple-system, 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: background 0.25s, color 0.25s;
}

/* ── Bilingual helpers ── */
[data-lang="nl"] .en { display: none !important; }
[data-lang="en"] .nl { display: none !important; }

/* ── Navbar ── */
.nav-wrap {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 24px; max-width: 1060px; margin: 0 auto; width: 100%;
}
.logo { display: flex; align-items: center; text-decoration: none; }
.logo svg { display: block; height: 34px; width: auto; color: var(--text); }
.nav-actions { display: flex; align-items: center; gap: 8px; }
.nav-links { display: flex; gap: 2px; }
.nav-link {
  font-size: 0.875rem; font-weight: 600; color: var(--text-2);
  text-decoration: none; padding: 6px 12px; border-radius: var(--radius);
  display: inline-flex; align-items: center; gap: 6px;
  transition: color .15s, background .15s;
}
.nav-link:hover { color: var(--green); background: var(--green-light); }
.icon-btn {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text-2); width: 36px; height: 36px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-family: inherit;
  transition: color .15s, border-color .15s, background .15s;
}
.icon-btn svg { width: 16px; height: 16px; }
.icon-btn:hover { color: var(--green); border-color: var(--green); background: var(--green-light); }
.lang-btn {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text-2); padding: 0 16px; border-radius: 999px;
  font-size: 13px; font-weight: 600; cursor: pointer; font-family: inherit;
  transition: color .15s, border-color .15s, background .15s;
  letter-spacing: .02em; height: 36px;
}
.lang-btn:hover { color: var(--green); border-color: var(--green); background: var(--green-light); }

/* ── Theme icon toggle ── */
[data-theme="dark"] .theme-sun { display: none; }
[data-theme="dark"] .theme-moon { display: block; }
.theme-sun { display: block; }
.theme-moon { display: none; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-sun { display: none; }
  :root:not([data-theme="light"]) .theme-moon { display: block; }
}

/* ── Footer ── */
footer {
  margin-top: auto; text-align: center; padding: 24px;
  color: var(--text-3); font-size: .85rem; border-top: 1px solid var(--border);
}
footer a { color: var(--green); text-decoration: none; font-weight: 500; }
footer a:hover { text-decoration: underline; }

/* ── Responsive: hide nav-links on small screens ── */
@media (max-width: 480px) { .nav-links { display: none; } }


/* =============================================================
   Legal page components (terms.html, privacy.html)
   ============================================================= */

/* ── Layout ── */
main {
  max-width: 860px;
  margin: 0 auto;
  padding: 48px 24px 80px;
}

/* ── Page hero ── */
.page-hero { margin-bottom: 48px; }
.page-hero h1 {
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  font-weight: 800; letter-spacing: -0.5px; line-height: 1.2;
  color: var(--text); margin-bottom: 12px;
}
.page-hero .meta { color: var(--text-2); font-size: 0.9rem; }
.page-hero .meta strong { color: var(--green); }

/* ── Acceptance notice ── */
.acceptance-notice {
  background: color-mix(in srgb, var(--green) 8%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--green) 30%, var(--border));
  border-left: 4px solid var(--green);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin-bottom: 32px;
}
.acceptance-notice p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-2);
  line-height: 1.6;
}
.acceptance-notice strong { color: var(--text); }

/* ── Table of contents ── */
.toc {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px 28px;
  margin-bottom: 48px; box-shadow: var(--shadow-sm);
}
.toc h2 {
  font-size: 0.8rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--text-3); margin-bottom: 14px;
}
.toc ol { list-style: decimal; padding-left: 20px; display: grid; gap: 6px; }
.toc a { color: var(--green); text-decoration: none; font-size: 0.9rem; }
.toc a:hover { text-decoration: underline; }

/* ── Legal sections ── */
.legal-section { margin-bottom: 52px; }
.legal-section h2 {
  font-size: 1.3rem; font-weight: 700; letter-spacing: -0.2px;
  color: var(--text); margin-bottom: 16px; padding-top: 8px;
  border-top: 2px solid var(--green); display: inline-block; padding-right: 4px;
}
.legal-section h3 { font-size: 1rem; font-weight: 600; color: var(--text); margin: 20px 0 8px; }
.legal-section p { color: var(--text-2); margin-bottom: 12px; font-size: 0.9375rem; }
.legal-section p:last-child { margin-bottom: 0; }
.legal-section ul, .legal-section ol { padding-left: 20px; margin-bottom: 12px; display: grid; gap: 6px; }
.legal-section li { color: var(--text-2); font-size: 0.9375rem; }
.legal-section a { color: var(--green); }

/* ── Info box (green) ── */
.info-box {
  background: var(--green-light); border-left: 3px solid var(--green);
  border-radius: 0 var(--radius) var(--radius) 0; padding: 14px 18px; margin: 16px 0;
}
.info-box p { color: var(--green-light-text) !important; font-size: 0.9rem !important; margin-bottom: 0 !important; }

/* ── Note box (blue) ── */
.note-box {
  background: var(--blue-light); border-left: 3px solid var(--blue);
  border-radius: 0 var(--radius) var(--radius) 0; padding: 14px 18px; margin: 16px 0;
}
.note-box p { color: var(--blue) !important; font-size: 0.9rem !important; margin-bottom: 4px !important; }
.note-box p:last-child { margin-bottom: 0 !important; }

/* ── Company card ── */
.company-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px 28px;
  box-shadow: var(--shadow-sm); margin-top: 16px;
}
.company-card .company-name {
  font-weight: 700; font-size: 1rem; color: var(--text);
  margin-bottom: 8px; display: flex; align-items: center; gap: 10px;
}
.logo-icon-sm {
  width: 28px; height: 28px; background: var(--green); border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  color: white; font-weight: 800; font-size: 0.85rem; flex-shrink: 0;
}
.company-card dl { display: grid; grid-template-columns: max-content 1fr; gap: 4px 20px; margin-top: 12px; }
.company-card dt {
  font-size: 0.8rem; font-weight: 600; color: var(--text-3);
  text-transform: uppercase; letter-spacing: 0.05em; padding-top: 2px;
}
.company-card dd { font-size: 0.9rem; color: var(--text-2); }
.company-card dd a { color: var(--green); text-decoration: none; }
.company-card dd a:hover { text-decoration: underline; }

/* ── Plans table (terms.html) ── */
.plans-table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 0.9rem; }
.plans-table th {
  text-align: left; padding: 10px 14px; background: var(--surface2);
  color: var(--text-3); font-size: 0.75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em; border-bottom: 1px solid var(--border);
}
.plans-table td { padding: 10px 14px; color: var(--text-2); border-bottom: 1px solid var(--border); vertical-align: top; }
.plans-table tr:last-child td { border-bottom: none; }
.plan-badge {
  display: inline-block; padding: 2px 8px; border-radius: 99px;
  font-size: 0.75rem; font-weight: 700;
  background: var(--surface2); color: var(--text-2); border: 1px solid var(--border);
}
.plan-badge.pro  { background: rgba(58,127,213,0.12); color: #3A7FD5; border-color: rgba(58,127,213,0.25); }
.plan-badge.club { background: rgba(127,119,221,0.12); color: #7F77DD; border-color: rgba(127,119,221,0.25); }

/* ── Data table (privacy.html) ── */
.data-table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 0.875rem; }
.data-table th {
  text-align: left; padding: 10px 14px; background: var(--surface2);
  color: var(--text-3); font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  border-bottom: 1px solid var(--border); white-space: nowrap;
}
.data-table td { padding: 10px 14px; color: var(--text-2); border-bottom: 1px solid var(--border); vertical-align: top; }
.data-table tr:last-child td { border-bottom: none; }
.data-table td:first-child { font-weight: 600; color: var(--text); white-space: nowrap; }
.basis-tag { display: inline-block; padding: 2px 8px; border-radius: 99px; font-size: 0.72rem; font-weight: 700; white-space: nowrap; }
.basis-contract { background: var(--green-light); color: var(--green-light-text); }
.basis-legit    { background: var(--blue-light);  color: var(--blue); }
.basis-legal    { background: var(--orange-light); color: #b07000; }

/* ── Rights grid (privacy.html) ── */
.rights-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 16px 0; }
.right-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; }
.right-card .right-title {
  font-size: 0.85rem; font-weight: 700; color: var(--text);
  margin-bottom: 4px; display: flex; align-items: center; gap: 8px;
}
.right-card .right-title .art {
  font-size: 0.7rem; background: var(--green-light); color: var(--green-light-text);
  padding: 1px 6px; border-radius: 99px; font-weight: 700;
}
.right-card p { font-size: 0.8rem; color: var(--text-2); margin: 0; }

/* ── Legal pages: mobile ── */
@media (max-width: 600px) {
  main { padding: 32px 16px 64px; }
  .toc { padding: 18px 20px; }
  .company-card { padding: 18px 20px; }
  .company-card dl { grid-template-columns: 1fr; gap: 2px; }
  .company-card dt { margin-top: 8px; }
  .rights-grid { grid-template-columns: 1fr; }
  .data-table { font-size: 0.8rem; }
  .data-table th, .data-table td { padding: 8px 10px; }
}
