/* Art direction: Family Tree app → warm, clean, trustworthy
   Palette: warm beige surfaces, teal accent
   Typography: DM Serif Display (headings) + DM Sans (body)
   Density: balanced */

:root, [data-theme="light"] {
  --text-xs:   clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem,0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem,    0.95rem+ 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem,1rem   + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,  1.2rem + 1.25vw, 2.25rem);

  --space-1:2px; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem;
  --space-10:2.5rem; --space-12:3rem; --space-16:4rem;

  --color-bg:#f7f6f2; --color-surface:#f9f8f5; --color-surface-2:#fbfbf9;
  --color-surface-offset:#f3f0ec; --color-surface-dynamic:#e6e4df;
  --color-divider:#dcd9d5; --color-border:#d4d1ca;

  --color-text:#28251d; --color-text-muted:#7a7974; --color-text-faint:#bab9b4;
  --color-text-inverse:#f9f8f4;

  --color-primary:#01696f; --color-primary-hover:#0c4e54; --color-primary-active:#0f3638;
  --color-primary-highlight:#cedcd8;

  --color-success:#437a22; --color-success-hover:#2e5c10; --color-success-highlight:#d4dfcc;
  --color-error:#a12c7b;   --color-error-hover:#7d1e5e;   --color-error-highlight:#e0ced7;
  --color-warning:#964219; --color-warning-hover:#713417; --color-warning-highlight:#ddcfc6;

  --radius-sm:.375rem; --radius-md:.5rem; --radius-lg:.75rem;
  --radius-xl:1rem; --radius-full:9999px;
  --shadow-sm:0 1px 2px oklch(0.2 0.01 80/.06);
  --shadow-md:0 4px 12px oklch(0.2 0.01 80/.08);
  --shadow-lg:0 12px 32px oklch(0.2 0.01 80/.12);
  --transition-interactive:180ms cubic-bezier(.16,1,.3,1);
  --content-default:960px; --content-wide:1200px; --content-narrow:640px;
  --font-display:'DM Serif Display',Georgia,serif;
  --font-body:'DM Sans','Helvetica Neue',sans-serif;
}

[data-theme="dark"] {
  --color-bg:#171614; --color-surface:#1c1b19; --color-surface-2:#201f1d;
  --color-surface-offset:#1d1c1a; --color-surface-dynamic:#2d2c2a;
  --color-divider:#262523; --color-border:#393836;
  --color-text:#cdccca; --color-text-muted:#797876; --color-text-faint:#5a5957;
  --color-text-inverse:#2b2a28;
  --color-primary:#4f98a3; --color-primary-hover:#227f8b; --color-primary-active:#1a626b;
  --color-primary-highlight:#313b3b;
  --color-success:#6daa45; --color-success-hover:#4d8f25; --color-success-highlight:#3a4435;
  --color-error:#d163a7;   --color-error-hover:#b9478f;   --color-error-highlight:#4c3d46;
  --color-warning:#bb653b; --color-warning-hover:#b95525; --color-warning-highlight:#564942;
  --shadow-sm:0 1px 2px oklch(0 0 0/.2);
  --shadow-md:0 4px 12px oklch(0 0 0/.3);
  --shadow-lg:0 12px 32px oklch(0 0 0/.4);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --color-bg:#171614; --color-surface:#1c1b19; --color-surface-2:#201f1d;
    --color-surface-offset:#1d1c1a; --color-surface-dynamic:#2d2c2a;
    --color-divider:#262523; --color-border:#393836;
    --color-text:#cdccca; --color-text-muted:#797876; --color-text-faint:#5a5957;
    --color-text-inverse:#2b2a28;
    --color-primary:#4f98a3; --color-primary-hover:#227f8b; --color-primary-active:#1a626b;
    --color-primary-highlight:#313b3b;
    --color-success:#6daa45; --color-success-hover:#4d8f25; --color-success-highlight:#3a4435;
    --color-error:#d163a7; --color-error-hover:#b9478f; --color-error-highlight:#4c3d46;
    --color-warning:#bb653b; --color-warning-hover:#b95525; --color-warning-highlight:#564942;
    --shadow-sm:0 1px 2px oklch(0 0 0/.2);
    --shadow-md:0 4px 12px oklch(0 0 0/.3);
    --shadow-lg:0 12px 32px oklch(0 0 0/.4);
  }
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; scroll-behavior:smooth; scroll-padding-top:var(--space-16); }
body { min-height:100dvh; line-height:1.6; font-family:var(--font-body); font-size:var(--text-base); color:var(--color-text); background:var(--color-bg); }
img,svg { display:block; max-width:100%; height:auto; }
input,button,textarea,select { font:inherit; color:inherit; }
h1,h2,h3,h4 { text-wrap:balance; line-height:1.15; }
p,li { text-wrap:pretty; }
button { cursor:pointer; background:none; border:none; }
table { border-collapse:collapse; width:100%; }
a { color:var(--color-primary); text-decoration:none; }
a:hover { color:var(--color-primary-hover); }
:focus-visible { outline:2px solid var(--color-primary); outline-offset:3px; border-radius:var(--radius-sm); }
@media (prefers-reduced-motion:reduce) { *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; } }
a,button,[role="button"],input,textarea,select { transition:color var(--transition-interactive),background var(--transition-interactive),border-color var(--transition-interactive),box-shadow var(--transition-interactive); }

/* ── Auth pages ─────────────────────────────────────────────────────────────── */
.auth-page { display:flex; align-items:center; justify-content:center; min-height:100dvh; padding:var(--space-6) var(--space-4); background:var(--color-bg); }
.auth-wrapper { width:100%; max-width:420px; }
.auth-card { background:var(--color-surface); border:1px solid oklch(from var(--color-text) l c h/.1); border-radius:var(--radius-xl); padding:var(--space-8); box-shadow:var(--shadow-md); }

.auth-logo { display:flex; align-items:center; gap:var(--space-3); margin-bottom:var(--space-6); }
.auth-logo svg { color:var(--color-primary); flex-shrink:0; }
.auth-logo-text { font-family:var(--font-display); font-size:var(--text-lg); color:var(--color-text); }

.auth-title { font-family:var(--font-display); font-size:var(--text-xl); color:var(--color-text); margin-bottom:var(--space-2); }
.auth-subtitle { font-size:var(--text-sm); color:var(--color-text-muted); margin-bottom:var(--space-6); }

/* Google button */
.btn-google {
  display:flex; align-items:center; justify-content:center; gap:var(--space-3);
  width:100%; padding:var(--space-3) var(--space-4);
  background:var(--color-surface-2); color:var(--color-text);
  border:1px solid oklch(from var(--color-text) l c h/.15);
  border-radius:var(--radius-md); font-size:var(--text-sm); font-weight:500;
  text-decoration:none; margin-bottom:var(--space-4);
  transition:background var(--transition-interactive), box-shadow var(--transition-interactive);
}
.btn-google:hover { background:var(--color-surface-offset); box-shadow:var(--shadow-sm); color:var(--color-text); }
.btn-google svg { flex-shrink:0; }

.auth-divider { display:flex; align-items:center; gap:var(--space-3); margin-bottom:var(--space-4); }
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1px; background:var(--color-divider); }
.auth-divider span { font-size:var(--text-xs); color:var(--color-text-muted); white-space:nowrap; }

.auth-footer { font-size:var(--text-sm); color:var(--color-text-muted); text-align:center; margin-top:var(--space-6); }

/* ── Forms ───────────────────────────────────────────────────────────────────── */
.form-group { margin-bottom:var(--space-4); }
.form-group label { display:block; font-size:var(--text-sm); font-weight:500; color:var(--color-text); margin-bottom:var(--space-2); }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:var(--space-3) var(--space-4); font-size:var(--text-sm);
  background:var(--color-surface-2); color:var(--color-text);
  border:1px solid oklch(from var(--color-text) l c h/.15);
  border-radius:var(--radius-md);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--color-primary); outline:none; box-shadow:0 0 0 3px oklch(from var(--color-primary) l c h/.15); }
.form-hint { font-size:var(--text-xs); color:var(--color-text-muted); margin-top:var(--space-2); display:block; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); }
@media(max-width:600px) { .form-row { grid-template-columns:1fr; } }

.input-password-wrap { position:relative; }
.input-password-wrap input { padding-right:var(--space-10); }
.toggle-password { position:absolute; right:var(--space-3); top:50%; transform:translateY(-50%); color:var(--color-text-muted); padding:var(--space-2); }
.toggle-password:hover { color:var(--color-text); }

/* ── Buttons ─────────────────────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:var(--space-2); padding:var(--space-3) var(--space-5); font-size:var(--text-sm); font-weight:500; border-radius:var(--radius-md); cursor:pointer; border:none; text-decoration:none; }
.btn:active { transform:scale(.98); }
.btn-primary { background:var(--color-primary); color:var(--color-text-inverse); }
.btn-primary:hover { background:var(--color-primary-hover); color:var(--color-text-inverse); }
.btn-secondary { background:var(--color-surface-offset); color:var(--color-text); border:1px solid oklch(from var(--color-text) l c h/.12); }
.btn-secondary:hover { background:var(--color-surface-dynamic); }
.btn-danger { background:var(--color-error); color:#fff; }
.btn-danger:hover { background:var(--color-error-hover); color:#fff; }
.btn-warning { background:var(--color-warning); color:#fff; }
.btn-warning:hover { background:var(--color-warning-hover); color:#fff; }
.btn-success { background:var(--color-success); color:#fff; }
.btn-success:hover { background:var(--color-success-hover); color:#fff; }
.btn-sm { padding:var(--space-2) var(--space-3); font-size:var(--text-xs); }
.btn-full { width:100%; }
.btn-icon { padding:var(--space-2); }

/* ── Alerts ──────────────────────────────────────────────────────────────────── */
.alert { padding:var(--space-3) var(--space-4); border-radius:var(--radius-md); margin-bottom:var(--space-4); font-size:var(--text-sm); }
.alert-success { background:var(--color-success-highlight); color:var(--color-success); }
.alert-error   { background:var(--color-error-highlight);   color:var(--color-error); }
.alert-warning { background:var(--color-warning-highlight); color:var(--color-warning); }
.alert-info    { background:var(--color-primary-highlight); color:var(--color-primary); }

/* ── Layout ──────────────────────────────────────────────────────────────────── */
.app-shell { display:grid; grid-template-columns:240px 1fr; grid-template-rows:auto 1fr; min-height:100dvh; }
.topbar { grid-column:1/-1; display:flex; align-items:center; justify-content:space-between; padding:0 var(--space-6); height:56px; background:var(--color-surface); border-bottom:1px solid var(--color-divider); position:sticky; top:0; z-index:100; }
.topbar-brand { display:flex; align-items:center; gap:var(--space-3); font-family:var(--font-display); font-size:var(--text-lg); color:var(--color-text); }
.topbar-brand svg { color:var(--color-primary); }
.topbar-actions { display:flex; align-items:center; gap:var(--space-3); }
.topbar-user { display:flex; align-items:center; gap:var(--space-2); font-size:var(--text-sm); color:var(--color-text-muted); }
.topbar-avatar { width:32px; height:32px; border-radius:var(--radius-full); object-fit:cover; background:var(--color-primary-highlight); }
.topbar-avatar-placeholder { width:32px; height:32px; border-radius:var(--radius-full); background:var(--color-primary); display:flex; align-items:center; justify-content:center; color:#fff; font-size:var(--text-xs); font-weight:600; flex-shrink:0; }

.sidebar { background:var(--color-surface); border-right:1px solid var(--color-divider); padding:var(--space-6) 0; }
.sidebar-nav { list-style:none; }
.sidebar-nav li a { display:flex; align-items:center; gap:var(--space-3); padding:var(--space-3) var(--space-6); font-size:var(--text-sm); color:var(--color-text-muted); border-right:2px solid transparent; }
.sidebar-nav li a:hover { color:var(--color-text); background:var(--color-surface-offset); }
.sidebar-nav li a.active { color:var(--color-primary); background:var(--color-primary-highlight); border-right-color:var(--color-primary); font-weight:500; }
.sidebar-nav li a svg { width:18px; height:18px; flex-shrink:0; }
.sidebar-section { padding:var(--space-4) var(--space-6) var(--space-2); font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.06em; color:var(--color-text-faint); font-weight:500; }
.badge-nav { background:var(--color-error); color:#fff; border-radius:var(--radius-full); font-size:var(--text-xs); padding:1px 6px; margin-left:auto; }

.main-content { padding:var(--space-8) var(--space-8); overflow-y:auto; }
@media(max-width:768px) { .app-shell { grid-template-columns:1fr; } .sidebar { display:none; } .main-content { padding:var(--space-4); } }

.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--space-6); flex-wrap:wrap; gap:var(--space-4); }
.page-title { font-family:var(--font-display); font-size:var(--text-xl); color:var(--color-text); }

/* ── Stats cards ─────────────────────────────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:var(--space-4); margin-bottom:var(--space-8); }
.stat-card { background:var(--color-surface); border:1px solid oklch(from var(--color-text) l c h/.08); border-radius:var(--radius-lg); padding:var(--space-5); }
.stat-card .stat-value { font-size:var(--text-xl); font-weight:700; color:var(--color-text); font-variant-numeric:tabular-nums; }
.stat-card .stat-label { font-size:var(--text-xs); color:var(--color-text-muted); margin-top:var(--space-1); }

/* ── Table ───────────────────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; background:var(--color-surface); border:1px solid oklch(from var(--color-text) l c h/.08); border-radius:var(--radius-lg); }
table th { font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.05em; color:var(--color-text-muted); font-weight:500; padding:var(--space-3) var(--space-4); background:var(--color-surface-offset); text-align:left; border-bottom:1px solid var(--color-divider); }
table td { font-size:var(--text-sm); padding:var(--space-3) var(--space-4); border-bottom:1px solid var(--color-divider); vertical-align:middle; }
table tr:last-child td { border-bottom:none; }
table tr:hover td { background:var(--color-surface-offset); }

/* ── Badges ──────────────────────────────────────────────────────────────────── */
.badge { display:inline-flex; align-items:center; padding:2px var(--space-3); border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:500; }
.badge-male    { background:var(--color-primary-highlight); color:var(--color-primary); }
.badge-female  { background:var(--color-error-highlight); color:var(--color-error); }
.badge-pending  { background:var(--color-warning-highlight); color:var(--color-warning); }
.badge-approved { background:var(--color-success-highlight); color:var(--color-success); }
.badge-rejected { background:var(--color-error-highlight); color:var(--color-error); }
.badge-admin   { background:var(--color-primary-highlight); color:var(--color-primary); }
.badge-google  { display:inline-flex; align-items:center; gap:4px; background:#f1f3f4; color:#3c4043; padding:2px var(--space-3); border-radius:var(--radius-full); font-size:var(--text-xs); }
[data-theme="dark"] .badge-google { background:#3c4043; color:#e8eaed; }

/* ── Cards ───────────────────────────────────────────────────────────────────── */
.card { background:var(--color-surface); border:1px solid oklch(from var(--color-text) l c h/.08); border-radius:var(--radius-lg); padding:var(--space-6); box-shadow:var(--shadow-sm); margin-bottom:var(--space-6); }
.card-title { font-size:var(--text-lg); font-weight:600; margin-bottom:var(--space-4); }

/* ── Member profile ──────────────────────────────────────────────────────────── */
.member-avatar { width:72px; height:72px; border-radius:var(--radius-full); object-fit:cover; background:var(--color-surface-offset); }
.member-avatar-placeholder { width:72px; height:72px; border-radius:var(--radius-full); background:var(--color-primary-highlight); display:flex; align-items:center; justify-content:center; font-size:var(--text-xl); color:var(--color-primary); }
.member-header { display:flex; align-items:center; gap:var(--space-4); margin-bottom:var(--space-6); }
.detail-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:var(--space-4); }
.detail-item .detail-label { font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.05em; color:var(--color-text-muted); }
.detail-item .detail-value { font-size:var(--text-sm); color:var(--color-text); margin-top:2px; }

/* ── Tree ────────────────────────────────────────────────────────────────────── */
.tree-wrap { background:var(--color-surface); border:1px solid oklch(from var(--color-text) l c h/.08); border-radius:var(--radius-lg); overflow:hidden; }
.tree-wrap svg { display:block; }

/* ── Theme toggle ────────────────────────────────────────────────────────────── */
.theme-toggle { display:flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:var(--radius-md); color:var(--color-text-muted); }
.theme-toggle:hover { background:var(--color-surface-offset); color:var(--color-text); }

/* ── Search/filter bar ───────────────────────────────────────────────────────── */
.filter-bar { display:flex; gap:var(--space-3); flex-wrap:wrap; margin-bottom:var(--space-4); }
.filter-bar input, .filter-bar select { padding:var(--space-2) var(--space-4); font-size:var(--text-sm); background:var(--color-surface); border:1px solid oklch(from var(--color-text) l c h/.15); border-radius:var(--radius-md); color:var(--color-text); }
.filter-bar input:focus, .filter-bar select:focus { border-color:var(--color-primary); outline:none; }

/* ── Empty state ─────────────────────────────────────────────────────────────── */
.empty-state { display:flex; flex-direction:column; align-items:center; text-align:center; padding:var(--space-16) var(--space-8); color:var(--color-text-muted); }
.empty-state svg { width:48px; height:48px; margin-bottom:var(--space-4); color:var(--color-text-faint); }
.empty-state h3 { color:var(--color-text); margin-bottom:var(--space-2); }
.empty-state p { max-width:36ch; margin-bottom:var(--space-6); font-size:var(--text-sm); }

/* ── Action group ────────────────────────────────────────────────────────────── */
.actions { display:flex; gap:var(--space-2); flex-wrap:wrap; }

/* ── Responsive sidebar hamburger ───────────────────────────────────────────── */
.hamburger { display:none; align-items:center; justify-content:center; width:40px; height:40px; }
@media(max-width:768px) {
  .hamburger { display:flex; }
  .sidebar { display:block; position:fixed; left:-260px; top:56px; width:240px; height:calc(100vh - 56px); z-index:200; transition:left .25s ease; }
  .sidebar.open { left:0; box-shadow:var(--shadow-lg); }
}
