/* ════════════════════════════════════════
   FLOURISH 2.0 — The Sacred Growth Theme
   Color System: Earth + Gold + Burgundy + Sage
   Light Theme: Warm parchment (sepia) tones
   Dark Theme: Deep forest (moss) tones
   ════════════════════════════════════════ */

[data-theme="dark"] {
  --bg:            #0d1a11;
  --surface:        #152615;
  --surface-2:      #1e341e;
  --surface-3:      #264326;
  --border:          #2d4a2d;
  --border-light:    #3d5c3d;
  --text:            #e8dcc8;
  --text-muted:      #a8b89a;
  --text-dim:        #6e8462;
  --text-inverse:    #0d1a11;

  --accent:          #c9a84c;
  --accent-soft:      #a6883e;
  --accent-glow:      rgba(201,168,76,0.12);
  --accent-glow-strong: rgba(201,168,76,0.25);

  --spiritual:        #8b5a7c;
  --spiritual-soft:   rgba(139,90,124,0.12);
  --wealth:           #c9a84c;
  --wealth-soft:      rgba(201,168,76,0.12);
  --health:           #5a8f6e;
  --health-soft:      rgba(90,143,110,0.12);
  --relationships:    #7a6fae;
  --relationships-soft:rgba(122,111,174,0.12);

  --danger:           #b85c5c;
  --success:          #5a9e6f;
  --warning:           #c9a84c;
  --info:              #7a9eb8;

  --radial-deep:      radial-gradient(ellipse at 50% 0%, #1a2f1a, #0d1a11 60%);
  --sheen-accent:     linear-gradient(135deg, #c9a84c, #a6883e, #dfc07a, #c9a84c);
}

[data-theme="light"] {
  --bg:            #f5efe6;
  --surface:        #fffaf2;
  --surface-2:      #efe8d8;
  --surface-3:      #e8dece;
  --border:          #d6c9b0;
  --border-light:    #c9bc9f;
  --text:            #2d2420;
  --text-muted:      #5e5248;
  --text-dim:        #8a7d72;
  --text-inverse:    #f5efe6;

  --accent:          #8b6914;
  --accent-soft:      #6b520f;
  --accent-glow:      rgba(139,105,20,0.08);
  --accent-glow-strong:rgba(139,105,20,0.18);

  --spiritual:        #7a506e;
  --spiritual-soft:   rgba(122,80,110,0.08);
  --wealth:           #8b6914;
  --wealth-soft:      rgba(139,105,20,0.08);
  --health:           #4a7a5e;
  --health-soft:      rgba(74,122,94,0.08);
  --relationships:    #5e5294;
  --relationships-soft:rgba(94,82,148,0.08);

  --danger:           #a04545;
  --success:          #3d8f55;
  --warning:           #8b6914;
  --info:              #3d6f8f;

  --radial-deep:      radial-gradient(ellipse at 50% 0%, #fffaf2, #f5efe6 60%);
  --sheen-accent:     linear-gradient(135deg, #8b6914, #6b520f, #a68a30, #8b6914);
}

:root {
  --radius:     16px;
  --radius-sm:  12px;
  --radius-lg:  24px;
  --header:     56px;
  --nav:        68px;
  --transition:  cubic-bezier(0.22, 1, 0.36, 1);
}

html { scroll-behavior: smooth; }
*  { box-sizing: border-box; margin: 0; padding: 0; }

html,body {
  height:           100%;
  background:       var(--bg);
  color:            var(--text);
  font-family:      'Georgia','Times New Roman',serif;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
  overscroll-behavior-y: none;
}

#app {
  height:            100dvh;
  display:           flex;
  flex-direction:    column;
  overflow:          hidden;
  background:        var(--radial-deep);
}

/* ═══════ HEADER ═══════ */
header.app-header {
  height:            var(--header);
  display:           flex;
  align-items:       center;
  justify-content:   space-between;
  padding:           0 18px;
  flex-shrink:       0;
  position:          relative;
  z-index:           50;
}
header.app-header::after {
  content:'';
  position:absolute;
  inset:auto 0 0;
  height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--border-light) 50%,transparent 100%);
}

header .brand {
  display:flex;align-items:center;gap:8px;
  font-weight:800;font-size:19px;
  color:var(--accent);
  letter-spacing:0.4px;
}
header .brand .logo {
  font-size:24px;
  filter:drop-shadow(0 2px 4px var(--accent-glow-strong));
}

/* Theme toggle */
#theme-toggle {
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:999px;
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;cursor:pointer;
  transition:transform .2s,background .3s;
  touch-action:manipulation;
}
#theme-toggle:active { transform:scale(0.92); }

/* Gender toggle */
#gender-toggle {
  display:flex;align-items:center;gap:10px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:999px;
  padding:5px 14px;
  cursor:pointer;
  font-family:inherit;font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
  transition:all .3s var(--transition);
  touch-action:manipulation;
  -webkit-user-select:none;user-select:none;
}
#gender-toggle .g-label { color:var(--accent); transition:color .3s; }
#gender-toggle .g-label.dim { color:var(--text-dim); font-weight:400; }
#gender-toggle .g-track {
  width:36px;height:20px;
  background:var(--surface-3);
  border:1px solid var(--border);
  border-radius:999px;
  position:relative;
  flex-shrink:0;
}
#gender-toggle .g-track::after {
  content:'';
  position:absolute;
  top:2px;left:2px;
  width:14px;height:14px;
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  border-radius:50%;
  box-shadow:0 2px 6px var(--accent-glow-strong);
  transition:transform .35s var(--transition);
}
#gender-toggle.women .g-track::after { transform:translateX(16px); }
#gender-toggle.women .label-men { color:var(--text-dim);font-weight:400; }
#gender-toggle.women .label-women { color:var(--accent);font-weight:700; }

/* ═══════ MAIN ═══════ */
main#main {
  flex:1;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:16px;
  padding-bottom:calc(var(--nav) + env(safe-area-inset-bottom,0px) + 12px);
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent;
}
main#main::-webkit-scrollbar { width:4px; }
main#main::-webkit-scrollbar-thumb { background:var(--border);border-radius:2px; }

/* ═══════ CARDS ═══════ */
.card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  margin-bottom:14px;
  position:relative;
  overflow:hidden;
  transition:box-shadow .3s,transform .2s;
}
.card::before {
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1.5px;
  background:linear-gradient(135deg,rgba(201,168,76,0.06),transparent 60%,rgba(139,90,124,0.04));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none;
}
.card:hover { box-shadow:0 8px 32px var(--accent-glow); }
.card-header {
  font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:0.12em;
  color:var(--accent);
  margin-bottom:12px;
  padding-bottom:10px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.card-header .icon {
  font-size:16px;
  filter:drop-shadow(0 0 4px var(--accent-glow));
}

/* ═══════ BUTTONS ═══════ */
.btn {
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 20px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--surface-2);
  color:var(--text);
  font-size:14px;font-family:inherit;
  cursor:pointer;
  transition:transform .15s,filter .2s;
  touch-action:manipulation;
  -webkit-user-select:none;user-select:none;
}
.btn:active { transform:scale(0.97); }

.btn-primary {
  background:var(--sheen-accent);
  color:var(--text-inverse);
  border:none;
  font-weight:800;
  box-shadow:0 4px 16px var(--accent-glow-strong);
  position:relative;
  overflow:hidden;
}
.btn-primary::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
  transform:translateX(-100%);
  transition:transform .6s;
}
.btn-primary:hover::after { transform:translateX(100%); }
.btn-primary.done {
  background:var(--success);
  box-shadow:0 4px 16px rgba(90,158,111,0.25);
}

.btn-ghost {
  background:transparent;
  border-color:var(--border-light);
  color:var(--text-muted);
}
.btn-ghost:hover { background:var(--surface-2);color:var(--text); }

.btn-danger {
  background:rgba(184,92,92,0.08);
  color:var(--danger);
  border-color:rgba(184,92,92,0.25);
}

.btn-nav-round {
  width:40px;height:40px;
  border-radius:50%;
  background:var(--surface-2);
  border:1px solid var(--border);
  color:var(--text-dim);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;cursor:pointer;
  transition:all .2s;
  touch-action:manipulation;
}
.btn-nav-round:hover { color:var(--accent);border-color:var(-- accent); }
.btn-nav-round:active { transform:scale(0.92); }
.btn-nav-round:disabled { opacity:0.3;pointer-events:none; }

/* ═══════ BOTTOM NAV ═══════ */
.bottom-nav {
  display:flex;
  justify-content:space-around;
  align-items:center;
  background:linear-gradient(0deg,var(--surface),var(--bg));
  border-top:1px solid var(--border);
  height:var(--nav);
  padding:6px 0 calc(6px + env(safe-area-inset-bottom,0px));
  flex-shrink:0;
  z-index:100;
}
.bottom-nav .nav-btn {
  flex:1;height:100%;
  background:none;border:none;
  color:var(--text-dim);
  font-size:13px;
  cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;
  position:relative;
  touch-action:manipulation;
  -webkit-user-select:none;user-select:none;
  transition:color .2s,transform .1s;
}
.bottom-nav .nav-btn .nav-icon { font-size:22px;transition:transform .2s; }
.bottom-nav .nav-btn .nav-label { font-size:10px;font-weight:600;letter-spacing:0.03em; }
.bottom-nav .nav-btn::before {
  content:'';
  position:absolute;
  top:0;left:50%;
  transform:translateX(-50%);
  width:0;height:3px;
  background:var(--accent);
  border-radius:0 0 3px 3px;
  transition:width .25s var(--transition);
}
.bottom-nav .nav-btn:active { transform:scale(0.92); }
.bottom-nav .nav-btn:active .nav-icon { transform:translateY(-2px); }
.bottom-nav .nav-btn.active { color:var(--accent); }
.bottom-nav .nav-btn.active::before { width:24px; }
.bottom-nav .nav-btn.active .nav-icon {
  filter:drop-shadow(0 0 4px var(--accent-glow-strong));
}

/* ═══════ PAGE: DEVOTIONAL ═══════ */
.devotional-page { padding:0 0 24px; }

.day-header {
  display:flex;align-items:center;gap:14px;
  padding:16px 4px;
  margin-bottom:6px;
}
.day-header .day-nav-wrap {
  display:flex;gap:8px;
  flex-shrink:0;
}
.day-header .day-info { flex:1;min-width:0; }
.day-header .day-eyebrow {
  font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:0.15em;
  color:var(--text-dim);margin-bottom:4px;
}
.day-header .day-number {
  font-size:32px;font-weight:800;
  line-height:1;
  background:var(--sheen-accent);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.day-header .day-topic {
  font-size:16px;font-weight:600;
  color:var(--text);margin-top:6px;
  line-height:1.3;
}
.day-header .day-meta {
  font-size:11px;color:var(--text-dim);margin-top:4px;
}

/* Scripture block — the jewel */
.scripture-block {
  position:relative;
  background:linear-gradient(135deg,var(--surface-2),var(--surface));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:24px 20px;
  margin-bottom:14px;
  overflow:hidden;
}
.scripture-block::before {
  content:'';
  position:absolute;left:0;top:20%;bottom:20%;width:3px;
  background:var(--sheen-accent);
  border-radius:0 2px 2px 0;
}
.scripture-block .scripture-ref {
  font-size:12px;font-weight:800;
  text-transform:uppercase;letter-spacing:0.1em;
  color:var(--accent);margin-bottom:10px;
  display:flex;align-items:center;gap:8px;
}
.scripture-block .scripture-ref .version {
  font-size:10px;font-weight:400;
  color:var(--text-dim);
  text-transform:none;letter-spacing:0;
  background:var(--surface-2);
  padding:2px 6px;border-radius:4px;
}
.scripture-block .scripture-text {
  font-size:17px;line-height:1.7;
  color:var(--text);
  font-style:italic;
  text-indent:0;
}
.scripture-block .scripture-text::first-letter {
  font-size:2.2em;font-weight:700;
  float:left;line-height:.9;
  margin-right:6px;margin-top:2px;
  background:var(--sheen-accent);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* Track card (men/women specific) */
.track-card {
  border-left:3px solid;
}
.track-card.men   { border-left-color:var(--accent); }
.track-card.women { border-left-color:var(--spiritual); }
.track-card .track-label {
  font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:0.1em;
  margin-bottom:8px;
}
.track-card.men   .track-label { color:var(--accent); }
.track-card.women .track-label { color:var(--spiritual); }
.track-text {
  font-size:15px;line-height:1.75;
  color:var(--text);
}

/* Cross-pillar gold thread */
.cross-pillar-card {
  background:linear-gradient(135deg,var(--wealth-soft),transparent);
  border-color:var(--accent-soft);
}

/* Enrichment with depth */
.context-card { border-left:3px solid var(--accent-soft); }
.word-card     { border-left:3px solid var(--spiritual); }
.christ-card   { border-left:3px solid var(--success); }
.reflect-card  { border-left:3px solid var(--info); }

.reflect-q {
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:14px;
  font-size:14px;line-height:1.65;
  color:var(--text-muted);
  position:relative;
  padding-left:30px;
}
.reflect-q::before {
  content:attr(data-n);
  position:absolute;left:10px;top:14px;
  font-weight:800;color:var(--accent);font-size:13px;
}

/* Actions bar */
.devotional-actions {
  display:flex;gap:10px;
  padding:0 4px;margin-top:16px;
}

/* ═══════ PAGE: PROGRESS — THE SACRED GARDEN ═══════ */
.progress-page { padding:0 0 24px; }

/* Hero with plant */
.progress-hero {
  display:flex;flex-direction:column;align-items:center;
  padding:32px 16px 24px;
  text-align:center;
}
.progress-hero .plant-stage {
  width:160px;height:140px;
  margin-bottom:16px;
  filter:drop-shadow(0 8px 24px var(--accent-glow));
}
.progress-stat {
  font-size:56px;font-weight:800;
  line-height:1;
  background:var(--sheen-accent);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.progress-stat span { font-size:18px;opacity:.6; }
.progress-label {
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.15em;
  color:var(--text-dim);margin-top:8px;
}

/* The living progress bar */
.living-bar {
  height:10px;
  background:var(--surface-2);
  border-radius:5px;
  margin:14px 16px 8px;
  overflow:hidden;
  position:relative;
}
.living-bar .fill {
  height:100%;border-radius:5px;
  background:var(--sheen-accent);
  box-shadow:0 0 12px var(--accent-glow-strong);
  transition:width 1.2s var(--transition);
  position:relative;
}
.living-bar .fill::after {
  content:'';
  position:absolute;right:-2px;top:-3px;
  width:16px;height:16px;
  background:var(--accent);
  border-radius:50%;
  box-shadow:0 0 12px var(--accent-glow-strong);
  filter:blur(2px);
}
.living-bar .fill::before {
  content:'';
  position:absolute;right:0;top:-1px;width:8px;height:8px;
  background:#fff;border-radius:50%;
  filter:blur(1px);
}
.pct-label {
  font-size:12px;font-weight:700;
  color:var(--accent);text-align:center;
  letter-spacing:0.05em;
}

/* Stage description */
.growth-status {
  text-align:center;padding:0 16px;margin-top:8px;
  font-size:14px;color:var(--text-muted);line-height:1.5;
}
.growth-status .stage-name {
  color:var(--accent);font-weight:700;font-size:15px;
}

/* Stats diamonds */
.stats-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  padding:0 8px;
  margin-bottom:18px;
}
.stat-diamond {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 12px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.stat-diamond::before {
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--accent-glow),transparent 60%);
  opacity:.5;
}
.stat-diamond .stat-num {
  font-size:28px;font-weight:800;
  color:var(--accent);
  position:relative;
}
.stat-diamond .stat-label {
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.1em;
  color:var(--text-dim);margin-top:6px;
  position:relative;
}

/* Pillar garden */
.pillar-garden {
  display:flex;flex-direction:column;gap:12px;
}
.pillar-row {
  display:flex;align-items:center;gap:12px;
}
.pillar-row .pillar-icon {
  width:32px;height:32px;
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:14px;
}
.pillar-row.health   .pillar-icon { background:var(--health-soft);color:var(--health); }
.pillar-row.wealth  .pillar-icon { background:var(--wealth-soft);color:var(--wealth); }
.pillar-row.relationships .pillar-icon { background:var(--relationships-soft);color:var(--relationships); }
.pillar-row.spiritual .pillar-icon { background:var(--spiritual-soft);color:var(--spiritual); }

.pillar-row .pillar-info { flex:1;min-width:0; }
.pillar-row .pillar-name {
  font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.08em;
}
.pillar-row.health   .pillar-name { color:var(--health); }
.pillar-row.wealth  .pillar-name { color:var(--wealth); }
.pillar-row.relationships .pillar-name { color:var(--relationships); }
.pillar-row.spiritual .pillar-name { color:var(--spiritual); }

.pillar-track {
  flex:1;height:8px;
  background:var(--surface-2);
  border-radius:4px;overflow:hidden;
}
.pillar-fill {
  height:100%;border-radius:4px;
  transition:width .8s var(--transition);
}
.pillar-row.health   .pillar-fill { background:var(--health); }
.pillar-row.wealth  .pillar-fill { background:var(--wealth); }
.pillar-row.relationships .pillar-fill { background:var(--relationships); }
.pillar-row.spiritual .pillar-fill { background:var(--spiritual); }

.pillar-count {
  font-size:13px;font-weight:700;
  color:var(--text-dim);width:28px;text-align:right;
}

/* Week garden */
.week-garden {
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:6px;
  margin-top:12px;
}
.week-cell {
  aspect-ratio:1;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  cursor:pointer;
  touch-action:manipulation;
  transition:all .2s;
  position:relative;
  overflow:hidden;
}
.week-cell .w-label { font-size:9px;color:var(--text-dim);text-transform:uppercase; }
.week-cell .w-num  { font-size:14px;font-weight:700;color:var(--text);margin-top:2px; }
.week-cell:hover { transform:translateY(-2px); }
.week-cell.done {
  background:var(--health-soft);
  border-color:var(--health);
}
.week-cell.done .w-num { color:var(--health); }
.week-cell.done::after {
  content:'';position:absolute;bottom:3px;left:50%;
  transform:translateX(-50%);
  width:4px;height:4px;background:var(--health);border-radius:50%;
}
.week-cell.today {
  border-color:var(--accent);
  box-shadow:0 0 0 2px var(--accent-glow-strong),inset 0 0 8px var(--accent-glow);
}
.week-cell.today .w-num { color:var(--accent); }

/* ═══════ PAGE: CHURCHES / EVENTS / STORE ═══════ */
.search-box {
  width:100%;padding:12px 14px;margin-bottom:12px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--text);font-size:14px;font-family:inherit;
  outline:none;transition:border-color .2s,box-shadow .2s;
}
.search-box:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-glow);
}

.event-item {
  display:flex;gap:14px;
  padding:14px 0;
  border-bottom:1px solid var(--border);
}
.event-item:last-child { border-bottom:none; }
.event-date-block {
  width:48px;text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.event-date-block .d-month {
  font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);
}
.event-date-block .d-day {
  font-size:20px;font-weight:800;color:var(--accent);line-height:1;
}

.event-body .event-title { font-size:15px;font-weight:600;color:var(--text); }
.event-body .event-meta  { font-size:12px;color:var(--text-dim);margin-top:4px; }
.event-tag {
  display:inline-block;
  padding:3px 8px;border-radius:999px;
  font-size:10px;font-weight:700;letter-spacing:0.05em;
  text-transform:uppercase;margin-top:6px;
}
.event-tag.public  { background:var(--health-soft);color:var(--health); }
.event-tag.private { background:var(--spiritual-soft);color:var(--spiritual); }

.store-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:14px; }
.store-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .3s;
}
.store-card:hover { transform:translateY(-3px);box-shadow:0 12px 32px var(--accent-glow); }
.store-card .thumb {
  height:120px;background:linear-gradient(135deg,var(--surface-2),var(--surface-3));
  display:flex;align-items:center;justify-content:center;font-size:48px;
  position:relative;
}
.store-card .thumb::after {
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,0.2));
}
.store-card .info { padding:14px;flex:1;display:flex;flex-direction:column; }
.store-card .store-title { font-size:15px;font-weight:600;color:var(--text); }
.store-card .store-desc { font-size:13px;color:var(--text-muted);margin-top:4px;flex:1; }
.store-card .store-footer {
  display:flex;align-items:center;justify-content:space-between;
  margin-top:12px;
}
.store-card .store-price {
  font-size:18px;font-weight:800;
  background:var(--sheen-accent);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ═══════ PAGE: PROFILE ═══════ */
.profile-hero {
  text-align:center;padding:32px 16px 20px;
}
.profile-hero .avatar-ring {
  width:80px;height:80px;margin:0 auto;
  border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--spiritual));
  padding:3px;
}
.profile-hero .avatar-ring .avatar-inner {
  width:100%;height:100%;
  background:var(--surface);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:36px;
}
.profile-hero .profile-name {
  font-size:22px;font-weight:700;color:var(--text);margin-top:14px;
}
.profile-hero .profile-meta {
  font-size:12px;color:var(--text-dim);margin-top:4px;
  letter-spacing:0.05em;
}

.setting-row {
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.setting-row:last-child { border-bottom:none; }
.setting-row .s-label { font-size:15px;color:var(--text); }
.setting-row .s-val   { font-size:14px;color:var(--accent);font-weight:600; }

.toggle-switch {
  width:48px;height:26px;
  background:var(--surface-2);border:1px solid var(--border);
  border-radius:999px;position:relative;cursor:pointer;
  transition:background .3s;
  flex-shrink:0;
}
.toggle-switch .knob {
  position:absolute;top:2.5px;left:3px;
  width:19px;height:19px;
  background:var(--text-dim);border-radius:50%;
  transition:transform .35s var(--transition),background .3s;
}
.toggle-switch.on { background:var(--accent-soft);border-color:var(--accent); }
.toggle-switch.on .knob { transform:translateX(22px);background:#fff;box-shadow:0 2px 6px rgba(0,0,0,0.2); }

.tithe-row {
  display:flex;justify-content:space-between;
  padding:12px 0;border-bottom:1px solid var(--border);
  color:var(--text);font-size:14px;
}
.tithe-row:last-child { border-bottom:none; }
.tithe-row .amount { font-weight:700;color:var(--wealth); }

.prayer-list .prayer-item {
  padding:12px 0;border-bottom:1px solid var(--border);
  color:var(--text-muted);font-size:14px;
  display:flex;align-items:center;gap:8px;
}
.prayer-list .prayer-item:last-child { border-bottom:none; }
.prayer-list .prayer-item.status-urgent  { color:var(--danger); }
.prayer-list .prayer-item.status-active  { color:var(--warning); }
.prayer-list .prayer-item.status-answered { color:var(--success); }

/* ═══════ LOADING / ERROR ═══════ */
.sacred-loader {
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  min-height:50vh;gap:20px;padding:24px;text-align:center;
}
.seed-glyph {
  font-size:48px;
  animation:seedBreathe 2.4s ease-in-out infinite;
  filter:drop-shadow(0 4px 12px var(--accent-glow));
}
@keyframes seedBreathe {
  0%,100% { transform:scale(1);opacity:.7; }
  50% { transform:scale(1.15);opacity:1; }
}
.loader-text {
  font-size:16px;font-weight:700;color:var(--accent);
  letter-spacing:0.05em;
}
.loader-sub {
  font-size:13px;color:var(--text-dim);max-width:220px;line-height:1.5;
}

.error-state {
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  min-height:50vh;gap:16px;padding:24px;text-align:center;
}
.error-state .error-icon { font-size:48px; }
.error-state .error-msg {
  font-size:15px;color:var(--danger);line-height:1.5;max-width:280px;
}

/* ═══════ TOAST ═══════ */
.toast {
  position:fixed;top:calc(var(--header) + 12px);left:50%;
  transform:translateX(-50%) translateY(-20px);
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:12px 20px;
  font-size:14px;font-weight:600;color:var(--text);
  box-shadow:0 12px 48px rgba(0,0,0,0.3);
  opacity:0;pointer-events:none;
  transition:opacity .3s,transform .35s var(--transition);
  z-index:999;
}
.toast.show { opacity:1;transform:translateX(-50%) translateY(0); }

/* ═══════ PILLAR CHIPS ═══════ */
.pillar-chip {
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:999px;
  font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:0.06em;
}
.pillar-chip::before {
  content:'';width:6px;height:6px;border-radius:50%;
}
.pillar-chip.health   { background:var(--health-soft);color:var(--health); }
.pillar-chip.health::before   { background:var(--health); }
.pillar-chip.wealth  { background:var(--wealth-soft);color:var(--wealth); }
.pillar-chip.wealth::before  { background:var(--wealth); }
.pillar-chip.relationships { background:var(--relationships-soft);color:var(--relationships); }
.pillar-chip.relationships::before { background:var(--relationships); }
.pillar-chip.spiritual { background:var(--spiritual-soft);color:var(--spiritual); }
.pillar-chip.spiritual::before { background:var(--spiritual); }

/* ═══════ ANIMATIONS ═══════ */
@keyframes pulseGlow {
  0%,100% { box-shadow:0 0 0 0 var(--accent-glow); }
  50% { box-shadow:0 0 12px 4px var(--accent-glow-strong); }
}
.glow-pulse { animation:pulseGlow 2.5s infinite; }

@keyframes slideUp {
  from { opacity:0;transform:translateY(16px); }
  to   { opacity:1;transform:translateY(0); }
}
.card-enter { animation:slideUp .5s var(--transition) both; }

@keyframes float {
  0%,100% { transform:translateY(0); }
  50% { transform:translateY(-6px); }
}
.float { animation:float 4s ease-in-out infinite; }

/* ═══════ MISC ═══════ */
.page-title {
  font-size:26px;font-weight:800;
  margin-bottom:16px;
  background:var(--sheen-accent);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.empty-state {
  text-align:center;padding:48px 24px;
  color:var(--text-dim);
}
.empty-state .e-icon { font-size:52px;opacity:.5;margin-bottom:12px; }
.scroll-x {
  display:flex;gap:10px;overflow-x:auto;
  padding-bottom:4px;scrollbar-width:none;
}
.scroll-x::-webkit-scrollbar { display:none; }
.hidden { display:none!important; }

/* ═══════ DESKTOP ═══════ */
@media (min-width:768px) {
  #app { flex-direction:row; }
  header.app-header { display:none; }
  .bottom-nav {
    position:static;flex-direction:column;
    justify-content:flex-start;gap:2px;
    width:240px;height:100vh;
    border-top:none;border-right:1px solid var(--border);
    padding:20px 10px;
  }
  .bottom-nav .nav-btn {
    flex-direction:row;gap:12px;
    padding:12px 16px;border-radius:var(--radius-sm);
    justify-content:flex-start;width:100%;height:auto;
    font-size:14px;
  }
  .bottom-nav .nav-btn .nav-icon { font-size:20px; }
  .bottom-nav .nav-btn .nav-label { font-size:13px; }
  .bottom-nav .nav-btn.active { background:var(--surface-2); }
  .bottom-nav .nav-btn.active::before { display:none; }
  main#main {
    padding:24px;padding-bottom:24px;
    max-width:900px;margin:0 auto;
  }
  .store-grid { grid-template-columns:repeat(3,1fr); }
}

/* ═══════ EXPANDABLE ENRICHMENT ═══════ */
.expandable {
  margin-bottom:14px;
}
.expand-toggle {
  width:100%;display:flex;align-items:center;justify-content:space-between;
  background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:14px 16px;
  color:var(--text);font-family:inherit;font-size:14px;font-weight:600;
  cursor:pointer;transition:background .2s;
  touch-action:manipulation;
}
.expand-toggle:hover { background:var(--surface-3); }
.expand-toggle .toggle-icon { transition:transform .3s; }
.expand-toggle.open .toggle-icon { transform:rotate(180deg); }
.expand-body {
  background:var(--surface);
  border:1px solid var(--border);border-top:none;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  padding:0 16px;max-height:0;overflow:hidden;
  transition:max-height .4s var(--transition),padding .4s;
}
.expand-body.open {
  padding:14px 16px;
  max-height:800px;
}
.expand-body p { font-size:14px;line-height:1.7;color:var(--text-muted);margin-bottom:10px; }
.expand-body p:last-child { margin-bottom:0; }
.expand-body .word-greek { font-style:italic;color:var(--accent);font-weight:600; }

/* ═══════ PAGE: PILLARS ═══════ */
.pillars-page { padding:0 0 24px; }

.pillars-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-bottom:16px;
}
@media(min-width:768px){
  .pillars-grid { grid-template-columns:repeat(2,1fr); }
}

.pillar-tile {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  cursor:pointer;
  transition:transform .2s,box-shadow .3s;
  position:relative;
  overflow:hidden;
}
.pillar-tile:hover { transform:translateY(-2px);box-shadow:0 8px 32px var(--accent-glow); }
.pillar-tile::before {
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--accent);opacity:0;transition:opacity .3s;
}
.pillar-tile:hover::before { opacity:1; }
.pillar-tile.health::before { background:var(--health); }
.pillar-tile.wealth::before { background:var(--wealth); }
.pillar-tile.relationships::before { background:var(--relationships); }
.pillar-tile.integration::before { background:var(--spiritual); }

.pillar-tile-icon {
  width:48px;height:48px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin-bottom:12px;
}
.pillar-tile-name {
  font-size:18px;font-weight:700;color:var(--text);
  margin-bottom:4px;
}
.pillar-tile-count {
  font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.1em;
  color:var(--text-dim);margin-bottom:10px;
}
.pillar-tile-desc {
  font-size:13px;line-height:1.6;color:var(--text-muted);
}
.pillar-tile-cta {
  font-size:12px;font-weight:700;
  color:var(--accent);margin-top:12px;
  text-transform:uppercase;letter-spacing:0.08em;
}

/* Pillar hero inside detail */
.pillar-hero {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:24px;
  margin-bottom:16px;
  text-align:center;
}
.pillar-hero-icon {
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;margin:0 auto 12px;
}
.pillar-hero-title {
  font-size:22px;font-weight:800;color:var(--text);
  margin-bottom:6px;
}
.pillar-hero-subtitle {
  font-size:13px;color:var(--text-muted);margin-bottom:10px;
}
.pillar-hero-stats {
  font-size:12px;font-weight:600;color:var(--text-dim);
  letter-spacing:0.05em;
}

/* Week cards in pillar detail */
.week-list { display:flex;flex-direction:column;gap:10px; }
.week-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:16px;
  cursor:pointer;
  transition:transform .2s,box-shadow .3s,border-color .2s;
}
.week-card:hover { transform:translateX(4px);box-shadow:0 4px 20px var(--accent-glow);border-color:var(--border-light); }
.week-card.health:hover { border-color:var(--health); }
.week-card.wealth:hover { border-color:var(--wealth); }
.week-card.relationships:hover { border-color:var(--relationships); }
.week-card.integration:hover { border-color:var(--spiritual); }

.week-card-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;
}
.week-num {
  font-size:14px;font-weight:700;color:var(--text);
}
.week-progress {
  display:flex;align-items:center;gap:8px;
}
.week-bar {
  width:60px;height:6px;
  background:var(--surface-2);
  border-radius:3px;overflow:hidden;
}
.week-fill {
  height:100%;border-radius:3px;
  transition:width .5s var(--transition);
}
.week-fill.health { background:var(--health); }
.week-fill.wealth { background:var(--wealth); }
.week-fill.relationships { background:var(--relationships); }
.week-fill.integration { background:var(--spiritual); }
.week-pct {
  font-size:11px;font-weight:700;color:var(--accent);
  min-width:32px;text-align:right;
}
.week-theme {
  font-size:13px;font-weight:500;
  color:var(--text-muted);line-height:1.5;
  margin-bottom:10px;
}
.week-days-preview {
  display:flex;flex-wrap:wrap;gap:6px;
}
.day-dot {
  width:28px;height:28px;border-radius:50%;
  background:var(--surface-2);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;color:var(--text-dim);
  transition:all .2s;
}
.day-dot.done {
  background:var(--success);border-color:var(--success);
  color:#fff;
}
.day-dot.today {
  box-shadow:0 0 0 2px var(--accent);
  color:var(--accent);
}
.day-dot.more {
  background:var(--surface-3);border-style:dashed;
  font-size:9px;
}

/* Week detail header */
.week-detail-header {
  display:flex;align-items:center;gap:14px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px;
  margin-bottom:14px;
}
.week-detail-info { flex:1;min-width:0; }
.week-detail-eyebrow {
  font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:0.15em;
  color:var(--text-dim);margin-bottom:4px;
}
.week-detail-theme {
  font-size:16px;font-weight:700;color:var(--text);line-height:1.4;
}
.week-detail-progress {
  font-size:12px;color:var(--accent);margin-top:6px;font-weight:600;
}

/* Day rows in week detail */
.day-list { display:flex;flex-direction:column;gap:8px; }
.day-row {
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:14px;
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;transition:all .2s;
}
.day-row:hover { border-color:var(--border-light);transform:translateX(4px); }
.day-row.done { border-color:rgba(90,158,111,0.3); }
.day-row.today { box-shadow:0 0 0 2px var(--accent); }
.day-row-left { display:flex;align-items:center;gap:12px;flex:1;min-width:0; }
.day-row-num {
  width:36px;height:36px;border-radius:50%;
  background:var(--surface-2);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:var(--text-dim);
  flex-shrink:0;
}
.day-row-num.health { color:var(--health);border-color:var(--health); }
.day-row-num.wealth { color:var(--wealth);border-color:var(--wealth); }
.day-row-num.relationships { color:var(--relationships);border-color:var(--relationships); }
.day-row-num.integration { color:var(--spiritual);border-color:var(--spiritual); }
.day-row-info { flex:1;min-width:0; }
.day-row-topic { font-size:15px;font-weight:600;color:var(--text); }
.day-row-scripture { font-size:12px;color:var(--accent);margin-top:2px; }
.day-row-excerpt { font-size:12px;color:var(--text-dim);margin-top:3px;line-height:1.5; }
.day-row-right { flex-shrink:0; }
.day-row-status { font-size:18px;color:var(--text-dim); }
.day-row-status.done { color:var(--success); }

/* Page subtitle */
.page-subtitle {
  font-size:13px;color:var(--text-muted);
  margin-bottom:16px;text-align:center;
}

/* ════════════════════════════════════════
   CHURCH & QR FEATURES v9
   ════════════════════════════════════════ */

/* My Church rows */
.church-my-row {
  display:flex;align-items:center;gap:12px;
  background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:12px 14px;
  cursor:pointer;transition:all .2s;
}
.church-my-row:hover { border-color:var(--accent);transform:translateX(4px); }
.church-my-icon {
  width:40px;height:40px;border-radius:50%;
  background:var(--accent-glow);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}
.church-my-info { flex:1;min-width:0; }
.church-my-name { font-size:15px;font-weight:600;color:var(--text); }
.church-my-meta { font-size:12px;color:var(--text-dim);margin-top:2px; }
.church-my-arrow { font-size:18px;color:var(--accent);flex-shrink:0; }

/* Church cards */
.church-card { transition:all .2s; }
.church-card.joined { border-color:rgba(201,168,76,0.3); }
.church-avatar {
  width:48px;height:48px;border-radius:50%;
  background:var(--accent-glow);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;flex-shrink:0;
}

/* Church hero */
.church-hero {
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:24px 16px;
  text-align:center;margin-bottom:14px;
  position:relative;
}
.church-hero .btn-nav-round {
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
}
.church-hero-icon { font-size:56px;margin-bottom:8px; }
.church-hero-name {
  font-size:22px;font-weight:700;color:var(--text);
  font-family:'Playfair Display',Georgia,serif;
}
.church-hero-meta {
  font-size:13px;color:var(--text-muted);margin-top:4px;
}
.church-hero-pastor {
  font-size:13px;color:var(--accent);margin-top:6px;font-weight:600;
}

/* QR Scanner / Manual entry */
#qr-video-wrap video {
  width:100%;height:100%;object-fit:cover;
}

/* Join popup overlay */
.join-overlay {
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,0.7);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:fadeIn .2s;
}
.join-popup {
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:32px 24px;
  max-width:360px;width:100%;text-align:center;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}
.join-popup-icon { font-size:48px;margin-bottom:12px; }
.join-popup-title {
  font-size:20px;font-weight:700;color:var(--text);
  margin-bottom:4px;
}
.join-popup-meta {
  font-size:13px;color:var(--text-muted);margin-bottom:12px;
}
.join-popup-desc {
  font-size:14px;color:var(--text-dim);line-height:1.6;
  margin-bottom:20px;
}
.join-popup-actions {
  display:flex;gap:12px;justify-content:center;
}
.join-popup-actions .btn { flex:1; }

/* QR result display */
#gen-qr-result svg {
  max-width:100%;height:auto;
}

/* Print styles for QR codes */
@media print {
  body * { visibility:hidden; }
  #gen-qr-result, #gen-qr-result * { visibility:visible; }
  #gen-qr-result { position:absolute;left:50%;top:50%;transform:translate(-50%,-50%); }
}

/* ════════════════════════════════════════════
   V10 ADDITIONS — auth, church, chat, dashboard,
   plans, year tabs, milestones
   ════════════════════════════════════════════ */
#auth-chip{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#auth-chip.signed{border-color:var(--accent);color:var(--accent)}

.year-tabs{display:flex;gap:8px;margin-bottom:14px}
.year-tab{flex:1;padding:10px 0;text-align:center;border-radius:12px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);font-weight:700;font-size:13px;cursor:pointer;transition:all .2s}
.year-tab.active{background:var(--accent);color:#10200f;border-color:var(--accent)}
.year-tab .yt-sub{display:block;font-size:10px;font-weight:500;opacity:.75;margin-top:2px}

.promise-hero{background:linear-gradient(160deg,var(--surface),var(--surface-2));border:1px solid var(--accent);border-radius:16px;padding:20px;margin-bottom:16px}
.promise-hero .ph-eyebrow{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:8px}
.promise-hero .ph-verse{font-style:italic;line-height:1.6;font-size:15px;margin-bottom:10px}
.promise-hero .ph-ref{font-size:12px;color:var(--accent);font-weight:600;margin-bottom:12px}
.promise-hero .ph-body{font-size:13.5px;line-height:1.7;color:var(--text-muted)}

.milestone-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:300;padding:24px}
.milestone-card{background:var(--surface);border:1px solid var(--accent);border-radius:20px;padding:28px 22px;max-width:380px;text-align:center}
.milestone-card .m-icon{font-size:52px;margin-bottom:10px}
.milestone-card .m-title{font-size:20px;font-weight:800;color:var(--accent);margin-bottom:8px}
.milestone-card .m-verse{font-style:italic;font-size:14px;line-height:1.6;color:var(--text-muted);margin-bottom:6px}
.milestone-card .m-ref{font-size:12px;color:var(--accent);margin-bottom:12px}
.milestone-card .m-body{font-size:14px;line-height:1.65;margin-bottom:18px}

.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:flex-end;justify-content:center;z-index:280}
.auth-sheet{background:var(--surface);border-radius:20px 20px 0 0;padding:24px 20px 36px;width:100%;max-width:520px;border-top:1px solid var(--accent)}
.auth-sheet h3{margin:0 0 4px;font-size:19px}
.auth-sheet .as-sub{font-size:13px;color:var(--text-muted);margin-bottom:16px;line-height:1.5}
.auth-input{width:100%;padding:13px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:15px;margin-bottom:10px;box-sizing:border-box}
.auth-toggle-row{display:flex;justify-content:space-between;align-items:center;margin:6px 0 14px;font-size:13px;color:var(--text-muted)}
.auth-link{color:var(--accent);cursor:pointer;font-weight:600}

.chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.f-chip{padding:7px 13px;border-radius:18px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:12.5px;font-weight:600;cursor:pointer}
.f-chip.active{background:var(--accent);color:#10200f;border-color:var(--accent)}

.req-card{border-left:3px solid var(--accent);margin-bottom:10px}
.req-card.urgent{border-left-color:#c0504d}
.req-card.answered{border-left-color:#5a8f6e;opacity:.85}
.req-meta{font-size:11.5px;color:var(--text-dim);margin-top:4px}
.req-badge{display:inline-block;padding:2px 9px;border-radius:10px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-right:6px}
.req-badge.active{background:rgba(201,168,76,.18);color:var(--accent)}
.req-badge.urgent{background:rgba(192,80,77,.2);color:#e07370}
.req-badge.answered{background:rgba(90,143,110,.2);color:#7dba94}
.req-badge.archived{background:var(--surface-2);color:var(--text-dim)}

.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 210px);min-height:320px}
.chat-scroll{flex:1;overflow-y:auto;padding:6px 2px;display:flex;flex-direction:column;gap:8px}
.chat-bubble{max-width:82%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5}
.chat-bubble.mine{align-self:flex-end;background:var(--accent);color:#10200f;border-bottom-right-radius:4px}
.chat-bubble.theirs{align-self:flex-start;background:var(--surface-2);color:var(--text);border-bottom-left-radius:4px}
.chat-bubble .cb-sender{font-size:10.5px;font-weight:700;opacity:.7;margin-bottom:3px}
.chat-bubble .cb-time{font-size:10px;opacity:.55;margin-top:3px;text-align:right}
.chat-input-row{display:flex;gap:8px;padding:10px 0 4px}
.chat-input-row input{flex:1;padding:12px 14px;border-radius:22px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:14px}

.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.dash-stat{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;text-align:center}
.dash-stat .ds-num{font-size:26px;font-weight:800;color:var(--accent)}
.dash-stat .ds-label{font-size:11px;color:var(--text-muted);margin-top:3px;text-transform:uppercase;letter-spacing:.6px}
.member-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:13.5px}
.member-row:last-child{border-bottom:none}
.member-row .mr-days{color:var(--accent);font-weight:700}

.plan-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px;margin-bottom:12px;cursor:pointer;transition:border-color .2s}
.plan-card:active{border-color:var(--accent)}
.plan-card .pc-pillar{font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:5px}
.plan-card .pc-title{font-size:16.5px;font-weight:800;margin-bottom:4px}
.plan-card .pc-tag{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:10px}
.plan-card .pc-bar{height:6px;border-radius:3px;background:var(--surface-2);overflow:hidden}
.plan-card .pc-bar .pc-fill{height:100%;background:var(--accent);transition:width .4s}
.plan-card .pc-meta{display:flex;justify-content:space-between;font-size:11.5px;color:var(--text-dim);margin-top:6px}
.pc-pillar.health{color:#5a8f6e}.pc-pillar.wealth{color:#c9a84c}.pc-pillar.relationships{color:#9a8fd0}

.plan-day{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.plan-day:last-child{border-bottom:none}
.plan-day .pd-check{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;margin-top:2px}
.plan-day.done .pd-check{background:var(--accent);border-color:var(--accent);color:#10200f}
.plan-day .pd-title{font-weight:700;font-size:14.5px;margin-bottom:2px}
.plan-day.done .pd-title{text-decoration:line-through;opacity:.65}
.plan-day .pd-ref{font-size:12px;color:var(--accent);margin-bottom:4px}
.plan-day .pd-action{font-size:13px;color:var(--text-muted);line-height:1.6}

.announce-card{border-left:3px solid var(--accent);padding-left:12px;margin-bottom:14px}
.announce-card .an-title{font-weight:700;font-size:14.5px}
.announce-card .an-body{font-size:13px;color:var(--text-muted);line-height:1.6;margin-top:3px}
.announce-card .an-meta{font-size:11px;color:var(--text-dim);margin-top:4px}

.rsvp-row{display:flex;gap:6px;margin-top:10px}
.rsvp-btn{flex:1;padding:8px 0;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);font-size:12px;font-weight:700;cursor:pointer}
.rsvp-btn.active{background:var(--accent);color:#10200f;border-color:var(--accent)}

.empty-mini{text-align:center;color:var(--text-dim);font-size:13px;padding:18px 8px}
.day-jump{display:flex;gap:8px;align-items:center;margin:10px 0 4px}
.day-jump input{width:90px;padding:9px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:14px}
.conv-row{display:flex;justify-content:space-between;align-items:center;padding:12px 4px;border-bottom:1px solid var(--border);cursor:pointer}
.conv-row:last-child{border-bottom:none}
.conv-row .cr-title{font-weight:700;font-size:14.5px}
.conv-row .cr-sub{font-size:12px;color:var(--text-dim);margin-top:2px}
.section-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);font-weight:700;margin:18px 4px 8px}
