/* Mode-X Mesh — public site design system
   Matched to the Android app theme (ui/theme/Theme.kt):
   navy primary, teal accent, soft amber, blue-grey surfaces.
   Inter for UI, JetBrains Mono for data, Material Symbols for icons. */

:root {
  --navy:      #0E5A8A;   /* MxmNavy   — primary            */
  --teal:      #3FB28F;   /* MxmTeal   — secondary / accent */
  --amber:     #F0A030;   /* MxmAmber  — tertiary / alert   */
  --green:     #2AC98E;   /* MxmSuccess                     */
  --warning:   #E8972A;   /* MxmWarning                     */
  --error:     #CF4545;   /* MxmError                       */
  --gold:      #E8C72A;   /* MxmMarkFav                     */
  --violet:    #8A6FE0;
  --cyan:      #35B9C9;

  --bg:        #0F1219;
  --bg-raise:  #1A2130;
  --bg-card:   #1A2130;
  --bg-cardv:  #232D42;
  --border:    #2A3550;

  --fg:        #EAEEF8;
  --fg-soft:   #CDD5E8;
  --muted:     #8A97B5;
  --disabled:  #4A5570;

  --accent:    var(--teal);
  --mono: 'JetBrains Mono', ui-monospace, monospace;
  --sans: 'Inter', system-ui, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background:
    radial-gradient(1200px 520px at 82% -12%, rgba(14,90,138,0.30), transparent 60%),
    radial-gradient(900px 480px at 8% 0%, rgba(63,178,143,0.12), transparent 55%),
    var(--bg);
  color: var(--fg);
  font-family: var(--sans);
  font-size: 15px; line-height: 1.6;
  min-height: 100vh; display: flex; flex-direction: column;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--teal); text-decoration: none; }
a:hover { text-decoration: underline; }
code, .mono { font-family: var(--mono); font-size: 0.92em; }

.msym {
  font-family: 'Material Symbols Rounded';
  font-weight: normal; font-style: normal;
  font-size: 20px; line-height: 1; letter-spacing: normal;
  text-transform: none; display: inline-block; white-space: nowrap;
  word-wrap: normal; direction: ltr; vertical-align: middle;
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.site-head {
  display: flex; align-items: center; gap: 26px; padding: 13px 26px;
  border-bottom: 1px solid var(--border);
  background: rgba(15,18,25,0.86); backdrop-filter: blur(12px);
  position: sticky; top: 0; z-index: 1000;
}
.brand { display: flex; align-items: center; gap: 10px; text-decoration: none !important; }
.brand-mark {
  width: 28px; height: 28px; border-radius: 8px;
  background: linear-gradient(135deg, var(--navy), var(--teal));
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 17px;
}
.brand-name { font-weight: 800; letter-spacing: 0.06em; color: var(--fg); font-size: 15px; }
.brand-name em { color: var(--teal); font-style: normal; }
.site-nav { display: flex; gap: 2px; flex-wrap: wrap; margin-left: auto; }
.site-nav a {
  color: var(--muted); padding: 7px 12px; border-radius: 9px;
  font-weight: 500; font-size: 13.5px; text-decoration: none !important;
  display: inline-flex; align-items: center; gap: 6px;
}
.site-nav a .msym { font-size: 18px; }
.site-nav a:hover { color: var(--fg); background: var(--bg-cardv); }
.site-nav a.on { color: var(--teal); background: rgba(63,178,143,0.12); }
.admin-link { color: var(--muted); text-decoration: none !important; display: inline-flex; align-items: center; }
.admin-link:hover { color: var(--teal); }

.site-main { flex: 1; width: 100%; max-width: 1180px; margin: 0 auto; padding: 36px 26px 64px; }
.site-main-full { flex: 1; width: 100%; padding: 0; display: flex; flex-direction: column; }
.site-foot {
  border-top: 1px solid var(--border); padding: 22px 26px;
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  color: var(--muted); font-size: 13px;
}
.site-foot a { color: var(--muted); }
.site-foot a:hover { color: var(--teal); }

.hero { padding: 58px 0 34px; }
.hero h1 { font-size: clamp(34px, 5.5vw, 56px); font-weight: 800; letter-spacing: -0.02em; line-height: 1.07; margin: 0 0 18px; }
.hero h1 .accent { color: var(--teal); }
.hero p.lead { font-size: 18px; color: var(--fg-soft); max-width: 650px; margin: 0 0 28px; }
.cta-row { display: flex; gap: 12px; flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 22px; border-radius: 11px; font-weight: 600; font-size: 14.5px;
  text-decoration: none !important; border: 1px solid var(--border);
  color: var(--fg); background: var(--bg-card);
  transition: transform .12s ease, border-color .12s ease;
}
.btn:hover { transform: translateY(-1px); border-color: var(--teal); }
.btn-primary { background: linear-gradient(135deg, var(--navy), var(--teal)); color: #fff; border-color: transparent; }
.btn-primary:hover { filter: brightness(1.08); }

.stat-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin: 26px 0 8px; }
.stat { background: var(--bg-card); border: 1px solid var(--border); border-radius: 14px; padding: 18px 20px; }
.stat .v { font-family: var(--mono); font-size: 28px; font-weight: 600; color: var(--teal); }
.stat .k { color: var(--muted); font-size: 12.5px; text-transform: uppercase; letter-spacing: 0.07em; margin-top: 2px; }

.features { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 16px; margin: 40px 0; }
.feature { background: var(--bg-card); border: 1px solid var(--border); border-radius: 16px; padding: 22px; transition: border-color .15s ease, transform .15s ease; }
.feature:hover { border-color: var(--teal); transform: translateY(-2px); }
.feature .icon {
  width: 42px; height: 42px; border-radius: 11px; background: rgba(63,178,143,0.12);
  display: flex; align-items: center; justify-content: center; color: var(--teal); margin-bottom: 12px;
}
.feature .icon .msym { font-size: 24px; }
.feature h3 { margin: 0 0 6px; font-size: 16px; }
.feature p { margin: 0; color: var(--muted); font-size: 14px; }

h1.page-title { font-size: 28px; font-weight: 800; letter-spacing: -0.01em; margin: 0 0 6px; display: flex; align-items: center; gap: 10px; }
h1.page-title .msym { color: var(--teal); font-size: 26px; }
p.page-sub { color: var(--muted); margin: 0 0 26px; }
.card { background: var(--bg-card); border: 1px solid var(--border); border-radius: 16px; padding: 20px 22px; margin-bottom: 18px; }
table.data { width: 100%; border-collapse: collapse; font-size: 14px; }
table.data th { text-align: left; color: var(--muted); font-size: 11.5px; text-transform: uppercase; letter-spacing: 0.07em; padding: 8px 10px; border-bottom: 1px solid var(--border); }
table.data td { padding: 9px 10px; border-bottom: 1px solid rgba(42,53,80,0.5); }
table.data tr:hover td { background: rgba(63,178,143,0.04); }

.pill { display: inline-block; font-family: var(--mono); font-size: 11.5px; border: 1px solid var(--border); border-radius: 999px; padding: 1px 9px; color: var(--muted); white-space: nowrap; }
.pill.teal  { color: var(--teal);  border-color: rgba(63,178,143,0.45); }
.pill.amber { color: var(--amber); border-color: rgba(240,160,48,0.45); }
.pill.navy  { color: #6fb7ff; border-color: rgba(14,90,138,0.6); }
.pill.green { color: var(--green); border-color: rgba(42,201,142,0.45); }
.pill.red   { color: var(--error); border-color: rgba(207,69,69,0.45); }
.dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:6px; }
.dot.on  { background: var(--green); box-shadow: 0 0 8px rgba(42,201,142,0.7); }
.dot.off { background: var(--disabled); }

.map-wrap { flex: 1; min-height: calc(100vh - 130px); position: relative; background:#0f1219; }
#map { position: absolute; inset: 0; }
.map-legend { position: absolute; bottom: 18px; left: 18px; z-index: 800; background: rgba(26,33,48,0.94); border: 1px solid var(--border); border-radius: 13px; padding: 12px 16px; font-size: 12.5px; color: var(--muted); }
.leaflet-container { background: #0F1219; font-family: var(--sans); }
.leaflet-popup-content-wrapper { background: var(--bg-card); color: var(--fg); border: 1px solid var(--border); border-radius: 13px; }
.leaflet-popup-tip { background: var(--bg-card); }
.leaflet-popup-content a { color: var(--teal); }
.leaflet-bar a { background: var(--bg-card); color: var(--fg); border-color: var(--border); }

.msg { display: flex; gap: 14px; padding: 13px 4px; border-bottom: 1px solid rgba(42,53,80,0.5); }
.msg .avatar { width: 38px; height: 38px; border-radius: 11px; flex: none; background: linear-gradient(135deg, var(--navy), #16243a); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; color: var(--teal); font-family: var(--mono); font-size: 12px; }
.msg .from { font-weight: 600; font-size: 14px; }
.msg .meta { color: var(--muted); font-size: 12px; }
.msg .text { margin-top: 2px; font-size: 14.5px; }
.msg.bot .avatar { background: linear-gradient(135deg, var(--teal), var(--navy)); color: #fff; }

.roles-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.role-card { background: var(--bg-card); border: 1px solid var(--border); border-left-width: 3px; border-radius: 12px; padding: 14px 16px; }
.role-card h4 { margin: 0 0 2px; font-size: 14.5px; }
.role-card .tag { color: var(--muted); font-size: 12.5px; }
.role-card .wire { font-family: var(--mono); font-size: 11px; color: var(--disabled); }

.docs-layout { display: grid; grid-template-columns: 250px 1fr; gap: 30px; }
.docs-nav { position: sticky; top: 78px; align-self: start; font-size: 13.5px; }
.docs-nav a { display: block; color: var(--muted); padding: 5px 10px; border-radius: 8px; text-decoration: none !important; text-transform: capitalize; }
.docs-nav a:hover { color: var(--fg); background: var(--bg-cardv); }
.docs-nav a.on { color: var(--teal); background: rgba(63,178,143,0.12); }
.docs-body { min-width: 0; }
.docs-body h1, .docs-body h2 { letter-spacing: -0.01em; }
.docs-body h2 { border-bottom: 1px solid var(--border); padding-bottom: 6px; margin-top: 36px; }
.docs-body pre { background: #0d1018; border: 1px solid var(--border); border-radius: 11px; padding: 14px 16px; overflow-x: auto; font-size: 13px; }
.docs-body code { background: rgba(63,178,143,0.10); padding: 1px 5px; border-radius: 5px; }
.docs-body pre code { background: none; padding: 0; }
.docs-body table { border-collapse: collapse; width: 100%; font-size: 13.5px; }
.docs-body th, .docs-body td { border: 1px solid var(--border); padding: 7px 10px; text-align: left; }
.docs-body blockquote { margin: 16px 0; padding: 10px 18px; border-left: 3px solid var(--teal); background: rgba(63,178,143,0.05); color: var(--muted); }

.flash-option { border: 1px solid var(--border); border-radius: 16px; padding: 24px; background: var(--bg-card); margin-bottom: 18px; }
.flash-option h3 { margin-top: 0; display: flex; align-items: center; gap: 8px; }
.flash-option h3 .msym { color: var(--teal); }
esp-web-install-button button { font-family: var(--sans); }

@media (max-width: 860px) {
  .docs-layout { grid-template-columns: 1fr; }
  .docs-nav { position: static; display: flex; flex-wrap: wrap; gap: 4px; }
  .site-head { gap: 12px; }
  .site-nav a span.lbl { display: none; }
}

.stat{text-decoration:none;color:inherit;display:block}
.stat:hover{border-color:var(--teal);transform:translateY(-1px)}
.small-muted{color:var(--muted);font-size:13px;line-height:1.45}
