/* ────────────────────────────────────────────────────────────────
   BUCONOS — modern dive ops dashboard
   ──────────────────────────────────────────────────────────────── */

:root {
  /* Buconos Diving — photo-first, deep navy palette */
  --bg-0: #050b14;
  --bg-1: #0a1626;
  --bg-2: #0e1f33;
  --bg-3: #14304e;
  --surface: rgba(255, 255, 255, 0.025);
  --surface-2: rgba(255, 255, 255, 0.05);
  --border: rgba(255, 255, 255, 0.075);
  --border-2: rgba(255, 255, 255, 0.14);

  --ink-0: #ffffff;
  --ink-1: #c8d3df;
  --ink-2: #7e92a8;
  --ink-3: #4e6378;

  /* Single brand accent: teal from the website's underline */
  --accent:        #1ab3c6;
  --accent-2:      #0e8a99;
  --accent-soft:   #4dd1de;

  /* Legacy aliases used across components */
  --accent-aqua:   #4dd1de;
  --accent-violet: #6a86c9;
  --accent-warm:   #f5b042;
  --accent-coral:  #ff7a52;

  /* Trip categories — still need differentiation */
  --cat-buceo:     #1ab3c6;  /* primary teal */
  --cat-apnea:     #f5b042;  /* warm freediving (apnea is the lighter discipline) */
  --cat-internac:  #6a86c9;  /* deep blue */

  --ok: #2dd4a7;
  --warn: #f5b042;
  --danger: #ff5c75;

  --radius: 12px;
  --radius-sm: 8px;

  --shadow-1: 0 1px 0 rgba(255,255,255,0.04) inset,
              0 8px 24px rgba(0,0,0,0.35);
  --shadow-2: 0 24px 60px -20px rgba(0,0,0,0.6);

  --font-sans: 'Manrope', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-display: 'Montserrat', 'Manrope', sans-serif;
  --font-wordmark: 'Anton', 'Montserrat', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  /* Legacy aliases — backward compat with module CSS */
  --primary: var(--accent);
  --primary-light: var(--accent-2);
  --secondary: var(--accent-soft);
  --bg: var(--bg-0);
  --bg-card: var(--bg-1);
  --text: var(--ink-0);
  --text-light: var(--ink-2);
  --success: var(--ok);
  --warning: var(--warn);
  --shadow: var(--shadow-1);
}

[data-theme="light"] {
  --bg-0: #f5f6f7;
  --bg-1: #ffffff;
  --bg-2: #fafbfc;
  --bg-3: #ebeef2;
  --surface: rgba(10, 22, 38, 0.025);
  --surface-2: rgba(10, 22, 38, 0.05);
  --border: rgba(10, 22, 38, 0.10);
  --border-2: rgba(10, 22, 38, 0.20);

  --ink-0: #0a1626;
  --ink-1: #2b3d54;
  --ink-2: #5e7088;
  --ink-3: #8896aa;

  --shadow-1: 0 1px 0 rgba(255,255,255,0.7) inset,
              0 6px 18px rgba(10,22,38,0.06);
  --shadow-2: 0 24px 60px -20px rgba(10,22,38,0.18);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--bg-0);
  color: var(--ink-0);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.005em;
}

body {
  min-height: 100vh;
  background: var(--bg-0);
}

[data-theme="light"] body { background: var(--bg-0); }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
h1, h2, h3 { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.01em; }

/* ────────────────────────────────────────────────────────────────
   LAYOUT
   ──────────────────────────────────────────────────────────────── */
.app {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

/* ────────────────────────────────────────────────────────────────
   SIDEBAR
   ──────────────────────────────────────────────────────────────── */
.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  border-right: 1px solid var(--border);
  padding: 26px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  background: var(--bg-0);
}

.brand { padding: 0 4px 6px; }

.brand-wordmark {
  display: flex; flex-direction: column;
  align-items: flex-start;
  color: var(--ink-0);
  line-height: 1;
}
.brand-wordmark .bw-top {
  font-family: var(--font-wordmark);
  font-size: 30px;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1;
}
.brand-wordmark .bw-wave {
  width: 100%;
  height: 6px;
  color: var(--ink-0);
  margin: 4px 0 2px;
  opacity: 0.95;
}
.brand-wordmark .bw-bot {
  font-family: var(--font-display);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.36em;
  color: var(--ink-0);
  align-self: stretch;
  text-align: center;
}

.nav { display: flex; flex-direction: column; gap: 1px; flex: 1; }
.nav-label {
  font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--ink-3); padding: 14px 8px 6px;
  font-weight: 700;
  font-family: var(--font-display);
}

.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  border-radius: 6px;
  font-size: 11.5px;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-1);
  font-weight: 600;
  position: relative;
  transition: background 120ms, color 120ms;
}
.nav-item:hover { background: var(--surface); color: var(--ink-0); }

.nav-item .ni-ico {
  width: 16px; text-align: center;
  font-size: 13px;
  color: var(--ink-2);
}

.nav-item.is-active {
  background: var(--surface);
  color: var(--ink-0);
  border: none;
}
.nav-item.is-active .ni-ico { color: var(--accent); }
.nav-item.is-active::before {
  content: '';
  position: absolute; left: -16px; top: 9px; bottom: 9px;
  width: 2px; background: var(--accent);
  border-radius: 0 2px 2px 0;
}
.ni-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent);
  margin-left: auto;
}
.ni-badge {
  margin-left: auto;
  font-size: 10.5px; font-weight: 600;
  padding: 1px 6px;
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--ink-1);
  font-family: var(--font-mono);
}

.side-footer { padding: 0 4px; }
.conn {
  display: flex; gap: 10px; align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
}
.conn-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 8px var(--ok);
  flex-shrink: 0;
}
.conn > div { min-width: 0; flex: 1; }
.conn b { display: block; font-size: 12px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.conn span { display: block; font-size: 10.5px; color: var(--ink-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ────────────────────────────────────────────────────────────────
   TOPBAR
   ──────────────────────────────────────────────────────────────── */
.main { min-width: 0; padding: 18px 28px 40px; display: flex; flex-direction: column; gap: 22px; }

.topbar {
  display: flex; align-items: center; gap: 16px;
  padding: 4px 0;
}
.bc { font-size: 12.5px; color: var(--ink-2); display: flex; gap: 8px; align-items: center; }
.bc b { color: var(--ink-0); font-weight: 600; }
.bc-sep { opacity: 0.4; }

.search {
  margin-left: 8px;
  flex: 1; max-width: 460px;
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--ink-2);
}
.search:focus-within { border-color: var(--border-2); background: var(--surface-2); }
.search input {
  flex: 1; background: none; border: none; outline: none;
  color: var(--ink-0); font-family: inherit; font-size: 13px;
}
.search input::placeholder { color: var(--ink-3); }
.search kbd {
  font-family: var(--font-mono); font-size: 10px;
  padding: 2px 6px; border-radius: 4px;
  background: var(--surface-2); color: var(--ink-2);
  border: 1px solid var(--border);
}

.top-meta { margin-left: auto; display: flex; align-items: center; gap: 14px; }

.trm {
  display: flex; align-items: baseline; gap: 6px;
  padding: 7px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-family: var(--font-mono);
}
.trm-l { font-size: 9.5px; color: var(--ink-3); letter-spacing: 0.1em; text-transform: uppercase; }
.trm b { font-size: 12.5px; font-weight: 600; color: var(--ink-0); }
.trm-d { font-size: 10.5px; }
.trm-d.up { color: var(--ok); }
.trm-d.down { color: var(--danger); }

.icon-btn {
  width: 34px; height: 34px;
  display: grid; place-items: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--ink-1);
  position: relative;
  transition: background 120ms;
}
.icon-btn:hover { background: var(--surface-2); }
.icon-btn.dim { background: transparent; border-color: transparent; color: var(--ink-3); }
.icon-btn .pulse {
  position: absolute; top: 7px; right: 7px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent-coral);
  box-shadow: 0 0 0 2px var(--bg-1), 0 0 8px var(--accent-coral);
}

.me {
  display: flex; align-items: center; gap: 10px;
  padding: 5px 12px 5px 5px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
}
.me-av {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  display: grid; place-items: center;
  font-size: 11px; font-weight: 700; color: #02161e;
  font-family: var(--font-display);
}
.me-txt b { display: block; font-size: 12px; font-weight: 600; line-height: 1.1; }
.me-txt span { font-size: 10.5px; color: var(--ink-2); }

/* ────────────────────────────────────────────────────────────────
   HERO — photo overlay
   ──────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  min-height: 560px;
  display: flex;
  align-items: flex-end;
  box-shadow: var(--shadow-2);
  border: 1px solid var(--border);
}

.hero-photo {
  position: absolute; inset: 0;
  pointer-events: none;
}
.hero-svg { width: 100%; height: 100%; display: block; }

.hero-photo-tint {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(5,11,20,0) 0%, rgba(5,11,20,0.30) 50%, rgba(5,11,20,0.92) 100%),
    linear-gradient(90deg, rgba(5,11,20,0.7) 0%, rgba(5,11,20,0.15) 55%, rgba(5,11,20,0) 100%);
}

.hero-inner {
  position: relative;
  padding: 40px 48px 36px;
  width: 100%;
  display: flex; flex-direction: column; gap: 16px;
  z-index: 1;
}

.hero-eyebrow { display: flex; gap: 8px; flex-wrap: wrap; }

.eb-pill {
  font-family: var(--font-display);
  font-size: 9.5px;
  padding: 5px 12px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.45);
  color: var(--ink-0);
  letter-spacing: 0.20em;
  font-weight: 700;
  text-transform: uppercase;
}
.eb-tag {
  font-family: var(--font-display);
  font-size: 9.5px;
  padding: 5px 12px;
  background: var(--accent);
  color: #02161e;
  letter-spacing: 0.16em;
  font-weight: 800;
  text-transform: uppercase;
}

.hero-title {
  font-family: var(--font-wordmark);
  font-size: clamp(64px, 9vw, 120px);
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: 0.005em;
  color: var(--ink-0);
  text-shadow: 0 4px 28px rgba(0,0,0,0.5);
  margin-top: 4px;
  text-transform: uppercase;
}
.hero-sub {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--ink-0);
  max-width: 70ch;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}

.hero-quote {
  position: absolute;
  bottom: 40px; right: 48px;
  max-width: 30ch;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink-0);
  padding-left: 14px;
  border-left: 2px solid var(--accent);
  text-shadow: 0 2px 12px rgba(0,0,0,0.7);
}
.hero-quote cite {
  display: block;
  margin-top: 8px;
  font-family: var(--font-display);
  font-size: 9.5px;
  font-weight: 800;
  font-style: normal;
  color: var(--accent);
  letter-spacing: 0.22em;
}

.hero-cta {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-top: 6px;
}
.cta-meta {
  font-family: var(--font-display);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  color: var(--ink-1);
  margin-left: 8px;
  font-weight: 600;
  text-transform: uppercase;
}
.cta-meta b { color: var(--accent); font-weight: 800; }

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 24px;
  border-radius: 0;
  font-family: var(--font-display);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: transform 120ms, background 120ms, color 120ms, border-color 120ms;
}
.btn:active { transform: translateY(1px); }
.btn-arrow {
  display: inline-block;
  transition: transform 200ms;
  font-weight: 400;
}
.btn:hover .btn-arrow { transform: translateX(4px); }

.btn-primary {
  background: var(--ink-0);
  color: #061d35;
}
.btn-primary:hover { background: var(--accent); color: #02161e; }

.btn-ghost {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.5);
  color: var(--ink-0);
}
.btn-ghost:hover { background: rgba(255,255,255,0.1); border-color: var(--ink-0); }

.btn-on-dark { background: var(--ink-0); color: #02161e; }
.btn-ghost-d {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.3);
  color: var(--ink-0);
}

/* Conditions strip pinned at hero bottom */
.hero-cond {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  margin-top: 22px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.12);
}
.hc {
  background: rgba(5,11,20,0.6);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  padding: 14px 18px;
  display: flex; flex-direction: column; gap: 6px;
}
.hc-l {
  font-family: var(--font-display);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.20em;
  color: var(--ink-2);
}
.hc b {
  font-family: var(--font-wordmark);
  font-size: 34px;
  font-weight: 400;
  color: var(--ink-0);
  line-height: 1;
}
.hc b small {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-2);
  margin-left: 4px;
}
.hc-state b {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.10em;
  padding-top: 12px;
  color: var(--ok);
}

/* ────────────────────────────────────────────────────────────────
   KPIS
   ──────────────────────────────────────────────────────────────── */
.kpis {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.kpi {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px 14px 12px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 132px;
  position: relative;
  overflow: hidden;
}
.kpi-hl {
  background: var(--bg-1);
  border-color: var(--accent);
}
.kpi-hl::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--accent);
}

.kpi-h { display: flex; align-items: center; gap: 8px; }
.kpi-l {
  font-family: var(--font-display);
  font-size: 9.5px;
  color: var(--ink-2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  flex: 1;
}
.kpi-delta {
  font-family: var(--font-display);
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.10em;
  padding: 3px 6px;
  border-radius: 0;
  text-transform: uppercase;
}
.kpi-delta.up { color: var(--ok); background: rgba(61,220,151,0.10); }
.kpi-delta.down { color: var(--danger); background: rgba(255,92,117,0.10); }
.kpi-delta.warn { color: var(--warn); background: rgba(245,165,36,0.10); }

.kpi-v {
  font-family: var(--font-wordmark);
  font-size: 40px;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: var(--ink-0);
  line-height: 1;
}
.kpi-v small { font-size: 12px; color: var(--ink-2); font-weight: 400; letter-spacing: 0; margin-right: 4px; }
.kpi-v small:last-child { margin-right: 0; margin-left: 2px; }

.kpi-spark { height: 28px; margin-top: auto; }
.kpi-spark svg { width: 100%; height: 100%; display: block; }

.kpi-foot {
  font-size: 10.5px;
  color: var(--ink-2);
}
.kpi-foot b { color: var(--ink-0); font-weight: 600; font-family: var(--font-mono); }
.kpi-foot-row { display: flex; gap: 10px; flex-wrap: wrap; }
.kpi-foot-row span { display: inline-flex; align-items: center; gap: 4px; }

.kpi-bar {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: auto;
}
.bar {
  height: 5px; border-radius: 999px;
  background: var(--surface-2);
  overflow: hidden;
}
.bar > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-aqua));
  border-radius: 999px;
}
.bar.bar-multi { display: flex; }
.bar-multi .seg { display: block; height: 100%; }
.seg.pagada { background: var(--ok); }
.seg.confirmada { background: var(--accent-aqua); }
.seg.pendiente { background: var(--warn); }

.kpi-legend { display: flex; gap: 8px; font-size: 10px; color: var(--ink-2); flex-wrap: wrap; }
.kpi-legend span { display: inline-flex; align-items: center; gap: 4px; }

.dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--ink-3); display: inline-block;
}
.dot.pagada { background: var(--ok); }
.dot.confirmada { background: var(--accent-aqua); }
.dot.pendiente { background: var(--warn); }
.dot.ok { background: var(--ok); }
.dot.warn { background: var(--warn); }
.dot.acc { background: var(--accent); }
.dot.aqua { background: var(--accent-aqua); }
.dot.violet { background: var(--accent-violet); }

.kpi-chips { display: flex; gap: 5px; flex-wrap: wrap; margin-top: auto; }
.chip {
  font-family: var(--font-display);
  font-size: 9.5px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 0;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  background: var(--surface-2);
  color: var(--ink-1);
  white-space: nowrap;
}
.chip-blue { background: rgba(26,179,198,0.12); color: var(--accent); }
.chip-aqua { background: rgba(245,176,66,0.10); color: var(--cat-apnea); }
.chip-violet { background: rgba(106,134,201,0.12); color: var(--cat-internac); }

/* ────────────────────────────────────────────────────────────────
   GRID
   ──────────────────────────────────────────────────────────────── */
.grid {
  display: grid;
  grid-template-columns: 1.55fr 1fr;
  gap: 22px;
  align-items: start;
}
.col { display: flex; flex-direction: column; gap: 22px; min-width: 0; }

/* PANEL */
.panel {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 22px 24px;
  overflow: hidden;
  position: relative;
}
.panel-h {
  display: flex; align-items: flex-start; gap: 16px; justify-content: space-between;
  margin-bottom: 14px;
}
.panel-h > :first-child { flex: 1; min-width: 0; }
.panel-h h2 {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-0);
}
.panel-sub {
  display: block;
  font-size: 11.5px;
  color: var(--ink-2);
  margin-top: 4px;
  letter-spacing: 0.02em;
}
.link {
  font-size: 12px; color: var(--accent);
  font-weight: 600;
}
.link:hover { text-decoration: underline; }

.seg-ctrl {
  display: inline-flex;
  padding: 3px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.seg-ctrl button {
  padding: 5px 10px;
  font-size: 11.5px;
  font-weight: 500;
  border-radius: 6px;
  color: var(--ink-2);
}
.seg-ctrl button.is-on {
  background: var(--bg-2);
  color: var(--ink-0);
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

.pill {
  font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: 999px;
}
.pill-warn { background: rgba(245,165,36,0.12); color: var(--accent-warm); }

/* TRIP LIST */
.trip-list { display: flex; flex-direction: column; }

.trip {
  display: grid;
  grid-template-columns: 60px 3px 1fr 110px 130px 24px;
  gap: 14px;
  align-items: center;
  padding: 16px 4px;
  border-top: 1px solid var(--border);
  position: relative;
}
.trip:first-child { border-top: none; padding-top: 6px; }

.trip-date {
  text-align: center;
  font-family: var(--font-display);
}
.trip-date b {
  display: block;
  font-family: var(--font-wordmark);
  font-size: 32px;
  font-weight: 400;
  letter-spacing: 0.01em;
  line-height: 1;
  color: var(--ink-0);
}
.trip-date span {
  font-family: var(--font-display);
  font-size: 9.5px;
  color: var(--ink-2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
}

.trip-band {
  width: 3px; height: 36px;
  border-radius: 3px;
  background: var(--border-2);
}
.band-pacifico { background: var(--cat-buceo); }
.band-caribe { background: var(--accent-soft); }
.band-internacional { background: var(--cat-internac); }
.band-apnea { background: var(--cat-apnea); }

.trip-body { min-width: 0; }
.trip-row {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}
.trip-row h3 {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-right: 4px;
  color: var(--ink-0);
}
.trip-meta {
  display: flex; gap: 14px; flex-wrap: wrap;
  font-size: 11.5px;
  color: var(--ink-2);
  line-height: 1.4;
}

.tag {
  font-family: var(--font-display);
  font-size: 9px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 0;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  background: var(--surface-2);
  color: var(--ink-1);
  border: 1px solid var(--border);
}
.tag-cert { background: rgba(255,255,255,0.06); color: var(--ink-1); border-color: var(--border-2); }
.tag-buceo { background: rgba(26,179,198,0.12); color: var(--accent); border-color: rgba(26,179,198,0.30); }
.tag-apnea { background: rgba(245,176,66,0.10); color: var(--cat-apnea); border-color: rgba(245,176,66,0.30); }
.tag-level { background: var(--surface-2); font-family: var(--font-mono); text-transform: none; }
.tag-hot { background: rgba(245,176,66,0.10); color: var(--accent-warm); border-color: rgba(245,176,66,0.22); text-transform: none; }

.trip-cap {
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px;
  min-width: 110px;
}
.cap-bar {
  width: 100px; height: 4px;
  background: var(--surface-2);
  border-radius: 999px;
  overflow: hidden;
}
.cap-bar > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-aqua));
  border-radius: 999px;
}
.trip-cap b {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.02em;
}
.trip-cap b i { color: var(--ink-2); font-style: normal; font-weight: 400; }
.trip-cap span { font-size: 10.5px; color: var(--ink-2); }

.trip-price {
  display: flex; flex-direction: column; align-items: flex-end; gap: 6px;
  min-width: 130px;
}
.trip-price b {
  font-family: var(--font-display);
  font-size: 14px; font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--ink-0);
  white-space: nowrap;
}
.badge {
  font-family: var(--font-display);
  font-size: 9px;
  font-weight: 800;
  padding: 3px 7px;
  border-radius: 0;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}
.badge.ok { background: rgba(61,220,151,0.10); color: var(--ok); }
.badge.mid { background: rgba(90,200,250,0.10); color: var(--accent-aqua); }
.badge.warn { background: rgba(245,165,36,0.10); color: var(--warn); }
.badge.dim { background: var(--surface-2); color: var(--ink-2); }

/* CHART */
.chart {
  position: relative;
  background:
    linear-gradient(180deg, transparent, var(--surface));
  border-radius: 10px;
  padding: 18px 20px 10px;
  border: 1px solid var(--border);
}
.chart-svg {
  width: 100%; height: 220px;
  display: block;
}
.grid-lines line {
  stroke: var(--border);
  stroke-dasharray: 2 4;
}
.bar-current text { font-family: var(--font-mono); }

.chart-axis {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  padding: 8px 20px 0;
  font-size: 10.5px;
  color: var(--ink-3);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.chart-axis span { text-align: center; }
.chart-axis .ax-on { color: var(--accent); font-weight: 800; }

.legend { display: flex; gap: 12px; flex-wrap: wrap; font-size: 11px; color: var(--ink-2); }
.lg { display: inline-flex; align-items: center; gap: 5px; }
.lg-dim { color: var(--ink-3); }
.sw { width: 10px; height: 10px; border-radius: 3px; display: inline-block; }
.sw-acc { background: var(--accent); }
.sw-aqua { background: var(--accent-aqua); }
.sw-violet { background: var(--accent-violet); }
.sw-line { background: none; border-bottom: 1.5px dashed var(--ink-3); border-radius: 0; height: 1px; align-self: center; }

/* LOG */
.log { display: flex; flex-direction: column; }
.log-row {
  display: grid;
  grid-template-columns: 56px 1.4fr repeat(4, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 11px 4px;
  border-top: 1px solid var(--border);
  font-size: 12px;
}
.log-row:first-child { border-top: none; padding-top: 4px; }
.log-num {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  background: var(--surface-2);
  border-radius: 6px;
  color: var(--ink-2);
  text-align: center;
}
.log-body b { display: block; font-size: 13px; font-weight: 600; }
.log-body span { font-size: 11px; color: var(--ink-2); }
.log-stat { display: flex; flex-direction: column; min-width: 0; }
.log-stat span {
  font-size: 9.5px; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600;
}
.log-stat b {
  font-family: var(--font-mono); font-size: 13px;
  font-weight: 600;
}
.log-stat b small { font-size: 10px; color: var(--ink-2); font-weight: 400; margin-left: 1px; }
.log-when { font-size: 10.5px; color: var(--ink-3); font-family: var(--font-mono); text-align: right; }

/* FEATURE */
.feature {
  padding: 0;
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--border-2);
  position: relative;
  overflow: hidden;
}
.feature-bg {
  position: absolute; inset: 0; opacity: 0.9;
}
.feature-bg svg { width: 100%; height: 100%; display: block; }

.feature-body {
  position: relative;
  padding: 20px 22px 22px;
  display: flex; flex-direction: column; gap: 14px;
}

.feature-eb { display: flex; justify-content: space-between; align-items: center; }
.feature-when {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-2);
  letter-spacing: 0.04em;
}

.feature-title {
  font-family: var(--font-wordmark);
  font-size: 56px;
  font-weight: 400;
  letter-spacing: 0.01em;
  line-height: 0.95;
  text-transform: uppercase;
}
.feature-title small {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0;
  color: var(--ink-1);
  display: block;
  margin-top: 6px;
}
.feature-dim {
  font-size: 12.5px;
  color: var(--ink-1);
  max-width: 36ch;
  line-height: 1.5;
}
.feature-dim b { color: var(--ink-0); }

.feature-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding: 12px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.feature-meta div { display: flex; flex-direction: column; gap: 2px; }
.feature-meta span {
  font-size: 9px; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600;
}
.feature-meta b {
  font-size: 12.5px;
  font-weight: 600;
  font-family: var(--font-display);
}
.feature-cta { display: flex; gap: 8px; }

/* TODO */
.todo { display: flex; flex-direction: column; }
.todo li {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 4px;
  border-top: 1px solid var(--border);
}
.todo li:first-child { border-top: none; padding-top: 2px; }
.todo li > div { flex: 1; }
.todo li b { display: block; font-size: 13px; font-weight: 600; }
.todo li span { font-size: 11.5px; color: var(--ink-2); }

.td-ic {
  width: 30px; height: 30px;
  border-radius: 8px;
  display: grid; place-items: center;
  font-size: 13px;
  font-weight: 600;
  flex-shrink: 0;
  font-family: var(--font-mono);
}
.td-ic-cert { background: rgba(167,139,250,0.12); color: var(--accent-violet); }
.td-ic-pay  { background: rgba(61,220,151,0.12); color: var(--ok); }
.td-ic-msg  { background: rgba(90,200,250,0.12); color: var(--accent-aqua); }
.td-ic-med  { background: rgba(255,92,117,0.10); color: var(--danger); }
.td-ic-cyl  { background: rgba(245,165,36,0.12); color: var(--warn); }

.btn-mini {
  font-size: 11.5px;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: 6px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--ink-0);
  transition: background 120ms;
}
.btn-mini:hover {
  background: var(--accent);
  color: #02161e;
  border-color: var(--accent);
}

/* MAP */
.mini-map {
  background:
    radial-gradient(circle at 50% 50%, var(--surface), transparent 70%),
    var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px;
}
.map-svg { width: 100%; height: 200px; display: block; }
.map-legend {
  display: flex; gap: 14px; flex-wrap: wrap;
  font-size: 11px;
  color: var(--ink-1);
  margin-top: 8px;
}
.map-legend span { display: inline-flex; align-items: center; gap: 5px; }

/* SEO */
.seo { display: flex; flex-direction: column; }
.seo-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 4px;
  border-top: 1px solid var(--border);
}
.seo-row:first-child { border-top: none; padding-top: 4px; }
.seo-pos {
  width: 30px; height: 30px;
  border-radius: 8px;
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 12px; font-weight: 700;
}
.pos-top3 { background: rgba(61,220,151,0.15); color: var(--ok); }
.pos-top10 { background: rgba(90,200,250,0.15); color: var(--accent-aqua); }
.pos-top20 { background: rgba(245,165,36,0.12); color: var(--warn); }
.seo-kw b { display: block; font-size: 13px; font-weight: 600; }
.seo-kw span { font-size: 11px; color: var(--ink-2); font-family: var(--font-mono); }
.seo-trend {
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
}
.seo-trend.up { color: var(--ok); }
.seo-trend.down { color: var(--danger); }

/* MARINE */
.marine {
  padding: 22px 24px;
  background: linear-gradient(135deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--border);
  border-radius: 16px;
  position: relative;
  overflow: hidden;
}
.marine::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, transparent 0 79px, rgba(78,226,213,0.04) 79px 80px);
  pointer-events: none;
}
.marine-h { margin-bottom: 14px; position: relative; }
.marine-h h2 {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.marine-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
  position: relative;
}
.mev {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px;
  display: flex; flex-direction: column; gap: 4px;
}
.mev-mo {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-3);
  font-weight: 600;
  letter-spacing: 0.1em;
}
.mev b {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.01em;
  color: var(--ink-0);
}
.mev span:not(.mev-mo):not(.mev-tag) {
  font-size: 11px; color: var(--ink-2); margin-top: 2px;
}
.mev-now {
  background: linear-gradient(135deg, rgba(78,226,213,0.10), rgba(78,226,213,0.02));
  border-color: rgba(78,226,213,0.20);
}
.mev-now .mev-mo { color: var(--accent); }
.mev-tag {
  margin-top: 4px;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(78,226,213,0.15);
  color: var(--accent);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  align-self: flex-start;
}
.mev-dim { opacity: 0.55; }

/* Responsive */
@media (max-width: 1280px) {
  .kpis { grid-template-columns: repeat(3, 1fr); }
  .grid { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .app { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed; bottom: 0; left: 0; right: 0; top: auto;
    height: auto; width: 100%; flex-direction: row;
    padding: 0; border-right: none; border-top: 1px solid var(--border);
    z-index: 999; overflow-x: auto; overflow-y: hidden;
    gap: 0;
  }
  .brand { display: none; }
  .nav-label { display: none; }
  .side-footer { display: none; }
  .nav { flex-direction: row; gap: 0; flex: 1; overflow-x: auto; }
  .nav-item {
    flex-direction: column; gap: 0; padding: 10px 8px;
    font-size: 0; letter-spacing: 0; min-width: 40px;
    text-align: center; justify-content: center; border-radius: 0;
  }
  .nav-item .ni-ico { font-size: 18px; width: auto; }
  .nav-item.is-active::before { display: none; }
  .nav-item.is-active { background: var(--surface-2); border-top: 2px solid var(--accent); }
  .ni-badge, .ni-dot { display: none; }

  .main { padding: 14px 14px 80px; }
  .topbar { flex-wrap: wrap; gap: 8px; }
  .search { max-width: 100%; margin-left: 0; order: 10; flex: 1 1 100%; }
  .search kbd { display: none; }
  .bc { display: none; }
  .top-meta { margin-left: auto; gap: 8px; }
  .me-txt { display: none; }

  .hero { min-height: 360px; }
  .hero-inner { padding: 20px 18px 16px; }
  .hero-title { font-size: 42px; }
  .hero-sub { font-size: 10px; letter-spacing: 0.10em; }
  .hero-quote { display: none; }
  .hero-cta { flex-wrap: wrap; }
  .hero-cta .btn { padding: 10px 16px; font-size: 10px; }
  .hero-cond { grid-template-columns: 1fr !important; gap: 1px; }
  .hc { padding: 10px 14px; }
  .hc b { font-size: 24px; }
  .eb-pill, .eb-tag { font-size: 8px; padding: 4px 8px; }

  .kpis { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .kpi { padding: 12px; min-height: 100px; }
  .kpi-v { font-size: 28px; }
  .kpi-l { font-size: 8px; }
  .kpi-chips { gap: 3px; }
  .chip { font-size: 8px; padding: 2px 5px; }

  .grid { grid-template-columns: 1fr; gap: 14px; }
  .panel { padding: 14px 16px; }
  .panel-h { flex-direction: column; gap: 8px; }

  .trip { grid-template-columns: 50px 3px 1fr; gap: 8px; padding: 12px 0; }
  .trip-cap, .trip-price { display: none; }
  .trip-date b { font-size: 22px; }
  .trip-row h3 { font-size: 11px; }
  .trip-meta { font-size: 10px; gap: 8px; }

  .feature-title { font-size: 32px; }
  .feature-meta { grid-template-columns: repeat(2, 1fr); }

  .log-row { grid-template-columns: 40px 1fr auto; }
  .log-stat:nth-child(n+4) { display: none; }

  .marine-strip { grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .mev { padding: 8px; }
  .mev b { font-size: 11px; }

  .seo-row { grid-template-columns: 30px 1fr auto; }

  .modal { width: 95%; max-width: 95%; }
  .form-row { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .kpis { grid-template-columns: 1fr 1fr; }
  .hero-title { font-size: 32px; }
  .hero { min-height: 300px; }
  .marine-strip { grid-template-columns: repeat(2, 1fr); }
  .feature-title { font-size: 26px; }
  .nav-item { min-width: 48px; font-size: 7px; padding: 6px 6px; }
}
