:root {
  --bg: #edf5ee;
  --bg-soft: #f7fbf7;
  --surface: rgba(255,255,255,0.88);
  --surface-strong: #ffffff;
  --text: #163321;
  --muted: #5c7464;
  --line: rgba(30, 80, 46, 0.12);
  --primary: #2f7d4c;
  --primary-strong: #1f6339;
  --secondary: #dfeee2;
  --danger: #bf4742;
  --shadow: 0 16px 40px rgba(26, 64, 39, 0.12);
  --radius: 22px;
}

body[data-theme="dark"] {
  --bg: #0f1712;
  --bg-soft: #16201a;
  --surface: rgba(20, 31, 24, 0.92);
  --surface-strong: #1a2a20;
  --text: #e9f5ec;
  --muted: #aac2b1;
  --line: rgba(201, 235, 209, 0.12);
  --primary: #6dcc8f;
  --primary-strong: #4db573;
  --secondary: #23372b;
  --danger: #ef7f74;
  --shadow: 0 18px 42px rgba(0, 0, 0, 0.35);
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }
body {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(88, 173, 113, 0.18), transparent 28%),
    radial-gradient(circle at top right, rgba(114, 168, 222, 0.14), transparent 28%),
    linear-gradient(180deg, var(--bg-soft), var(--bg));
  color: var(--text);
}
button, input, select, textarea { font: inherit; }
button, select, input, textarea {
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--surface-strong);
  color: var(--text);
}
button { cursor: pointer; }
textarea, input, select { padding: 0.78rem 0.9rem; }
textarea { resize: vertical; }
img { max-width: 100%; display: block; }
.hidden { display: none !important; }
.muted { color: var(--muted); }
.full-span { grid-column: 1 / -1; }

#app-shell {
  max-width: 1600px;
  margin: 0 auto;
  padding: 1rem;
}
.app-header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}
.eyebrow {
  margin: 0 0 0.35rem;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--muted);
}
#app-title { margin: 0; font-size: clamp(1.9rem, 4vw, 3rem); }
.header-subtitle { margin: 0.3rem 0 0; color: var(--muted); }
.header-actions, .profile-actions, .toolbar-group, .toolbar-stats, .tab-nav, .auth-actions { display: flex; gap: 0.75rem; }
.header-actions, .profile-actions, .toolbar-stats { flex-wrap: wrap; }

.panel {
  background: var(--surface);
  backdrop-filter: blur(18px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.auth-panel {
  display: grid;
  place-items: center;
  min-height: 62vh;
}
.auth-card {
  max-width: 580px;
  padding: 2rem;
}
.auth-card h2 { margin-top: 0; }
.tiny-note { color: var(--muted); font-size: 0.92rem; }

.workspace {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}
.left-rail {
  padding: 1rem;
  position: sticky;
  top: 1rem;
}
.profile-box { display: grid; gap: 1rem; }
.profile-row { display: flex; gap: 0.9rem; align-items: center; }
.profile-name { font-size: 1.15rem; font-weight: 700; }
.avatar {
  width: 62px;
  height: 62px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid rgba(255,255,255,0.65);
}
.tab-nav {
  flex-direction: column;
  margin-top: 1rem;
}
.tab-btn {
  width: 100%;
  text-align: left;
  padding: 0.95rem 1rem;
  background: transparent;
}
.tab-btn.active {
  background: rgba(80, 174, 112, 0.16);
  border-color: rgba(80, 174, 112, 0.36);
}
.content-area { min-width: 0; }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

#tab-map {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(320px, 0.9fr);
  gap: 1rem;
}
.right-stack { display: grid; gap: 1rem; }
.map-panel, .sector-panel, .form-panel { padding: 1rem; }
.toolbar { display: grid; gap: 0.9rem; margin-bottom: 0.9rem; }
.toolbar-grid { grid-template-columns: 1fr; }
.wrap { flex-wrap: wrap; }
.inline-control {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  padding: 0.35rem 0.4rem 0.35rem 0.75rem;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-strong);
}
.inline-control span { color: var(--muted); font-size: 0.92rem; }
.inline-control select { border: 0; padding: 0.3rem 0.35rem; background: transparent; }
.toolbar-hint { margin-top: 0; }
#map {
  width: 100%;
  min-height: 68vh;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--line);
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.62);
  border: 1px solid var(--line);
}
body[data-theme="dark"] .pill { background: rgba(255,255,255,0.04); }

.primary-btn, .secondary-btn, .ghost-btn, .danger-btn {
  padding: 0.82rem 1rem;
  font-weight: 600;
}
.primary-btn {
  background: linear-gradient(180deg, var(--primary), var(--primary-strong));
  color: white;
  border-color: transparent;
}
.secondary-btn {
  background: var(--secondary);
}
.ghost-btn {
  background: transparent;
}
.danger-btn {
  background: rgba(191, 71, 66, 0.12);
  color: var(--danger);
  border-color: rgba(191, 71, 66, 0.22);
}
.select-compact { padding: 0.65rem 0.85rem; }

.section-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1rem;
}
.section-head.slim { margin-top: 1.5rem; }
.section-head h2, .section-head h3 { margin: 0; }
.list-stack { display: grid; gap: 0.85rem; }
.list-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-strong);
  padding: 1rem;
}
.list-card h4, .list-card h3, .list-card p { margin-top: 0; }
.kpi { font-size: 1.45rem; font-weight: 800; }
.rank-row {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
}
.rank-badge {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: rgba(80, 174, 112, 0.16);
  font-weight: 800;
}

.settings-grid, .form-grid, .compact-grid, .dialog-form {
  display: grid;
  gap: 0.95rem;
}
.settings-grid, .form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.settings-grid label, .form-grid label, .dialog-form label {
  display: grid;
  gap: 0.45rem;
}
.settings-grid span, .form-grid span, .dialog-form span {
  font-size: 0.92rem;
  color: var(--muted);
}
.compact-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.image-preview-wrap {
  min-height: 110px;
  border-radius: 18px;
  border: 1px dashed var(--line);
  background: rgba(255,255,255,0.35);
  display: grid;
  place-items: center;
  overflow: hidden;
}
body[data-theme="dark"] .image-preview-wrap { background: rgba(255,255,255,0.03); }
.image-preview { width: 100%; height: 100%; object-fit: cover; }
.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 0.75rem;
}
.detail-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-strong);
  padding: 0.85rem;
}
.detail-card strong { display: block; margin-bottom: 0.35rem; }

.app-dialog {
  width: min(560px, calc(100vw - 1.5rem));
  border: none;
  border-radius: 24px;
  background: var(--surface-strong);
  color: var(--text);
  box-shadow: var(--shadow);
}
.dialog-form { padding: 1.1rem; }
.dialog-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
  background: var(--surface-strong);
  color: var(--text);
}

@media (max-width: 1080px) {
  .workspace, #tab-map {
    grid-template-columns: 1fr;
  }
  .left-rail { position: static; }
}

@media (max-width: 780px) {
  #app-shell { padding: 0.75rem; }
  .app-header { align-items: stretch; flex-direction: column; }
  .settings-grid, .form-grid, .compact-grid, .detail-grid { grid-template-columns: 1fr; }
  .tab-nav {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .tab-btn { text-align: center; }
  #map { min-height: 58vh; }
}

@media (max-width: 560px) {
  .tab-nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rank-row { grid-template-columns: 42px minmax(0,1fr); }
  .rank-row .kpi { grid-column: 2; }
}

.landing-page { display: grid; gap: 1rem; }
.site-header { position: sticky; top: 0; z-index: 1000; backdrop-filter: blur(18px); }
.landing-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.9fr);
  gap: 1rem;
  padding: 1.4rem;
}
.landing-copy { display: grid; gap: 1rem; align-content: center; }
.lead { font-size: clamp(1.05rem, 2vw, 1.2rem); max-width: 66ch; color: var(--muted); margin: 0; }
.hero-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.hero-stats { display: grid; gap: 0.85rem; }
.hero-stat-card, .landing-card {
  padding: 1rem;
  border-radius: 20px;
  background: var(--surface-strong);
  border: 1px solid var(--line);
  display: grid;
  gap: 0.45rem;
}
.landing-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.landing-list { margin: 0; padding-left: 1.1rem; color: var(--muted); display: grid; gap: 0.5rem; }
.auth-panel { min-height: auto; padding: 1rem; }
.team-meta { display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 0.4rem 0 0.7rem; }
.meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.38rem 0.65rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(80, 174, 112, 0.08);
  font-size: 0.88rem;
}
.member-row { display: flex; justify-content: space-between; align-items: center; gap: 0.75rem; }
.stack-actions { display: flex; gap: 0.55rem; flex-wrap: wrap; }
.dialog-form { min-width: min(92vw, 760px); max-height: 86vh; overflow: auto; }
@media (max-width: 980px) {
  .landing-hero, #tab-map, .workspace, .landing-grid { grid-template-columns: 1fr; }
  .left-rail { position: static; }
}
@media (max-width: 720px) {
  .app-header { align-items: stretch; flex-direction: column; }
  .settings-grid, .form-grid, .compact-grid { grid-template-columns: 1fr; }
  #map { min-height: 54vh; }
}


.landing-card-wide { grid-column: span 2; }
.stack-list { display: grid; gap: 0.75rem; }
.admin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; }
.code-block { white-space: pre-wrap; word-break: break-word; padding: 0.75rem; border-radius: 12px; background: rgba(0,0,0,0.08); }
[data-theme="dark"] .code-block { background: rgba(255,255,255,0.08); }
.cover-image { width: 100%; max-height: 220px; object-fit: cover; border-radius: 14px; margin-top: 0.5rem; }
@media (max-width: 900px) { .landing-card-wide { grid-column: span 1; } }
