:root {
  --bg: #0d1117;
  --bg-soft: #111827;
  --panel: rgba(18, 24, 38, 0.88);
  --panel-strong: #151c2e;
  --line: rgba(255, 255, 255, 0.12);
  --line-strong: rgba(255, 255, 255, 0.22);
  --text: #eef4ff;
  --muted: #aeb9c9;
  --accent: #d9b56a;
  --accent-2: #78e2c1;
  --danger: #ff7a8a;
  --warn: #ffcd6b;
  --ok: #69d98f;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.35);
  --radius: 22px;
  --max: 1180px;
}

/* Gold-Rend identity: warm gold is a trust signal, not a decorative afterthought. */
.brand strong { color: #ffe6a6; font-size: 1.04rem; letter-spacing: .055em; text-transform: uppercase; }
.site-header { border-bottom-color: rgba(217,181,106,.28); }
.landing-view::before { content: "GOLD-REND"; position: absolute; top: 108px; left: 50%; transform: translateX(-50%); color: rgba(255,218,144,.045); font-size: clamp(4rem, 17vw, 14rem); font-weight: 950; letter-spacing: .08em; white-space: nowrap; pointer-events: none; }
.landing-view { position: relative; overflow: hidden; }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(217, 181, 106, 0.14), transparent 32rem),
    radial-gradient(circle at top right, rgba(120, 226, 193, 0.11), transparent 30rem),
    linear-gradient(180deg, #0d1117 0%, #0f1522 45%, #0b0f18 100%);
  min-height: 100vh;
}

a { color: inherit; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }

.skip-link {
  position: absolute;
  left: 1rem;
  top: -100px;
  background: var(--accent);
  color: #191100;
  padding: .7rem 1rem;
  border-radius: 999px;
  z-index: 1000;
}
.skip-link:focus { top: 1rem; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(10, 14, 23, 0.72);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
}
.nav {
  width: min(var(--max), calc(100% - 2rem));
  margin: 0 auto;
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  text-decoration: none;
}
.brand-mark {
  width: 45px;
  height: 45px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at 35% 30%, #fff3cd, var(--accent) 45%, #6e511b 100%);
  color: #171100;
  font-weight: 900;
  box-shadow: 0 0 0 7px rgba(217, 181, 106, 0.08), 0 0 30px rgba(217, 181, 106, .24);
}

.brand-mark.logo-mark {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  padding: 0;
  overflow: hidden;
  background: #000;
  border: 1px solid rgba(217,181,106,.5);
  box-shadow: 0 0 0 6px rgba(217, 181, 106, 0.08), 0 0 34px rgba(217, 181, 106, .22);
}
.brand-mark img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.hero-logo {
  width: min(100%, 420px);
  aspect-ratio: 1 / 1;
  object-fit: contain;
  border-radius: 28px;
  background: #000;
  border: 1px solid rgba(217,181,106,.35);
  box-shadow: 0 20px 60px rgba(0,0,0,.35), 0 0 42px rgba(217,181,106,.18);
  margin: 0 auto .75rem;
}

.brand strong { display: block; letter-spacing: .02em; }
.brand small { display: block; color: var(--muted); font-size: .78rem; }
.nav-links {
  display: flex;
  align-items: center;
  gap: .25rem;
  flex-wrap: wrap;
  justify-content: center;
}
.nav-links a {
  text-decoration: none;
  color: var(--muted);
  padding: .55rem .7rem;
  border-radius: 999px;
  font-weight: 650;
  font-size: .92rem;
}
.nav-links a:hover, .nav-links a:focus { color: var(--text); background: rgba(255,255,255,.07); }
.nav-toggle { display: none; }
.language-picker {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  color: var(--muted);
  font-size: .82rem;
}
.language-picker select, .filters select, .smart-form select {
  color: var(--text);
  background: #111827;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: .6rem .7rem;
}

.hero, .section {
  width: min(var(--max), calc(100% - 2rem));
  margin: 0 auto;
}
.hero {
  min-height: calc(100vh - 74px);
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 2rem;
  align-items: center;
  padding: 4rem 0 3rem;
}
.eyebrow {
  margin: 0 0 .75rem;
  color: var(--accent-2);
  font-weight: 800;
  letter-spacing: .09em;
  text-transform: uppercase;
  font-size: .78rem;
}
h1, h2, h3, h4, p { overflow-wrap: anywhere; }
h1 {
  font-size: clamp(2.35rem, 5vw, 5.2rem);
  line-height: .95;
  letter-spacing: -.055em;
  margin: 0 0 1.25rem;
}
.hero-lead {
  color: var(--muted);
  font-size: 1.14rem;
  line-height: 1.72;
  max-width: 68ch;
  margin: 0 0 1.5rem;
}
.hero-actions, .dashboard-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  align-items: center;
}
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  min-height: 44px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: .75rem 1rem;
  color: var(--text);
  text-decoration: none;
  background: rgba(255,255,255,.06);
  font-weight: 800;
}
.button.primary {
  border-color: rgba(217,181,106,.55);
  color: #1b1404;
  background: linear-gradient(135deg, #ffe1a2, var(--accent));
}
.button.ghost:hover { background: rgba(255,255,255,.1); }
.button.danger { border-color: rgba(255,122,138,.5); color: #ffdbe0; }
.import-label input { display: none; }

/* V2 welcome: the first choice should be self-explanatory, not a wall of forms. */
.welcome-compass {
  width: min(100%, 940px);
  margin: 2.5rem auto 0;
  padding: clamp(1rem, 3vw, 1.6rem);
  text-align: left;
  border: 1px solid rgba(154, 181, 255, .22);
  border-radius: 26px;
  background: linear-gradient(135deg, rgba(30,91,255,.13), rgba(16,185,129,.07) 55%, rgba(124,58,237,.12));
  box-shadow: 0 24px 70px rgba(0,0,0,.22);
}
.welcome-compass-intro { display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; color: #c9d7ff; font-weight: 850; letter-spacing: .08em; font-size: .71rem; }
.welcome-compass-intro p { width: 100%; margin: .25rem 0 .9rem; color: var(--muted); font-size: .95rem; line-height: 1.55; font-weight: 550; letter-spacing: 0; }
.live-dot { width: 8px; height: 8px; border-radius: 50%; background: #51e5a5; box-shadow: 0 0 0 5px rgba(81,229,165,.12), 0 0 18px #51e5a5; }
.welcome-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: .7rem; }
.welcome-action { position: relative; min-height: 116px; display: flex; align-items: center; gap: .7rem; padding: 1rem; color: var(--text); text-decoration: none; border: 1px solid var(--line); border-radius: 18px; background: rgba(8,13,25,.52); transition: transform .2s ease, border-color .2s ease, background .2s ease; }
.welcome-action:hover { transform: translateY(-3px); background: rgba(18,28,49,.9); }
.welcome-action.need:hover { border-color: #f59e0b; }.welcome-action.help:hover { border-color: #10b981; }.welcome-action.chat:hover { border-color: #1e5bff; }
.action-icon { width: 38px; height: 38px; display: grid; flex: 0 0 auto; place-items: center; border-radius: 13px; font-size: 1.25rem; font-weight: 900; }
.need .action-icon { color: #ffd483; background: rgba(245,158,11,.15); }.help .action-icon { color: #7ef0c2; background: rgba(16,185,129,.15); }.chat .action-icon { color: #b7c8ff; background: rgba(30,91,255,.18); }
.welcome-action b, .welcome-action small { display: block; }.welcome-action b { font-size: .95rem; }.welcome-action small { margin-top: .28rem; color: var(--muted); font-size: .77rem; line-height: 1.35; }.welcome-action i { margin-left: auto; font-style: normal; color: var(--muted); font-size: 1.15rem; }
.welcome-footer { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1rem; color: #aebbd6; font-size: .76rem; }
.zeton-card { border-color: rgba(6,182,212,.38); background: linear-gradient(135deg, rgba(6,182,212,.13), rgba(30,91,255,.1)); }
.zeton-label { color: #73e6fa; font-size: .68rem; font-weight: 900; letter-spacing: .1em; }

@media (max-width: 760px) {
  .welcome-actions { grid-template-columns: 1fr; }
  .welcome-action { min-height: 86px; }
}
.trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 1.65rem;
}
.trust-row span, .pill {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: .4rem .75rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255,255,255,.045);
  font-weight: 700;
  font-size: .86rem;
}

.ezo-panel, .card, .smart-form {
  background: linear-gradient(180deg, rgba(24, 32, 50, .92), rgba(17, 24, 39, .88));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.ezo-panel {
  padding: 1.5rem;
  min-height: 520px;
  display: grid;
  place-items: center;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.ezo-panel::before {
  content: "";
  position: absolute;
  inset: -35%;
  background: conic-gradient(from 180deg, transparent, rgba(217,181,106,.12), transparent, rgba(120,226,193,.12), transparent);
  animation: spin 18s linear infinite;
}
.ezo-panel > * { position: relative; z-index: 1; }
.ezo-orb {
  width: min(300px, 70vw);
  height: min(300px, 70vw);
  position: relative;
  display: grid;
  place-items: center;
  margin: 1rem auto;
}
.ezo-orb .ring {
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  border: 34px solid rgba(217,181,106,.82);
  box-shadow: inset 0 0 36px rgba(255,255,255,.06), 0 0 60px rgba(217,181,106,.22);
}
.ezo-orb .arrow {
  position: absolute;
  width: 42%;
  height: 8px;
  left: 50%;
  top: 50%;
  transform-origin: 0 50%;
  transform: rotate(38deg);
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(120,226,193,.1), var(--accent-2));
  box-shadow: 0 0 28px rgba(120,226,193,.52);
  animation: breathe 5s ease-in-out infinite;
}
.ezo-orb .arrow::after {
  content: "";
  position: absolute;
  right: -7px;
  top: 50%;
  width: 18px;
  height: 18px;
  transform: translateY(-50%) rotate(45deg);
  border-top: 8px solid var(--accent-2);
  border-right: 8px solid var(--accent-2);
}
.ezo-orb .core {
  width: 92px;
  height: 92px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at 35% 30%, #fff7d7, var(--accent) 48%, #5d4315 100%);
  color: #151004;
  font-size: 1.4rem;
  font-weight: 950;
  box-shadow: 0 0 42px rgba(217,181,106,.38);
}
.status-grid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
  margin: 1rem 0 0;
}
.status-grid div, .metrics article {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.045);
  border-radius: 16px;
  padding: .9rem;
}
dt, .metrics small { color: var(--muted); font-size: .82rem; }
dd, .metrics span { margin: .2rem 0 0; font-size: 1.4rem; font-weight: 950; }

.section { padding: 4rem 0; }
.intro-grid {
  display: grid;
  grid-template-columns: 1.35fr repeat(3, 1fr);
  gap: 1rem;
}
.card { padding: 1.25rem; }
.card h2, .card h3 { margin-top: 0; }
.card p { color: var(--muted); line-height: 1.65; }
.accent-card { background: linear-gradient(135deg, rgba(217,181,106,.22), rgba(24,32,50,.92)); }
.section-heading {
  max-width: 820px;
  margin-bottom: 1.25rem;
}
.section-heading h2 {
  margin: 0 0 .55rem;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  letter-spacing: -.04em;
}
.section-heading p { color: var(--muted); line-height: 1.65; }
.smart-form { padding: 1.25rem; }
.form-grid, .filters {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
}
.smart-form label, .filters label {
  display: grid;
  gap: .4rem;
  color: var(--muted);
  font-weight: 750;
  font-size: .92rem;
}
.smart-form input, .smart-form textarea, .filters input {
  width: 100%;
  color: var(--text);
  background: rgba(7, 12, 21, .72);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: .78rem .85rem;
  outline: none;
}
.smart-form input:focus, .smart-form textarea:focus, .smart-form select:focus, .filters input:focus, .filters select:focus {
  border-color: rgba(217,181,106,.72);
  box-shadow: 0 0 0 4px rgba(217,181,106,.1);
}
.smart-form textarea { resize: vertical; }
.smart-form > label, .check-fieldset { margin-top: .9rem; }
.checkbox-line { display: flex !important; grid-template-columns: auto 1fr !important; align-items: flex-start; }
.checkbox-line input { width: auto; margin-top: .25rem; }
.check-fieldset {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 1rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .6rem;
}
.check-fieldset.compact { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.check-fieldset legend { color: var(--accent); font-weight: 900; padding: 0 .45rem; }
.check-fieldset label { display: flex; gap: .45rem; align-items: flex-start; color: var(--muted); font-weight: 650; }
.check-fieldset input { width: auto; margin-top: .25rem; }
.smart-form button[type="submit"] { margin-top: 1rem; }

.dashboard-heading {
  max-width: none;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}
.metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin: 1rem 0;
}
.metrics span { display: block; color: var(--accent); }
.filters { align-items: end; margin-bottom: 1rem; }
.dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
  gap: 1rem;
  align-items: start;
}
.card-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.card-title-row h3 { margin: 0; }
.case-list, .volunteer-list { display: grid; gap: .85rem; }
.case-item {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 1rem;
  background: rgba(255,255,255,.045);
}
.case-item.critical { border-color: rgba(255,122,138,.58); box-shadow: inset 4px 0 0 rgba(255,122,138,.75); }
.case-item.important { border-color: rgba(255,205,107,.45); box-shadow: inset 4px 0 0 rgba(255,205,107,.72); }
.case-item.normal { box-shadow: inset 4px 0 0 rgba(105,217,143,.55); }
.case-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
}
.case-head h4 { margin: 0 0 .25rem; font-size: 1.05rem; }
.case-meta { color: var(--muted); font-size: .87rem; display: flex; flex-wrap: wrap; gap: .4rem .8rem; }
.score-badge {
  min-width: 68px;
  text-align: center;
  border-radius: 999px;
  padding: .4rem .65rem;
  font-weight: 950;
  color: #160c0e;
  background: var(--ok);
}
.score-badge.critical { background: var(--danger); color: #210007; }
.score-badge.important { background: var(--warn); color: #1b1200; }
.case-desc { color: var(--muted); line-height: 1.55; margin: .8rem 0; }
.match-box {
  border-top: 1px solid var(--line);
  margin-top: .8rem;
  padding-top: .8rem;
  color: var(--muted);
  display: grid;
  gap: .4rem;
}
.match-box strong { color: var(--text); }
.case-actions {
  display: flex;
  gap: .55rem;
  flex-wrap: wrap;
  margin-top: .75rem;
}
.small-btn {
  border: 1px solid var(--line);
  color: var(--muted);
  background: rgba(0,0,0,.14);
  border-radius: 999px;
  padding: .45rem .65rem;
}
.small-btn:hover { color: var(--text); background: rgba(255,255,255,.07); }
.logic-stack { display: grid; gap: .55rem; margin: 1rem 0; }
.logic-stack div, .volunteer-card {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  padding: .75rem;
  color: var(--muted);
}
.logic-stack strong { color: var(--accent); margin-right: .35rem; }
.volunteer-card strong { display: block; color: var(--text); }
.volunteer-card small { color: var(--muted); display: block; margin-top: .25rem; }
.map-layout, .map-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
  gap: 1rem;
  align-items: start;
}
.map-workspace { margin-top: 1rem; }
.rend-map {
  width: 100%;
  min-height: 520px;
  border-radius: 16px;
  border: 1px solid var(--line);
  overflow: hidden;
  background: #101827;
}
.leaflet-container { font: inherit; color: #132014; }
.leaflet-popup-content-wrapper, .leaflet-popup-tip { background: #fff9ed; }
.map-toolbar, .map-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
  margin-top: .8rem;
}
.map-point, .privacy-note {
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.55;
}
.map-settings-panel { display: grid; gap: .85rem; }
.map-filters {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 1rem;
}
.map-report-list {
  display: grid;
  gap: .75rem;
  max-height: 560px;
  overflow: auto;
  padding-right: .25rem;
}
.map-report-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  padding: .85rem;
}
.map-report-card.critical {
  border-color: rgba(255,122,138,.58);
  box-shadow: inset 4px 0 0 rgba(255,122,138,.75);
}
.map-report-card.important {
  border-color: rgba(255,205,107,.45);
  box-shadow: inset 4px 0 0 rgba(255,205,107,.72);
}
.map-report-card strong { display: block; color: var(--text); }
.map-report-card small, .map-report-card p { color: var(--muted); }
.map-report-card p { margin: .45rem 0 0; line-height: 1.5; }
.map-marker-dot {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 3px solid #fff;
  box-shadow: 0 2px 12px rgba(0,0,0,.35);
}
.map-marker-dot.critical { background: var(--danger); }
.map-marker-dot.important { background: var(--warn); }
.map-marker-dot.normal { background: var(--ok); }
.map-marker-dot.profile { background: var(--accent-2); }
.social-grid {
  display: grid;
  grid-template-columns: minmax(240px, .7fr) minmax(0, 1.2fr) minmax(280px, .9fr);
  gap: 1rem;
  align-items: start;
}
.profile-panel, .chat-panel { min-height: 100%; }
.active-profile-label {
  display: grid;
  gap: .4rem;
  color: var(--muted);
  font-weight: 750;
  margin-bottom: .85rem;
}
.active-profile-label select {
  color: var(--text);
  background: #111827;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: .7rem .75rem;
}
.profile-list, .message-list, .notification-list, .forum-list, .conversation-list {
  display: grid;
  gap: .7rem;
}
.profile-card, .message-item, .notification-item, .forum-item {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  padding: .8rem;
}
.profile-card.active {
  border-color: rgba(120,226,193,.55);
  box-shadow: inset 4px 0 0 rgba(120,226,193,.7);
}
.profile-card strong { display: block; color: var(--text); }
.profile-card small { display: block; color: var(--muted); margin-top: .25rem; }
.profile-card p, .forum-item p, .notification-item p { margin: .45rem 0 0; color: var(--muted); line-height: 1.5; }
.notification-item.unread {
  border-color: rgba(120,226,193,.55);
  background: rgba(120,226,193,.08);
}
.message-list {
  max-height: 460px;
  overflow: auto;
  padding-right: .25rem;
}
.message-list.compact { max-height: 330px; }
.message-item.mine {
  border-color: rgba(217,181,106,.45);
  background: rgba(217,181,106,.08);
}
.message-meta {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  align-items: baseline;
  color: var(--muted);
  font-size: .85rem;
}
.message-meta strong { color: var(--text); }
.message-item p {
  margin: .45rem 0 0;
  color: var(--text);
  line-height: 1.55;
}
.mention {
  color: #102018;
  background: var(--accent-2);
  border-radius: 999px;
  padding: .05rem .35rem;
  font-weight: 900;
}
.channel-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: .4rem 0 .85rem;
}
.channel-tabs button {
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255,255,255,.045);
  padding: .5rem .75rem;
  font-weight: 800;
}
.channel-tabs button.active {
  color: #161004;
  background: var(--accent);
  border-color: var(--accent);
}
.message-form {
  display: grid;
  gap: .75rem;
  margin-top: .9rem;
}
.message-form label {
  display: grid;
  gap: .4rem;
  color: var(--muted);
  font-weight: 750;
}
.message-form textarea, .message-form input, .message-form select {
  width: 100%;
  color: var(--text);
  background: rgba(7, 12, 21, .72);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: .78rem .85rem;
}
.message-form textarea {
  resize: vertical;
}
.message-form textarea:focus, .message-form input:focus, .message-form select:focus, .active-profile-label select:focus {
  border-color: rgba(217,181,106,.72);
  box-shadow: 0 0 0 4px rgba(217,181,106,.1);
  outline: none;
}
.forum-grid { margin-top: 1rem; }
.forum-panel { display: grid; gap: 1rem; }
.form-grid.slim { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.conversation-btn {
  width: 100%;
  text-align: left;
  border: 1px solid var(--line);
  color: var(--text);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  padding: .7rem;
}
.conversation-btn small { display: block; color: var(--muted); margin-top: .2rem; }
.private-actions {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  margin-top: .75rem;
}
.split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.footer {
  width: min(var(--max), calc(100% - 2rem));
  margin: 0 auto;
  padding: 2rem 0;
  color: var(--muted);
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.toast {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  max-width: min(420px, calc(100vw - 2rem));
  background: #f7e2ad;
  color: #161004;
  padding: .9rem 1rem;
  border-radius: 16px;
  box-shadow: var(--shadow);
  transform: translateY(140%);
  opacity: 0;
  transition: .25s ease;
  z-index: 999;
  font-weight: 800;
}
.toast.show { transform: translateY(0); opacity: 1; }
.empty-state {
  border: 1px dashed var(--line-strong);
  border-radius: 18px;
  padding: 2rem;
  text-align: center;
  color: var(--muted);
}
.app-view { display: none; }
body.app-routed main > section { display: none; }
body.app-routed[data-route="/"] #landingView,
body.app-routed[data-route="/how-it-works"] #howItWorksView,
body.app-routed[data-route="/register"] #registerView,
body.app-routed[data-route="/login"] #loginView,
body.app-routed[data-route="/dashboard"] #dashboardHomeView,
body.app-routed[data-route="/ezo-chat"] #ezoChatView,
body.app-routed[data-route="/ai-segito"] #aiAssistantView,
body.app-routed[data-route="/zeton-tar"] #zetonVaultView,
body.app-routed[data-route="/contact"] #contactView,
body.app-routed[data-route="/report-new"] #reportNewView,
body.app-routed[data-route="/map"] #rendterkep,
body.app-routed[data-route="/profile"] #rendchat,
body.app-routed[data-route="/chat"] #rendchat,
body.app-routed[data-route="/messages"] #rendchat,
body.app-routed[data-route="/forum"] #rendchat,
body.app-routed[data-route="/reports"] #dashboard,
body.app-routed[data-route="/ezo"] #dashboard,
body.app-routed[data-route="/privacy"] #adatvedelem {
  display: block;
}
.landing-view {
  min-height: calc(100vh - 74px);
  display: none;
  place-items: center;
  text-align: center;
}
body.app-routed[data-route="/"] .landing-view { display: grid; }
.landing-shell {
  width: min(820px, 100%);
  margin: 0 auto;
  padding: 3rem 0;
}
.landing-logo {
  width: min(180px, 45vw);
  aspect-ratio: 1 / 1;
  object-fit: contain;
  border-radius: 24px;
  border: 1px solid rgba(217,181,106,.35);
  background: #000;
  margin-bottom: 1.25rem;
}
.landing-shell h1 {
  margin-bottom: 1rem;
}
.landing-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .85rem;
  margin-top: 1.3rem;
}
.dashboard-cards, .module-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.module-card {
  text-decoration: none;
  min-height: 150px;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.module-card:hover {
  transform: translateY(-2px);
  border-color: rgba(217,181,106,.55);
  background: linear-gradient(180deg, rgba(36, 46, 68, .95), rgba(17, 24, 39, .88));
}
.auth-card {
  width: min(620px, 100%);
  margin: 0 auto;
}
.wizard-steps {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1rem;
}
.wizard-steps span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: .45rem .7rem;
  color: var(--muted);
  font-weight: 800;
  font-size: .86rem;
}
.wizard-steps span.active {
  color: #161004;
  background: var(--accent);
  border-color: var(--accent);
}
.success-panel { margin-top: 1rem; }
body.app-routed[data-route="/chat"] #rendchat .profile-panel,
body.app-routed[data-route="/chat"] #rendchat .chat-panel[aria-labelledby="privateChatTitle"],
body.app-routed[data-route="/chat"] #rendchat .forum-grid {
  display: none;
}
body.app-routed[data-route="/chat"] #rendchat .social-grid { grid-template-columns: minmax(0, 1fr); }
body.app-routed[data-route="/messages"] #rendchat .chat-panel[aria-labelledby="publicChatTitle"],
body.app-routed[data-route="/messages"] #rendchat .forum-grid {
  display: none;
}
body.app-routed[data-route="/messages"] #rendchat .social-grid { grid-template-columns: minmax(260px, .55fr) minmax(0, 1fr); }
body.app-routed[data-route="/forum"] #rendchat .social-grid { display: none; }
body.app-routed[data-route="/profile"] #rendchat .chat-panel,
body.app-routed[data-route="/profile"] #rendchat .forum-grid {
  display: none;
}
body.app-routed[data-route="/profile"] #rendchat .social-grid { grid-template-columns: minmax(0, 1fr); }
.nav-links a.active {
  color: var(--text);
  background: rgba(255,255,255,.09);
}

@keyframes spin { to { transform: rotate(360deg); } }
@keyframes breathe {
  0%, 100% { transform: rotate(38deg) scaleX(.9); }
  50% { transform: rotate(112deg) scaleX(1.08); }
}

@media (max-width: 1020px) {
  .hero, .dashboard-grid, .intro-grid, .split, .social-grid, .map-layout, .map-workspace, .dashboard-cards, .module-grid { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding-top: 3rem; }
  .form-grid, .form-grid.slim, .check-fieldset, .check-fieldset.compact, .filters, .map-filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashboard-heading { align-items: flex-start; flex-direction: column; }
}
@media (max-width: 780px) {
  .nav { flex-wrap: wrap; padding: .7rem 0; }
  .nav-toggle { display: inline-flex; border: 1px solid var(--line); background: rgba(255,255,255,.06); color: var(--text); border-radius: 999px; padding: .6rem .85rem; }
  .nav-links { display: none; width: 100%; justify-content: flex-start; }
  .nav-links.open { display: flex; }
  .language-picker { margin-left: auto; }
  h1 { font-size: clamp(2.2rem, 13vw, 4rem); }
  .form-grid, .form-grid.slim, .check-fieldset, .check-fieldset.compact, .filters, .map-filters, .metrics { grid-template-columns: 1fr; }
  .footer { display: block; }
  .case-head { flex-direction: column; }
}

/* Zeton-tár: read-only pilot until compliant payment and identity flows exist. */
.wallet-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.wallet-card { min-height: 190px; padding: 1.35rem; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(145deg, rgba(23,30,51,.96), rgba(12,18,31,.86)); box-shadow: var(--shadow); }
.wallet-card > span { display: block; font-size: .72rem; font-weight: 900; letter-spacing: .12em; }.wallet-card > strong { display: block; margin: .45rem 0; font-size: 2.8rem; line-height: 1; }.wallet-card p, .wallet-details p { color: var(--muted); line-height: 1.55; }
.zeton-wallet { border-color: rgba(251,191,36,.5); }.zeton-wallet span, .zeton-wallet strong { color: #fbbf24; }.zheton-wallet { border-color: rgba(168,85,247,.5); }.zheton-wallet span, .zheton-wallet strong { color: #c084fc; }.gold-wallet { border-color: rgba(212,175,55,.5); }.gold-wallet span, .gold-wallet strong { color: #f6d469; }.wallet-details { margin-top: 1rem; }.wallet-details .card { padding: 1.25rem; }.wallet-notice { border-color: rgba(255,205,107,.38); }
@media (max-width: 760px) { .wallet-grid { grid-template-columns: 1fr; } }
.chat-translate-toggle { display: inline-flex; align-items: center; gap: .5rem; margin: .75rem 0; color: #bcd0ff; font-size: .84rem; font-weight: 750; }.chat-translate-toggle input { accent-color: #3b82f6; }.chat-privacy-note { margin: -.35rem 0 .75rem; color: var(--muted); font-size: .76rem; line-height: 1.4; }.chat-translation { display: block; margin-top: .42rem; color: #8eb5ff; font-size: .87rem; line-height: 1.45; }.chat-translation.pending { color: var(--muted); font-style: italic; }
.safety-toggle { color: #ffd98a; }.chat-safety-alert { margin: .55rem 0; padding: .7rem .85rem; border: 1px solid rgba(245,158,11,.42); border-radius: 12px; color: #ffe3aa; background: rgba(245,158,11,.1); font-size: .82rem; line-height: 1.4; }
.ai-module-card { border-color: rgba(168,85,247,.45); background: linear-gradient(135deg, rgba(124,58,237,.15), rgba(217,181,106,.08)); }.ai-assistant-card { width: min(780px, 100%); margin: 0 auto; padding: 1.25rem; }.assistant-messages { min-height: 180px; max-height: 430px; overflow: auto; padding: 1rem; margin-bottom: 1rem; border: 1px solid var(--line); border-radius: 16px; background: rgba(3,7,18,.36); }.assistant-message { margin: 0 0 1rem; padding: .8rem; border-radius: 12px; background: rgba(255,255,255,.045); line-height: 1.55; }.assistant-message.user { border-left: 3px solid #d9b56a; }.assistant-message.ai { border-left: 3px solid #a855f7; }
.ezo-chat-card { border-color: rgba(120,226,193,.42); background: linear-gradient(135deg, rgba(16,185,129,.12), rgba(30,91,255,.08)); }.ezo-analysis-result { margin-top: 1rem; padding: 1rem; border: 1px solid rgba(120,226,193,.3); border-radius: 16px; background: rgba(7,35,31,.45); }.ezo-analysis-result h3 { margin-top: 0; }.ezo-analysis-result ul { margin: .5rem 0; padding-left: 1.2rem; }.ezo-priority { display: inline-flex; padding: .3rem .55rem; border-radius: 999px; font-weight: 900; }.ezo-priority.normal { color: #c7d8ff; background: rgba(30,91,255,.18); }.ezo-priority.fontos { color: #ffe2a1; background: rgba(245,158,11,.18); }.ezo-priority.kritikus { color: #ffbec7; background: rgba(239,68,68,.2); }
