/* ===========================================================
   GDVet sim — tema dark navy (inspirado em gdvet.com.br)
   Variáveis no topo facilitam recolorir a marca.
   =========================================================== */
:root {
  --navy-900: #0a1124;
  --navy-800: #0e1730;
  --navy-700: #141f3d;
  --navy-600: #1b2950;
  --card: #131e3a;
  --card-2: #18254a;
  --border: #25345f;
  --text: #eef2fb;
  --muted: #9aa7c7;
  --accent: #38e0b0;        /* verde-água GDVet */
  --accent-2: #2bb894;
  --accent-ink: #04201a;
  --danger: #ff5d6c;
  --warn: #ffc24b;
  --ok: #38e0b0;
  --shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  --radius: 16px;
  --radius-sm: 10px;
  --app-bg: radial-gradient(1200px 600px at 70% -10%, #16224a 0%, #0a1124 55%);
  --topbar-bg: rgba(10, 17, 36, 0.82);
  --bar-bg: rgba(14, 23, 48, 0.92);
  --input-bg: var(--navy-800);
}

/* ---------- tema claro ---------- */
:root[data-theme="light"] {
  --navy-900: #eef1f8;
  --navy-800: #ffffff;
  --navy-700: #eef2f9;
  --navy-600: #dde4f1;
  --card: #ffffff;
  --card-2: #f6f8fc;
  --border: #d6deec;
  --text: #15213c;
  --muted: #5d6b88;
  --accent: #12a07e;
  --accent-2: #0d8568;
  --accent-ink: #ffffff;
  --danger: #e23a4c;
  --warn: #e0982a;
  --ok: #12a07e;
  --shadow: 0 10px 26px rgba(21, 33, 60, 0.10);
  --app-bg: radial-gradient(1200px 600px at 70% -10%, #e9eef8 0%, #f4f7fc 55%);
  --topbar-bg: rgba(255, 255, 255, 0.85);
  --bar-bg: rgba(255, 255, 255, 0.92);
  --input-bg: #f4f7fc;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--app-bg);
  color: var(--text);
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }

/* ---------- topbar ---------- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 28px;
  background: var(--topbar-bg);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.topbar-right { display: flex; align-items: center; gap: 16px; }
.theme-toggle {
  width: 38px; height: 38px; border-radius: 999px;
  border: 1px solid var(--border); background: var(--navy-700); color: var(--text);
  font-size: 17px; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: 0.15s; line-height: 1;
}
.theme-toggle:hover { border-color: var(--accent); }
.brand { display: flex; align-items: flex-end; gap: 6px; font-weight: 800; font-size: 22px; }
.brand-logo { display: inline-flex; flex-direction: column; align-items: flex-start; line-height: 1; }
.brand-dots { display: flex; gap: 3px; margin-top: 3px; }
.brand-dots i { width: 6px; height: 6px; border-radius: 50%; display: inline-block; }
.brand-dots i.r { background: #e8443b; } .brand-dots i.y { background: #f4b400; }
.brand-dots i.g { background: #3fa34d; } .brand-dots i.b { background: #5b8fc9; }
.brand-mark { color: var(--text); letter-spacing: -0.5px; }
.brand-sub {
  color: var(--accent);
  font-weight: 700;
  font-size: 16px;
  padding: 2px 8px;
  border: 1px solid var(--accent);
  border-radius: 999px;
}
.topnav { display: flex; gap: 8px; }
.topnav a {
  padding: 8px 14px;
  border-radius: 999px;
  color: var(--muted);
  font-weight: 500;
  font-size: 14px;
  transition: 0.15s;
}
.topnav a:hover { color: var(--text); background: var(--navy-700); }
.user-chip { font-size: 12px; font-weight: 600; color: var(--muted); background: var(--navy-700); border: 1px solid var(--border); border-radius: 999px; padding: 5px 12px; white-space: nowrap; }
.user-chip .role-adm { color: var(--accent); }

/* ---------- layout ---------- */
.app { max-width: 1180px; margin: 0 auto; padding: 32px 28px 60px; }
.footer { text-align: center; color: var(--muted); font-size: 13px; padding: 24px; }

.page-head { margin-bottom: 26px; position: relative; }
/* selo "uso educacional" no canto superior direito das telas dos simuladores */
.edu-badge { position: absolute; top: 0; right: 0; max-width: 170px; text-align: center; padding: 9px 13px; border-radius: 10px;
  background: rgba(244, 180, 0, .10); border: 1px solid rgba(244, 180, 0, .5); color: #d3a000;
  font-weight: 800; font-size: 11px; line-height: 1.3; text-transform: uppercase; letter-spacing: .4px; }
[data-theme="light"] .edu-badge { color: #9a7600; }
@media (max-width: 720px) { .edu-badge { position: static; display: inline-block; margin-bottom: 10px; } }
.page-head h1 { font-size: 30px; font-weight: 800; margin: 0 0 6px; letter-spacing: -0.5px; }
.page-head p { color: var(--muted); margin: 0; max-width: 640px; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--border);
  background: var(--navy-700);
  color: var(--text);
  font-weight: 600;
  font-size: 14px;
  padding: 10px 16px;
  border-radius: 999px;
  cursor: pointer;
  transition: 0.15s;
  font-family: inherit;
}
.btn:hover { border-color: var(--accent); color: var(--text); }
.btn-accent { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.btn-accent:hover { background: var(--accent-2); border-color: var(--accent-2); }
.btn-ghost { background: transparent; }
.btn-danger { color: var(--danger); border-color: transparent; background: transparent; }
.btn-danger:hover { border-color: var(--danger); }
.btn-sm { padding: 6px 12px; font-size: 13px; }
.btn-block { width: 100%; justify-content: center; }

/* ---------- case grid (menu) ---------- */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
  gap: 20px;
}
.case-card {
  background: linear-gradient(180deg, var(--card-2), var(--card));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: 0.18s;
}
.case-card:hover { transform: translateY(-3px); border-color: var(--accent); }
.case-card h3 { margin: 0; font-size: 20px; font-weight: 700; }
.case-card .desc { color: var(--muted); font-size: 14px; line-height: 1.5; flex: 1; }
.case-card .chip {
  align-self: flex-start;
  font-size: 12px;
  color: var(--accent);
  border: 1px solid var(--accent);
  border-radius: 999px;
  padding: 2px 10px;
}
.case-actions { display: flex; gap: 10px; }
.case-actions .btn { flex: 1; justify-content: center; }
.card-foot { display: flex; gap: 10px; border-top: 1px solid var(--border); padding-top: 12px; }
.card-foot .btn { flex: 1; justify-content: center; }

/* ---------- collapsible boxes ---------- */
.box {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--card);
  margin-bottom: 12px;
  overflow: hidden;
}
.box > summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 18px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  user-select: none;
}
.box > summary::-webkit-details-marker { display: none; }
.box > summary .tag { font-size: 12px; color: var(--muted); font-weight: 500; }
.box[open] > summary { border-bottom: 1px solid var(--border); color: var(--accent); }
.box .box-body { padding: 16px 18px; line-height: 1.6; color: var(--text); }
.box .box-body img { max-width: 100%; border-radius: 8px; margin-top: 10px; border: 1px solid var(--border); }
.box .box-body.muted { color: var(--muted); }

/* dossiê: caixa grande com subcaixas */
.box.dossier { margin-bottom: 22px; box-shadow: var(--shadow); }
.box.dossier > summary { font-size: 17px; padding: 16px 20px; }
.box.dossier > .box-body { background: var(--card-2); padding: 14px 16px 4px; }
.box.dossier .box { background: var(--navy-800); }

/* ---------- conduction layout ---------- */
.conduct-bar {
  position: sticky;
  top: 64px;
  z-index: 30;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  background: var(--bar-bg);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 18px;
  margin-bottom: 22px;
}
.conduct-bar .title { font-weight: 700; font-size: 17px; margin-right: auto; }
.mode-badge {
  font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: 999px;
  border: 1px solid var(--accent); color: var(--accent);
}
.clock {
  text-align: center;
  background: var(--navy-800);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 6px 14px;
  min-width: 92px;
}
.clock .label { display: block; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); }
.clock .time { font-size: 22px; font-weight: 800; font-variant-numeric: tabular-nums; }
.clock.step .time { color: var(--accent); }

.cols { display: grid; grid-template-columns: 1fr 380px; gap: 22px; align-items: start; }
@media (max-width: 980px) { .cols { grid-template-columns: 1fr; } }

.panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  margin-bottom: 20px;
}
.panel h2 { margin: 0 0 14px; font-size: 16px; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); }

/* steps list */
.steps { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.step-pill {
  font-size: 13px; padding: 6px 12px; border-radius: 999px;
  border: 1px solid var(--border); color: var(--muted); background: var(--navy-800);
}
.step-pill.active { border-color: var(--accent); color: var(--accent); }
.step-pill.done { color: var(--text); border-color: var(--accent-2); }

/* checklist item */
.cl-item { padding: 14px 0; border-bottom: 1px solid var(--border); }
.cl-item:last-child { border-bottom: none; }
.cl-item .cl-text { margin-bottom: 10px; line-height: 1.5; }
.scale { display: flex; gap: 8px; flex-wrap: wrap; }
.scale button {
  border: 1px solid var(--border); background: var(--navy-800); color: var(--muted);
  border-radius: 8px; padding: 7px 14px; cursor: pointer; font-weight: 600; font-size: 13px; font-family: inherit;
  transition: 0.12s;
}
.scale button:hover { color: var(--text); }
.scale button.sel-0 { background: var(--danger); color: #fff; border-color: var(--danger); }
.scale button.sel-5 { background: var(--warn); color: #3a2b00; border-color: var(--warn); }
.scale button.sel-10 { background: var(--ok); color: var(--accent-ink); border-color: var(--ok); }
.scale button.sel-na { background: var(--navy-600); color: var(--text); border-color: var(--muted); }

/* monitor */
.monitor { background: #07101f; border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.monitor.pcr { border-color: var(--danger); box-shadow: 0 0 0 2px rgba(255,93,108,0.25); }
.vit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 12px; }
.vit {
  background: #0b1830; border: 1px solid var(--border); border-radius: 10px; padding: 8px 12px;
}
.vit .vk { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); }
.vit input {
  width: 100%; background: transparent; border: none; color: var(--accent);
  font-size: 19px; font-weight: 800; font-family: inherit; padding: 2px 0;
}
.vit input:focus { outline: none; }
.preset-row { display: flex; gap: 8px; flex-wrap: wrap; }

/* score summary */
.score-box { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; }
.score-num { font-size: 40px; font-weight: 800; color: var(--accent); line-height: 1; }
.score-box .sub { color: var(--muted); font-size: 13px; }

/* ---------- forms (editor) ---------- */
.form-grid { display: grid; gap: 16px; }
.field label { display: block; font-size: 13px; color: var(--muted); margin-bottom: 6px; font-weight: 600; }
.field input[type="text"], .field input[type="number"], .field textarea, .field select {
  width: 100%; background: var(--navy-800); border: 1px solid var(--border); color: var(--text);
  border-radius: 10px; padding: 10px 12px; font-family: inherit; font-size: 14px;
}
.field textarea { min-height: 80px; resize: vertical; line-height: 1.5; }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--accent); }
.row { display: flex; gap: 12px; align-items: flex-end; }
.row .field { flex: 1; }
.repeat-item {
  border: 1px solid var(--border); border-radius: 12px; padding: 14px; margin-bottom: 12px; background: var(--navy-800);
}
.repeat-item .row { margin-bottom: 10px; }
.thumb { max-height: 80px; border-radius: 8px; border: 1px solid var(--border); margin-top: 8px; }

.toolbar { display: flex; gap: 10px; flex-wrap: wrap; margin: 22px 0; }
.toolbar.end { justify-content: flex-end; }

.inline-note { color: var(--muted); font-size: 13px; margin: 6px 0 16px; }
.divider { height: 1px; background: var(--border); margin: 26px 0; }
.section-title { font-size: 14px; text-transform: uppercase; letter-spacing: 1px; color: var(--accent); margin: 0 0 4px; font-weight: 700; }

/* radios for global rating */
.radios { display: flex; gap: 10px; flex-wrap: wrap; }
.radios label {
  border: 1px solid var(--border); border-radius: 999px; padding: 8px 16px; cursor: pointer; color: var(--muted); font-weight: 600; font-size: 14px;
}
.radios input { display: none; }
.radios input:checked + span { color: var(--accent-ink); }
.radios label:has(input:checked) { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }

/* history table */
.htable { width: 100%; border-collapse: collapse; }
.htable th, .htable td { text-align: left; padding: 12px 10px; border-bottom: 1px solid var(--border); font-size: 14px; }
.htable th { color: var(--muted); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; }

.empty { text-align: center; color: var(--muted); padding: 60px 20px; }
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: var(--accent); color: var(--accent-ink); padding: 12px 22px; border-radius: 999px;
  font-weight: 700; box-shadow: var(--shadow); z-index: 200; opacity: 0; transition: 0.2s; pointer-events: none;
}
.toast.show { opacity: 1; }

/* ---------- banner do simulador de monitor (menu) ---------- */
.mon-banner {
  display: flex; align-items: center; gap: 16px; justify-content: space-between;
  background: linear-gradient(110deg, #0b2030, var(--card));
  border: 1px solid var(--border); border-left: 4px solid var(--accent);
  border-radius: var(--radius); padding: 18px 22px; margin-bottom: 22px; box-shadow: var(--shadow);
  transition: 0.18s;
}
.mon-banner:hover { border-color: var(--accent); transform: translateY(-2px); }
.mon-banner-txt { display: flex; flex-direction: column; gap: 4px; }
.mon-banner-txt strong { font-size: 18px; }
.mon-banner-txt span { color: var(--muted); font-size: 14px; }

/* ---------- monitor multiparâmetros ---------- */
.mon {
  display: flex; flex-direction: column;
  background: linear-gradient(180deg, #161b26, #0e121b);
  border: 1px solid #2b3346;
  border-radius: 16px;
  padding: 0; overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03), 0 6px 24px rgba(0,0,0,.4);
}

/* moldura (bezel) do monitor */
.mon-bezel { background: linear-gradient(180deg, #11151e, #0b0e15); }
.mon-bezel-top { padding: 10px 14px; border-bottom: 1px solid #232c40; display: flex; flex-direction: column; gap: 8px; }
.mon-bz-line { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.mon-bz-btns { display: inline-flex; gap: 8px; flex-wrap: wrap; }
.mon-bz-modlbl { font-size: 12px; color: var(--muted); font-weight: 700; margin-right: 2px; letter-spacing: .3px; }

.mon-body { display: flex; align-items: stretch; }
.mon-bezel-left { display: flex; flex-direction: column; gap: 12px; align-items: center; padding: 14px 8px; border-right: 1px solid #232c40; }
.mon-bezel-right { width: 268px; flex-shrink: 0; padding: 12px; border-left: 1px solid #232c40; }
.mon-waves { flex: 1; min-width: 0; background: #05080f; padding: 12px; display: flex; flex-direction: column; gap: 10px; }

/* borda esquerda — símbolos com legenda (Alarme / Beep / Congelar) */
.mon-side { background: transparent; border: 1px solid transparent; color: #cdd6ea; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 3px; width: 58px; padding: 7px 4px; border-radius: 10px; font-family: inherit; }
.mon-side .ic { font-size: 20px; line-height: 1; }
.mon-side .lb { font-size: 10px; font-weight: 600; text-align: center; line-height: 1.15; }

/* filtros de busca dos casos */
.case-filters { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.case-filters input, .case-filters select { background: var(--navy-800, var(--card-bg)); border: 1px solid var(--border); color: var(--text); border-radius: 9px; padding: 9px 12px; font-family: inherit; font-size: 14px; }
.case-filters #fq { flex: 1; min-width: 220px; }
.case-filters input:focus, .case-filters select:focus { outline: none; border-color: var(--accent); }
.case-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.chip-sp { background: color-mix(in srgb, var(--accent) 22%, transparent); color: var(--accent); }

/* ===== Administração ===== */
.admin-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.admin-note { color: var(--muted); font-size: 12px; margin: 12px 2px 0; }
.tag-warn { display: inline-block; font-size: 11px; padding: 1px 7px; border-radius: 999px; background: rgba(245, 176, 66, .14); color: #f5b042; border: 1px solid #f5b042; }
.tag-ok { display: inline-block; font-size: 11px; padding: 1px 7px; border-radius: 999px; background: rgba(80, 200, 120, .14); color: #50c878; border: 1px solid #50c878; }
.admin-tabs { display: flex; gap: 6px; margin-bottom: 14px; }
.admin-tab { background: transparent; border: 1px solid var(--border); color: var(--muted); border-radius: 9px; padding: 7px 14px; cursor: pointer; font-family: inherit; font-size: 14px; font-weight: 600; }
.admin-tab.on { color: var(--text); border-color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, transparent); }
.row-pending { background: rgba(245, 176, 66, .06); }
.usage-filters { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.usage-filters input, .usage-filters select { background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 9px; padding: 9px 11px; font-family: inherit; font-size: 14px; }
.usage-filters input { flex: 1; min-width: 200px; }

/* ===== Minha conta ===== */
.acc-panel { max-width: 460px; }
.acc-field { margin-bottom: 14px; }
.acc-field label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 6px; font-weight: 600; }
.acc-field input { width: 100%; box-sizing: border-box; background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 10px; padding: 11px 12px; font-family: inherit; font-size: 15px; }
.acc-field input:focus { outline: none; border-color: var(--accent); }
.acc-field input:disabled { opacity: .6; }
.acc-msg { display: none; border-radius: 10px; padding: 10px 12px; font-size: 13px; margin-bottom: 14px; }
.acc-msg.err { background: rgba(255, 93, 108, .12); border: 1px solid var(--danger); color: var(--danger); }
.acc-msg.ok { background: rgba(80, 200, 120, .12); border: 1px solid #50c878; color: #50c878; }

/* ===== Tela de conta pendente ===== */
.pending-wrap { display: flex; align-items: center; justify-content: center; min-height: 60vh; padding: 24px; }
.pending-card { max-width: 460px; text-align: center; background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 18px; padding: 36px 30px; box-shadow: var(--shadow); }
.pending-emoji { font-size: 44px; margin-bottom: 8px; }
.pending-card h1 { margin: 6px 0 12px; font-size: 22px; }
.pending-card p { color: var(--text); margin: 8px 0; }
.pending-card p.muted { color: var(--muted); font-size: 13px; }
.pending-card .btn { margin-top: 18px; }

/* ===== Landing / página de vendas ===== */
.lp-body { margin: 0; }
.lp-top { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 22px; background: var(--topbar-bg); border-bottom: 1px solid var(--border); backdrop-filter: blur(8px); }
.lp-top-right { display: flex; align-items: center; gap: 10px; }
.lp { max-width: 1080px; margin: 0 auto; padding: 0 22px 60px; }
.lp-hero { text-align: center; padding: 64px 0 40px; }
.lp-hero h1 { font-size: clamp(28px, 5vw, 46px); font-weight: 800; line-height: 1.08; margin: 0 0 16px; letter-spacing: -.02em; }
.lp-lead { max-width: 720px; margin: 0 auto 26px; font-size: 18px; line-height: 1.5; color: var(--muted); }
.lp-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.lp-cta .btn { font-size: 15px; padding: 12px 22px; }
.lp-mini { margin-top: 16px; font-size: 12.5px; color: var(--muted); }
.lp-sec { padding: 40px 0; border-top: 1px solid var(--border); }
.lp-sec h2 { font-size: clamp(22px, 3.5vw, 30px); font-weight: 800; text-align: center; margin: 0 0 6px; }
.lp-sub { text-align: center; color: var(--muted); margin: 0 0 26px; }
.lp-sec > h2 + .lp-grid3, .lp-sec > h2 + .lp-media, .lp-sec > h2 + .lp-plans { margin-top: 26px; }
.lp-grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.lp-card { background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 14px; padding: 22px; }
.lp-card .lp-ic { font-size: 28px; display: block; margin-bottom: 10px; }
.lp-card h3 { margin: 0 0 6px; font-size: 17px; font-weight: 800; }
.lp-card p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.5; }
.lp-media { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.media-ph { aspect-ratio: 16/9; border: 1px dashed var(--border); border-radius: 14px; background: repeating-linear-gradient(135deg, color-mix(in srgb, var(--accent) 6%, transparent) 0 12px, transparent 12px 24px), var(--card); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: var(--muted); }
.media-ph .media-ic { font-size: 30px; opacity: .7; }
.media-ph .media-cap { font-size: 13px; font-weight: 600; }
.lp-plans { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.plan-card { position: relative; background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 16px; padding: 24px 18px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.plan-card h3 { margin: 0; font-size: 16px; font-weight: 800; }
.plan-price { display: flex; align-items: baseline; gap: 1px; }
.plan-cur { font-size: 16px; font-weight: 700; color: var(--muted); }
.plan-amt { font-size: 30px; font-weight: 800; }
.plan-per { font-size: 13px; color: var(--muted); }
.plan-note { font-size: 12.5px; color: var(--muted); margin: 0; }
.plan-card .btn { width: 100%; justify-content: center; margin-top: auto; }
.plan-best { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.plan-badge { position: absolute; top: -11px; left: 50%; transform: translateX(-50%); background: var(--accent); color: var(--accent-ink); font-size: 11px; font-weight: 800; padding: 3px 12px; border-radius: 999px; white-space: nowrap; }
.lp-inst { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; margin-top: 22px; background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 16px; padding: 22px; }
.lp-inst h3 { margin: 0 0 4px; font-size: 17px; font-weight: 800; }
.lp-inst p { margin: 0; color: var(--muted); font-size: 14px; max-width: 560px; }
@media (max-width: 860px) { .lp-grid3, .lp-plans { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .lp-grid3, .lp-plans, .lp-media { grid-template-columns: 1fr; } }

/* seletor de idioma (bandeiras) */
.lang-flags { display: inline-flex; gap: 2px; }
.lang-flags button { background: transparent; border: 1px solid transparent; border-radius: 7px; line-height: 0; padding: 4px 5px; cursor: pointer; opacity: .55; filter: grayscale(.4); }
.lang-flags button .flag { display: block; width: 22px; height: 15px; background-size: 100% 100%; background-repeat: no-repeat; border-radius: 2px; box-shadow: 0 0 0 1px rgba(0, 0, 0, .15); }
.lang-flags button:hover { opacity: .85; }
.lang-flags button.on { opacity: 1; filter: none; border-color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, transparent); }

/* leitura em voz alta (TTS) */
.tts-ctl { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.tts-lbl { font-size: 13px; font-weight: 700; color: var(--muted); }
.tts-voice { background: var(--navy-700, var(--card-2)); border: 1px solid var(--border); color: var(--muted); font-family: inherit; font-weight: 700; font-size: 12px; padding: 5px 12px; border-radius: 999px; cursor: pointer; }
.tts-voice.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.tts-stop { background: transparent; border: 1px solid var(--border); color: var(--muted); font-family: inherit; font-size: 12px; padding: 5px 10px; border-radius: 8px; cursor: pointer; }
.box > summary .tts-btn { margin-left: auto; background: transparent; border: 1px solid var(--border); color: var(--text); font-size: 13px; line-height: 1; padding: 3px 8px; border-radius: 7px; cursor: pointer; }
.box > summary .tts-btn.on { background: var(--accent); border-color: var(--accent); }
.box > summary:has(.tts-btn), .box > summary .dsum-t { display: inline; }
.box > summary:has(.tts-btn) { display: flex; align-items: center; gap: 8px; }

/* frase educacional abaixo da descrição (substitui o box flutuante) */
.edu-line { color: var(--warn, #f4b400); font-size: 12.5px; font-weight: 700; margin-top: 6px; }

/* editor: abas de simulador + lista de presets */
.sim-tabs { display: flex; gap: 6px; margin-bottom: 12px; }
.sim-tab { background: var(--navy-700); border: 1px solid var(--border); color: var(--muted); font-family: inherit; font-weight: 700; font-size: 13px; padding: 8px 16px; border-radius: 9px; cursor: pointer; }
.sim-tab.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.sim-preset-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.sim-preset-row { display: flex; align-items: center; gap: 6px; }
.sim-preset-row input { flex: 1; background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 8px; padding: 7px 10px; font-family: inherit; font-size: 13px; }
.sim-preset-actions { display: flex; gap: 8px; align-items: center; margin-bottom: 14px; }
.sim-preset-actions input { flex: 1; background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 8px; padding: 8px 10px; font-family: inherit; font-size: 13px; }
.sim-embed { border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }

/* condução: botões de abrir simuladores */
.sim-launch { display: flex; flex-direction: column; gap: 8px; }
.sim-launch .btn { width: 100%; justify-content: center; }
.dossier-h { margin: 14px 0 6px; font-size: 14px; font-weight: 800; color: var(--accent); }

/* janela de execução (simulador standalone aberto em nova aba) */
body.run-mode #topbar { display: none; }
body.run-mode #app, body.run-mode.app { max-width: none; padding: 0; }
.run-bar { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; padding: 10px 16px; background: var(--topbar-bg); border-bottom: 1px solid var(--border); backdrop-filter: blur(8px); }
.run-title { font-weight: 800; font-size: 15px; }
.run-presets { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.run-plabel { color: var(--muted); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; }
.run-trans { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; padding-left: 14px; border-left: 1px solid var(--border); }
.run-trans select { background: var(--navy-800, var(--card-bg)); border: 1px solid var(--border); color: var(--text); border-radius: 7px; padding: 5px 8px; font-family: inherit; font-size: 13px; }
.run-trans input { width: 56px; background: var(--navy-800, var(--card-bg)); border: 1px solid var(--border); color: var(--text); border-radius: 7px; padding: 5px 6px; font-family: inherit; font-size: 13px; }
.run-tu { color: var(--muted); font-size: 12px; }
.run-tstatus { font-size: 12px; font-weight: 700; color: var(--accent); min-width: 70px; }
.run-sim { padding: 14px 16px; }

/* linha dividida (dois traçados lado a lado, 50% cada) */
.lane-row { display: flex; gap: 10px; }
.lane-row .mon-lane { flex: 1; min-width: 0; }
.disp-split { background: var(--navy-700); border: 1px solid var(--border); color: var(--muted); font-family: inherit; font-size: 12px; font-weight: 700; padding: 5px 12px; border-radius: 999px; cursor: pointer; min-width: 92px; }
.disp-split.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.mon-side:hover { background: rgba(255,255,255,.07); }
.mon-side.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* borda superior 2ª linha — ativar/desativar módulos */
.mon-mod { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.14); color: #8aa0bf;
  font-family: inherit; font-size: 12px; font-weight: 700; padding: 5px 13px; border-radius: 999px; cursor: pointer; }
.mon-mod::before { content: '⏻'; margin-right: 5px; opacity: .85; }
.mon-mod:hover { border-color: var(--accent); }
.mon-mod.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* popup de ajuste de cores */
.mon-colors { display: flex; flex-direction: column; gap: 9px; }
.mon-color-row { display: flex; align-items: center; gap: 10px; }
.mon-color-row .lbl { width: 120px; font-size: 13px; font-weight: 600; color: var(--text); }
.mon-sws { display: inline-flex; gap: 6px; }
.mon-sw { width: 26px; height: 26px; border-radius: 7px; border: 2px solid rgba(255,255,255,.15); cursor: pointer; padding: 0; transition: transform .1s; }
.mon-sw:hover { transform: scale(1.08); }
.mon-sw.sel { border-color: #fff; box-shadow: 0 0 0 2px rgba(255,255,255,.25); }

@media (max-width: 900px) {
  .mon-body { flex-direction: column; }
  .mon-bezel-left { flex-direction: row; border-right: none; border-bottom: 1px solid #232c40; }
  .mon-bezel-right { width: auto; border-left: none; border-top: 1px solid #232c40; }
}

/* barra de ferramentas */
.mon-tools { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.mon-tb {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.14); color: #d6deea;
  font-family: inherit; font-size: 13px; font-weight: 600; padding: 7px 13px; border-radius: 999px; cursor: pointer;
}
.mon-tb:hover { border-color: var(--accent); }
.mon-tb.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.mon-tb b { font-weight: 800; }
.mon-tb.preset { font-size: 12px; }
.mon-presets { display: inline-flex; flex-wrap: wrap; gap: 8px; margin-left: auto; }
.mon-grp { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--muted); border: 1px solid var(--border); border-radius: 999px; padding: 3px 10px 3px 12px; }
.mon-grp .mon-tb { padding: 4px 9px; font-size: 12px; }

/* logo GDVet no canto */
.mon-logo { display: inline-flex; align-items: center; }
.mon-logo img { height: 22px; display: block; }
.mon-logo-fb { display: none; align-items: center; gap: 4px; }
.mon-logo-fb .d { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.mon-logo-fb .d.r { background: #e8443b; } .mon-logo-fb .d.y { background: #f4b400; }
.mon-logo-fb .d.g { background: #3fa34d; } .mon-logo-fb .d.b { background: #5b8fc9; }
.mon-logo-fb b { color: #fff; font-weight: 800; margin-left: 5px; letter-spacing: -.3px; }

/* overlay "Afastar!" do desfibrilador */
.mon { position: relative; }
.mon-flash { position: absolute; inset: 0; z-index: 40; display: none; align-items: center; justify-content: center;
  background: rgba(255,93,108,.16); color: #fff; font-size: 52px; font-weight: 800; letter-spacing: 2px;
  text-shadow: 0 0 18px rgba(255,93,108,.95); border-radius: var(--radius); pointer-events: none; }
.mon-flash.show { display: flex; }

/* caixa desfibrilador / cardioversor */
.defib { border-top: 1px dashed var(--border); margin-top: 2px; padding-top: 10px; }
.defib-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.defib-controls { display: none; flex-wrap: wrap; align-items: center; gap: 10px; }
.defib.open .defib-controls { display: inline-flex; }
.defib-charge { background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 8px; padding: 5px 8px; font-family: inherit; font-size: 12px; }
.defib-act { border-color: var(--danger); color: var(--danger); }
.defib-act:hover { background: var(--danger); color: #fff; }
.mon-pop-sep { height: 1px; background: var(--border); margin: 4px 0 2px; }

.mon-waves { display: flex; flex-direction: column; gap: 10px; }

/* PVC só aparece quando ativada (PANI fica sempre visível) */
.mon:not(.pvc-on) .lane-pvc, .mon:not(.pvc-on) .ptile[data-tile="cvp"] { display: none; }
.ptile.pani .pv { font-size: 24px; }
.ptile.pani.pani-err .pv { color: var(--danger); font-size: 22px; }
.mon-pop-row { display: flex; gap: 8px; margin-top: 4px; }

/* modo compacto (embutido na condução) */
.mon.compact .mon-body { flex-direction: column; }
.mon.compact .mon-bezel-left { flex-direction: row; border-right: none; border-bottom: 1px solid #232c40; }
.mon.compact .mon-bezel-right { width: auto; border-left: none; border-top: 1px solid #232c40; }
.mon.compact .mon-canvas { height: 72px; }
.mon.compact .mon-params { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.mon.compact .ptile .pv { font-size: 26px; }
.mon.compact .ptile.abp .pv, .mon.compact .ptile.temp .pv { font-size: 20px; }

/* alarme: pulso suave SEMPRE em vermelho, um pouco mais rápido (sombreamento bem leve) */
.ptile.alarm { animation: monAlarm 1.5s ease-in-out infinite; border-color: var(--danger) !important; }
@keyframes monAlarm {
  0%, 100% { box-shadow: 0 0 0 0 transparent; }
  50% { box-shadow: 0 0 16px -1px var(--danger), inset 0 0 26px -6px var(--danger); }
}

/* controle de alarme no painel direito */
.mon-alarm-ctrl { display: flex; gap: 6px; align-items: stretch; margin-bottom: 2px; }
.mon-al-btn { flex: 1; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.14); color: #d6deea; font-family: inherit; font-weight: 700; font-size: 12px; padding: 6px 10px; border-radius: 8px; cursor: pointer; }
.mon-al-btn.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.mon-al-btn b { font-weight: 800; }
.mon-al-cfg { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.14); color: #d6deea; font-size: 14px; padding: 6px 10px; border-radius: 8px; cursor: pointer; }
.mon-al-btn:hover, .mon-al-cfg:hover { border-color: var(--accent); }

/* popup "Ajustes do display" */
.disp-sec { margin-bottom: 16px; }
.disp-sec h4 { margin: 0 0 9px; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--accent); font-weight: 800; }
.disp-mods { display: flex; flex-direction: column; gap: 6px; }
.disp-row { display: flex; align-items: center; gap: 10px; }
.disp-ord { display: inline-flex; gap: 2px; width: 52px; }
.disp-arr { background: var(--navy-700); border: 1px solid var(--border); color: var(--text); border-radius: 6px; width: 24px; height: 24px; cursor: pointer; font-size: 11px; padding: 0; line-height: 1; }
.disp-arr:disabled { opacity: .3; cursor: default; }
.disp-arr:hover:not(:disabled) { border-color: var(--accent); }
.disp-name { flex: 1; font-size: 14px; color: var(--text); font-weight: 600; }
.disp-mod { background: var(--navy-700); border: 1px solid var(--border); color: var(--muted); font-family: inherit; font-size: 12px; font-weight: 700; padding: 5px 12px; border-radius: 999px; cursor: pointer; min-width: 92px; }
.disp-mod.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* popup de limites de alarme */
.al-cfg { display: flex; flex-direction: column; gap: 8px; }
.al-row { display: flex; align-items: center; gap: 10px; }
.al-lbl { width: 120px; font-size: 13px; font-weight: 600; color: var(--text); }
.al-row label { font-size: 12px; color: var(--muted); display: inline-flex; align-items: center; gap: 4px; }
.al-row input { width: 72px; background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 7px; padding: 6px; font-family: inherit; font-size: 13px; }
.al-row input:focus { outline: none; border-color: var(--accent); }
.mon-lane { background: #000; border: 1px solid #1d2740; border-radius: 10px; overflow: hidden; }
.lane-head { display: flex; align-items: center; justify-content: space-between; padding: 6px 10px 2px; }
.lane-name { font-weight: 800; font-size: 14px; letter-spacing: .5px; }
.lane-sel { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); color: #cdd6ea; font-family: inherit; font-size: 12px; padding: 3px 9px; border-radius: 999px; cursor: pointer; }
.lane-sel:hover { border-color: currentColor; }
.lane-sel b { color: #fff; font-weight: 700; }
.mon-canvas { display: block; width: 100%; height: 120px; }

.mon-params { display: flex; flex-direction: column; gap: 10px; }
.ptile {
  text-align: left; background: #0a1020; border: 1px solid #1d2740; border-left: 4px solid var(--c);
  border-radius: 10px; padding: 8px 12px; cursor: default; display: grid; grid-template-columns: 1fr auto; align-items: baseline; gap: 2px 8px; font-family: inherit;
}
.lane-sel.ro { background: none; border: none; cursor: default; padding: 2px 0; color: inherit; }

/* seletores de cor por parâmetro */
.ch-color { -webkit-appearance: none; appearance: none; width: 24px; height: 18px; border: 1px solid var(--border); border-radius: 5px; background: none; padding: 0; cursor: pointer; }
.ch-color::-webkit-color-swatch-wrapper { padding: 1px; }
.ch-color::-webkit-color-swatch { border: none; border-radius: 3px; }
.ch-color::-moz-color-swatch { border: none; border-radius: 3px; }
.ptile { position: relative; }
.ch-color.tile-color { position: absolute; top: 8px; right: 8px; }
.lane-ctrls { display: inline-flex; align-items: center; gap: 6px; }
.lane-speed, .lane-amp, .lane-scale { background: rgba(255,255,255,.06); border: 1px solid var(--border); color: #cdd6ea; font-family: inherit; font-size: 11px; border-radius: 6px; padding: 2px 4px; cursor: pointer; }
.lane-speed:focus, .lane-amp:focus, .lane-scale:focus { outline: none; border-color: var(--accent); }
.lane-speed option, .lane-amp option, .lane-scale option { background: var(--navy-800); color: var(--text); }
.ptile .pl { color: var(--muted); font-size: 12px; font-weight: 600; grid-column: 1 / -1; }
.ptile .pv { color: var(--c); font-size: 38px; font-weight: 800; line-height: 1; font-variant-numeric: tabular-nums; }
.ptile .pu { color: var(--muted); font-size: 12px; }
.ptile.abp .pv, .ptile.temp .pv { font-size: 30px; }
.ptile.co2v .pv { font-size: 27px; display: flex; align-items: baseline; gap: 3px; flex-wrap: nowrap; white-space: nowrap; }
.ptile.co2v .pv-ins { font-size: .5em; opacity: .8; font-weight: 700; }
.ptile.co2v .pu-in { color: var(--muted); font-size: 11px; font-weight: 600; margin-left: 1px; }
.ptile.co2v .co2-rr { display: inline-flex; align-items: baseline; gap: 2px; margin-left: 8px; color: var(--c); font-size: 21px; }
.mon.compact .ptile.co2v .pv { font-size: 20px; }

/* botão "Ativar / medir PANI" no painel direito */
.mon-pani-btn { width: 100%; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.14); color: #d6deea; font-family: inherit; font-weight: 700; font-size: 12px; padding: 7px 10px; border-radius: 8px; cursor: pointer; margin-bottom: 2px; }
.mon-pani-btn:hover { border-color: var(--accent); }
.mon-pani-btn:active { background: var(--accent); color: var(--accent-ink); }

.mon-menu, .mon-pop {
  position: fixed; z-index: 300; background: var(--card-2); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: var(--shadow); padding: 6px; max-height: 60vh; overflow: auto; width: 260px;
}
.mon-mi { padding: 8px 10px; border-radius: 7px; cursor: pointer; font-size: 13px; color: var(--text); }
.mon-mi:hover { background: var(--navy-700); }
.mon-mi.sel { color: var(--accent); font-weight: 700; }
.mon-pop label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 8px; font-weight: 600; }
.mon-pop input { width: 100%; margin-top: 4px; background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 8px; padding: 8px; font-family: inherit; font-size: 15px; }
.mon-pop input:focus { outline: none; border-color: var(--accent); }

/* ---------- VMsim (ventilação mecânica) ---------- */
.vm { display: flex; flex-direction: column; gap: 12px; background: #05080f; border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; position: relative; }
.vm-top { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; }
.vm-tabs { display: inline-flex; gap: 6px; margin-right: auto; }
.vm-tab { background: var(--navy-700); border: 1px solid var(--border); color: var(--muted); font-family: inherit; font-weight: 700; font-size: 14px; padding: 8px 18px; border-radius: 10px; cursor: pointer; }
.vm-tab:hover { border-color: var(--accent); color: var(--text); }
.vm-tab.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.vm-grid { display: grid; grid-template-columns: 1fr 250px; gap: 14px; }
@media (max-width: 900px) { .vm-grid { grid-template-columns: 1fr; } }
.vm-waves { display: flex; flex-direction: column; gap: 10px; }
.vm-lane { background: #000; border: 1px solid #1d2740; border-radius: 10px; overflow: hidden; }
.vm-lane-head { font-weight: 800; font-size: 14px; padding: 6px 10px 2px; letter-spacing: .3px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.vm-canvas { display: block; width: 100%; height: 116px; }
.vm-mon { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; align-content: start; }
.vm-loops { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 700px) { .vm-loops { grid-template-columns: 1fr; } }
.vm-loop { background: #000; border: 1px solid #1d2740; border-radius: 10px; overflow: hidden; }
.vm-loop-head { font-weight: 800; font-size: 13px; padding: 6px 10px 2px; }
.vm-loop-ax { color: var(--muted); font-weight: 500; font-size: 11px; }
.vm-loopcv { display: block; width: 100%; height: 200px; }
/* linha inferior: capnograma (estreito) + loops, todos na mesma altura */
.vm-bottom { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-top: 12px; align-items: stretch; }
@media (max-width: 820px) { .vm-bottom { grid-template-columns: 1fr; } }
.vm-bottom .vm-canvas { height: 150px; }
.vm-bottom .vm-loopcv { height: 150px; }
/* seletor de modo ventilatório (barra inferior) */
.vm-dials .vm-readout, .vm-dials .vm-modebox { align-self: center; }
.vm-modebox { background: var(--navy-800); border: 1px solid var(--accent); border-radius: 10px; padding: 6px 14px; display: flex; flex-direction: column; justify-content: center; cursor: pointer; font-family: inherit; }
.vm-modebox .vm-pl { font-size: 11px; color: var(--muted); font-weight: 600; }
.vm-modebox .vm-pv { font-size: 18px; font-weight: 800; color: var(--accent); }
.vm-modemenu { position: fixed; background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 6px; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 4px; z-index: 60; }
.vm-modeopt { padding: 9px 18px; border-radius: 8px; border: 1px solid var(--border); background: var(--navy-700); color: var(--text); font-family: inherit; font-weight: 700; font-size: 14px; cursor: pointer; text-align: left; }
.vm-modeopt:hover { border-color: var(--accent); }
.vm-modeopt.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
/* dials rotativos (estilo ventilador) — painel horizontal único, sem caixa por dial */
#vmParams { display: flex; flex-direction: column; gap: 10px; }
.vm-dials-hint { font-size: 11px; color: var(--muted); }
.vm-dials-hint b { color: var(--accent); }
.vm-dials { display: flex; flex-wrap: wrap; gap: 4px 8px; align-items: flex-start; background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 12px; padding: 10px 12px; }
.vm-boxes { display: flex; gap: 8px; flex-wrap: wrap; align-items: stretch; }
.vm-dial { position: relative; background: none; border: none; padding: 0 4px 2px; display: flex; flex-direction: column; align-items: center; user-select: none; width: 92px; }
.vm-dial-svg { width: 78px; height: 78px; touch-action: none; cursor: grab; }
.vm-dial.drag .vm-dial-svg { cursor: grabbing; }
.vm-dial-track { fill: none; stroke: var(--navy-800); stroke-width: 8; }
.vm-dial-arc { fill: none; stroke: var(--accent); stroke-width: 8; stroke-linecap: round; }
.vm-dial-hub { fill: var(--navy-700); stroke: var(--border); stroke-width: 1; }
.vm-dial-ind { stroke: var(--accent); stroke-width: 4; stroke-linecap: round; }
.vm-dial-c { position: absolute; left: 0; right: 0; top: 0; height: 78px; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.vm-dial-val { font-size: 19px; font-weight: 800; font-variant-numeric: tabular-nums; color: var(--text); }
.vm-dial-lbl { margin-top: 2px; font-size: 10px; color: var(--muted); font-weight: 600; text-align: center; line-height: 1.12; }
/* estado "pendente" (girou mas ainda não confirmou) — em âmbar até clicar para confirmar */
.vm-dial.pending .vm-dial-arc, .vm-dial.pending .vm-dial-ind { stroke: #f4b400; }
.vm-dial.pending .vm-dial-val { color: #f4b400; }
.vm-dial.pending .vm-dial-svg { filter: drop-shadow(0 0 3px rgba(244, 180, 0, .7)); }
.vm-readout { background: var(--navy-800); border: 1px dashed var(--border); border-radius: 10px; padding: 6px 12px; display: flex; flex-direction: column; justify-content: center; min-width: 84px; }
.vm-readout .vm-pl { font-size: 11px; color: var(--muted); font-weight: 600; }
.vm-readout .vm-pv { font-size: 17px; font-weight: 800; font-variant-numeric: tabular-nums; }
/* select de escala no cabeçalho da curva + chips de exibição */
.vm-scale { background: rgba(255,255,255,.06); border: 1px solid var(--border); color: #cdd6ea; font-family: inherit; font-size: 11px; border-radius: 6px; padding: 1px 4px; cursor: pointer; }
.vm-scale:focus { outline: none; border-color: var(--accent); }
.vm-scale option { background: var(--navy-800); color: var(--text); }
.vm-show-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 8px; }
.vm-chip { padding: 12px 10px; border-radius: 10px; border: 1px solid var(--border); background: var(--navy-700); color: var(--muted); font-family: inherit; font-weight: 700; font-size: 13px; cursor: pointer; }
.vm-chip.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
/* painel do paciente / mecânica pulmonar (estilo C6) */
.vm-section-h { margin: 18px 2px 0; font-weight: 800; font-size: 15px; color: var(--text); }
.vm-patient { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 12px; margin-top: 10px; }
.vm-pcard { background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; }
.vm-pcard-h { font-size: 11px; text-transform: uppercase; letter-spacing: .7px; color: var(--accent); font-weight: 800; margin-bottom: 10px; }
.vm-seg-row { display: flex; gap: 6px; margin-bottom: 8px; }
.vm-seg-row:last-child { margin-bottom: 0; }
.vm-seg { flex: 1; padding: 8px 6px; border-radius: 8px; border: 1px solid var(--border); background: var(--navy-700); color: var(--muted); font-family: inherit; font-weight: 700; font-size: 12px; cursor: pointer; transition: .12s; }
.vm-seg:hover { color: var(--text); }
.vm-seg.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.vm-stepper { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.vm-stepper:last-child { margin-bottom: 0; }
.vm-step-l { font-size: 12px; color: var(--muted); min-width: 86px; }
.vm-step-b { width: 30px; height: 30px; border-radius: 8px; border: 1px solid var(--border); background: var(--navy-700); color: var(--text); font-size: 17px; font-weight: 700; cursor: pointer; line-height: 1; }
.vm-step-b:hover { border-color: var(--accent); color: var(--accent); }
.vm-step-v { min-width: 56px; text-align: center; font-weight: 800; font-size: 15px; font-variant-numeric: tabular-nums; }
.vm-step-u, .vm-ibw { font-size: 11px; color: var(--muted); }
.vm-ibw { margin-left: auto; font-weight: 700; color: var(--text); }
/* pausa inspiratória (badge) */
.vm-hold-badge { display: none; margin: 10px 0 0; padding: 8px 12px; border-radius: 10px; background: rgba(56, 224, 176, .12); border: 1px solid var(--accent); color: var(--text); font-size: 13px; }
.vm-hold-badge.show { display: block; }
.vm-hold-badge b { color: var(--accent); }
/* modais (Monitoramento / Hemogasometria) */
.vm-modal { position: fixed; inset: 0; background: rgba(4, 8, 20, .55); backdrop-filter: blur(3px); display: none; align-items: center; justify-content: center; z-index: 60; padding: 20px; }
.vm-modal.show { display: flex; }
.vm-modal-card { background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow); width: min(900px, 96vw); max-height: 90vh; overflow: auto; }
.vm-modal-h { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--border); font-weight: 800; font-size: 16px; position: sticky; top: 0; background: var(--card-2); }
.vm-modal-x { width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--border); background: var(--navy-700); color: var(--text); cursor: pointer; font-size: 13px; }
.vm-modal-x:hover { border-color: var(--accent); }
.vm-modal-body { padding: 16px 18px; }
.vm-mg { margin-bottom: 16px; }
.vm-mg:last-child { margin-bottom: 0; }
.vm-mg-h { font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--accent); font-weight: 800; margin-bottom: 8px; }
.vm-mg-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(118px, 1fr)); gap: 8px; }
.vm-mcell { background: var(--navy-800); border: 1px solid var(--border); border-radius: 10px; padding: 8px 10px; display: flex; flex-direction: column; }
.vm-mc-v { font-size: 22px; font-weight: 800; font-variant-numeric: tabular-nums; line-height: 1.1; }
.vm-mc-l { font-size: 11px; color: var(--muted); font-weight: 600; margin-top: 2px; }
.vm-mc-u { font-size: 10px; color: var(--muted); }
.vm-hemo { width: 100%; border-collapse: collapse; margin-bottom: 14px; }
.vm-hemo td { padding: 9px 10px; border-bottom: 1px solid var(--border); font-size: 15px; }
.vm-hemo td.v { font-weight: 800; text-align: right; font-variant-numeric: tabular-nums; }
.vm-hemo td.u { color: var(--muted); font-size: 12px; width: 80px; }
/* log de eventos */
.log-filters { display: flex; gap: 8px; align-items: center; margin-bottom: 12px; flex-wrap: wrap; }
.log-filters .lf { padding: 6px 12px; border-radius: 999px; border: 1px solid var(--border); background: var(--navy-700); color: var(--muted); cursor: pointer; font-size: 13px; font-weight: 600; font-family: inherit; }
.log-filters .lf.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.log-clear { margin-left: auto; }
.log-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.log-table th { text-align: left; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .5px; padding: 6px 8px; border-bottom: 1px solid var(--border); }
.log-table td { padding: 7px 8px; border-bottom: 1px solid var(--border); vertical-align: top; }
.log-src { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; white-space: nowrap; }
.log-src.mon { background: rgba(56, 224, 176, .15); color: var(--accent); }
.log-src.vm { background: rgba(95, 208, 230, .15); color: #5fd0e6; }
.log-time { color: var(--muted); white-space: nowrap; font-variant-numeric: tabular-nums; }
.log-type { font-weight: 700; white-space: nowrap; }
.log-empty { color: var(--muted); padding: 24px; text-align: center; }
/* histórico de hemogasometria + registro do caso */
.vm-hemo-actions { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.vm-hemo-log { width: 100%; border-collapse: collapse; font-size: 13px; }
.vm-hemo-log th { text-align: right; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .4px; padding: 6px 8px; border-bottom: 1px solid var(--border); }
.vm-hemo-log td { padding: 6px 8px; border-bottom: 1px solid var(--border); text-align: right; font-variant-numeric: tabular-nums; }
.vm-hemo-log th:first-child, .vm-hemo-log td:first-child { text-align: left; }
.case-status { font-size: 13px; color: var(--muted); margin-bottom: 14px; }
.case-status b { color: var(--text); }
.case-new { display: flex; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.case-name { flex: 1; min-width: 160px; background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 9px; padding: 9px 11px; font-family: inherit; font-size: 14px; }
.case-name:focus { outline: none; border-color: var(--accent); }
.vm-params { display: flex; flex-wrap: wrap; gap: 10px; border-top: 1px solid var(--border); padding-top: 12px; }
.vm-pbox { background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 12px; padding: 8px 14px; min-width: 96px; cursor: pointer; text-align: center; display: flex; flex-direction: column; gap: 2px; font-family: inherit; }
.vm-pbox:hover { border-color: var(--accent); }
.vm-pbox .vm-pl { font-size: 11px; color: var(--muted); font-weight: 600; }
.vm-pbox .vm-pv { font-size: 22px; font-weight: 800; color: var(--text); line-height: 1; }
.vm-pbox .vm-pu { font-size: 10px; color: var(--muted); }

/* banner de ferramenta (VMsim) na home */
.tool-banner {
  display: flex; align-items: center; gap: 16px; justify-content: space-between;
  background: linear-gradient(110deg, #102a22, var(--card));
  border: 1px solid var(--border); border-left: 4px solid var(--accent);
  border-radius: var(--radius); padding: 18px 22px; margin-top: 22px; box-shadow: var(--shadow); transition: 0.18s;
}
.tool-banner:hover { border-color: var(--accent); transform: translateY(-2px); }
.tool-banner .tb-txt { display: flex; flex-direction: column; gap: 4px; }
.tool-banner .tb-txt strong { font-size: 18px; }
.tool-banner .tb-txt span { color: var(--muted); font-size: 14px; }

/* ---------- print (summary) ---------- */
@media print {
  .topbar, .footer, .no-print { display: none !important; }
  body { background: #fff; color: #000; }
  .panel, .box { border-color: #ccc; background: #fff; box-shadow: none; }
  .app { max-width: none; }
}

/* ===================== Simulador cardiovascular (Cardio) ===================== */
.cv-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.cv-species { display: inline-flex; gap: 6px; }
.cv-sp { padding: 8px 14px; border-radius: 999px; border: 1px solid var(--border); background: var(--navy-700); color: var(--muted); font-family: inherit; font-weight: 700; font-size: 13px; cursor: pointer; }
.cv-sp.on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.cv-speed { margin-left: auto; font-size: 12px; color: var(--muted); display: inline-flex; align-items: center; gap: 6px; }
.cv-speed select { background: var(--navy-800); border: 1px solid var(--border); color: var(--text); border-radius: 8px; padding: 4px 6px; font-family: inherit; }
.cv-graphs { display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 12px; }
@media (max-width: 900px) { .cv-graphs { grid-template-columns: 1fr; } }
.cv-graph, .cv-heart, .cv-circ { background: #000; border: 1px solid #1d2740; border-radius: 10px; overflow: hidden; position: relative; }
.cv-circ canvas { display: block; width: 100%; height: 360px; }
/* coração/circulação (70%) + monitor (30%) lado a lado */
.cv-bottom { display: flex; gap: 14px; margin-top: 12px; align-items: stretch; }
.cv-bottom .cv-circ { flex: 0 0 70%; min-width: 0; margin-top: 0; }
.cv-bottom .cv-monitor { flex: 1 1 30%; min-width: 0; margin-top: 0; align-content: start; }
@media (max-width: 900px) { .cv-bottom { flex-direction: column; } .cv-bottom .cv-circ { flex-basis: auto; } }
[data-theme="light"] .cv-graph, [data-theme="light"] .cv-heart, [data-theme="light"] .cv-circ { background: #fff; border-color: #d6deec; }
.cv-gh { font-weight: 800; font-size: 13px; padding: 6px 10px 2px; color: var(--text); }
.cv-gh span { color: var(--muted); font-weight: 500; font-size: 11px; }
.cv-graph canvas { display: block; width: 100%; height: 210px; }
.cv-mid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 12px; margin-top: 12px; align-items: start; }
@media (max-width: 900px) { .cv-mid { grid-template-columns: 1fr; } }
.cv-heart canvas { display: block; width: 100%; height: 280px; }
.cv-monitor, .cv-controls { background: linear-gradient(180deg, var(--card-2), var(--card)); border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; position: relative; }
.cv-ctl-h { font-size: 11px; text-transform: uppercase; letter-spacing: .7px; color: var(--accent); font-weight: 800; margin-bottom: 10px; }
.cv-monitor { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.cv-monitor .cv-ctl-h { grid-column: 1 / -1; margin-bottom: 2px; }
/* monitor como faixa horizontal ocupando toda a largura (parâmetros do painel viram popup) */
.cv-monitor-band { grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)); margin-top: 12px; }
.cv-monitor-band .cv-tile.abp { grid-column: auto; }
.cv-tile { background: var(--navy-800); border: 1px solid var(--border); border-radius: 10px; padding: 8px 10px; display: flex; flex-direction: column; }
.cv-tile.abp .cv-tv.big { font-size: 24px; }
.cv-tl { font-size: 11px; color: var(--muted); font-weight: 600; }
.cv-tv { font-size: 22px; font-weight: 800; color: var(--c); font-variant-numeric: tabular-nums; line-height: 1.1; }
.cv-tv.big { font-size: 30px; }
.cv-tu { font-size: 10px; color: var(--muted); }
.cv-row { display: grid; grid-template-columns: 120px 1fr 52px; align-items: center; gap: 8px; margin-bottom: 8px; }
.cv-row label { font-size: 12px; color: var(--muted); font-weight: 600; }
.cv-row input[type=range] { width: 100%; accent-color: var(--accent); }
.cv-val { font-size: 12px; font-weight: 700; text-align: right; font-variant-numeric: tabular-nums; }

/* módulo EEG/BIS (monitor multiparâmetros) */
.eeg-tiles { display: block; }
/* caixa BIS: número grande à esquerda; EMG/SQI/SR em lista de texto à direita, na cor do módulo */
.eeg-bis { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.bis-main { display: flex; flex-direction: column; }
.bis-lbl { color: var(--muted); font-size: 12px; font-weight: 600; }
.bis-num { color: var(--c); font-size: 38px; font-weight: 800; line-height: 1; font-variant-numeric: tabular-nums; }
.bis-list { display: flex; flex-direction: column; gap: 3px; align-items: flex-end; }
.bis-it { display: flex; align-items: baseline; gap: 6px; }
.bis-it span { color: var(--muted); font-size: 11px; font-weight: 600; }
.bis-it b { color: var(--c); font-weight: 800; font-size: 15px; font-variant-numeric: tabular-nums; min-width: 26px; text-align: right; }

/* disclaimer educacional + referências (todos os simuladores) */
.sim-note { margin-top: 8px; padding: 8px 12px; border-radius: 10px; background: rgba(244, 180, 0, .08); border: 1px solid rgba(244, 180, 0, .35); font-size: 12px; color: var(--muted); line-height: 1.5; }
.sim-note b { color: var(--text); }
.sim-refs { display: block; margin-top: 4px; font-size: 11px; color: var(--muted); opacity: .85; }
.sim-refs-box { margin-top: 6px; font-size: 11px; }
.sim-refs-box > summary { cursor: pointer; color: var(--accent); font-weight: 700; list-style: none; }
.sim-refs-box > summary::-webkit-details-marker { display: none; }
.sim-refs-box > summary::before { content: '▸ '; }
.sim-refs-box[open] > summary::before { content: '▾ '; }
.sim-refs-box ol { margin: 6px 0 0; padding-left: 22px; color: var(--muted); line-height: 1.5; }
.sim-refs-box li { margin-bottom: 3px; }
.page-head-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
/* Cardio: botão expandir + tela expandida de pressões */
.cv-gh { position: relative; }
.cv-exp { float: right; background: var(--navy-700); border: 1px solid var(--border); color: var(--muted); border-radius: 6px; padding: 1px 8px; font-size: 11px; cursor: pointer; font-family: inherit; }
.cv-exp:hover { border-color: var(--accent); color: var(--text); }
/* Cardio: selo GDVet (logo + bolinhas) no canto superior direito das caixas */
.cv-logo { position: absolute; top: 7px; right: 10px; z-index: 4; display: flex; align-items: center; gap: 5px; pointer-events: none; opacity: .85; }
.cv-logo b { font-size: 12px; font-weight: 800; letter-spacing: .2px; color: var(--text); }
.cv-logo-dots { display: flex; gap: 3px; }
.cv-logo-dots i { width: 6px; height: 6px; border-radius: 50%; display: inline-block; }
.cv-logo-dots i.r { background: #e8443b; } .cv-logo-dots i.y { background: #f4b400; }
.cv-logo-dots i.g { background: #3fa34d; } .cv-logo-dots i.b { background: #5b8fc9; }
/* Documentação (equações e fontes) */
.doc-sec { margin-bottom: 18px; }
.doc-sec > h2 { font-size: 18px; font-weight: 800; margin: 0 0 12px; }
.doc-box { margin-bottom: 8px; }
.doc-box .box-body p { margin: 0 0 8px; color: var(--muted); line-height: 1.55; }
.doc-formula { font-family: 'Cambria Math', 'Times New Roman', Georgia, serif; font-size: 15px; color: var(--text);
  background: var(--navy-800); border: 1px solid var(--border); border-left: 3px solid var(--accent);
  border-radius: 8px; padding: 9px 12px; margin: 6px 0; overflow-x: auto; }
.doc-refs { margin-top: 10px; font-size: 12px; }
.doc-refs b { color: var(--accent); font-size: 11px; text-transform: uppercase; letter-spacing: .6px; }
.doc-refs ol { margin: 5px 0 0; padding-left: 20px; color: var(--muted); line-height: 1.5; }
.doc-refs li { margin-bottom: 3px; }
.doc-defs { margin: 8px 0; padding-left: 18px; color: var(--muted); line-height: 1.55; font-size: 13px; }
.doc-defs li { margin-bottom: 4px; }
.doc-defs b { color: var(--text); }
.doc-norm { margin: 8px 0 0; padding: 8px 11px; border-radius: 8px; background: rgba(91, 143, 201, .10);
  border: 1px solid rgba(91, 143, 201, .3); font-size: 12.5px; color: var(--muted); line-height: 1.5; }
.doc-norm b { color: var(--text); }
.cv-expand .cv-exp-card { width: min(1280px, 97vw); max-height: 94vh; }
.cv-exp-tools { display: inline-flex; align-items: center; gap: 6px; }
.cv-exp-body { padding: 12px 16px; }
.cv-exp-body canvas { display: block; width: 100%; height: 64vh; background: #000; border: 1px solid #1d2740; border-radius: 8px; cursor: crosshair; touch-action: none; }
.cv-exp-read { margin-top: 8px; font-size: 13px; color: var(--muted); font-variant-numeric: tabular-nums; }

/* bandeiras do seletor de idioma (data-uri, embutidas no css) */
.flag-br{background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%201000%20700%22%3E%20%3Cdefs%3E%3CclipPath%20id%3D%22g%22%3E%3Ccircle%20cx%3D%22500%22%20cy%3D%22350%22%20r%3D%22175%22%2F%3E%3C%2FclipPath%3E%3C%2Fdefs%3E%20%3Crect%20width%3D%221000%22%20height%3D%22700%22%20fill%3D%22%23009b3a%22%2F%3E%20%3Cpath%20d%3D%22M500%2075%20L925%20350%20L500%20625%20L75%20350%20Z%22%20fill%3D%22%23fedf00%22%2F%3E%20%3Ccircle%20cx%3D%22500%22%20cy%3D%22350%22%20r%3D%22175%22%20fill%3D%22%23002776%22%2F%3E%20%3Cg%20clip-path%3D%22url(%23g)%22%3E%20%3Ccircle%20cx%3D%22500%22%20cy%3D%22545%22%20r%3D%22205%22%20fill%3D%22%23fff%22%2F%3E%20%3Ccircle%20cx%3D%22500%22%20cy%3D%22567%22%20r%3D%22205%22%20fill%3D%22%23002776%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E")}
.flag-us{background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%201235%20650%22%3E%20%3Crect%20width%3D%221235%22%20height%3D%22650%22%20fill%3D%22%23fff%22%2F%3E%20%3Crect%20y%3D%220.00%22%20width%3D%221235%22%20height%3D%2250.00%22%20fill%3D%22%23b22234%22%2F%3E%3Crect%20y%3D%22100.00%22%20width%3D%221235%22%20height%3D%2250.00%22%20fill%3D%22%23b22234%22%2F%3E%3Crect%20y%3D%22200.00%22%20width%3D%221235%22%20height%3D%2250.00%22%20fill%3D%22%23b22234%22%2F%3E%3Crect%20y%3D%22300.00%22%20width%3D%221235%22%20height%3D%2250.00%22%20fill%3D%22%23b22234%22%2F%3E%3Crect%20y%3D%22400.00%22%20width%3D%221235%22%20height%3D%2250.00%22%20fill%3D%22%23b22234%22%2F%3E%3Crect%20y%3D%22500.00%22%20width%3D%221235%22%20height%3D%2250.00%22%20fill%3D%22%23b22234%22%2F%3E%3Crect%20y%3D%22600.00%22%20width%3D%221235%22%20height%3D%2250.00%22%20fill%3D%22%23b22234%22%2F%3E%20%3Crect%20width%3D%22494%22%20height%3D%22350.00%22%20fill%3D%22%233c3b6e%22%2F%3E%20%3Cpath%20d%3D%22M41.2%2C18.7L44.8%2C30.0L56.7%2C30.0L47.1%2C36.9L50.8%2C48.2L41.2%2C41.2L31.6%2C48.2L35.2%2C36.9L25.6%2C30.0L37.5%2C30.0ZM123.5%2C18.7L127.2%2C30.0L139.0%2C30.0L129.4%2C36.9L133.1%2C48.2L123.5%2C41.2L113.9%2C48.2L117.6%2C36.9L108.0%2C30.0L119.8%2C30.0ZM205.8%2C18.7L209.5%2C30.0L221.4%2C30.0L211.8%2C36.9L215.4%2C48.2L205.8%2C41.2L196.2%2C48.2L199.9%2C36.9L190.3%2C30.0L202.2%2C30.0ZM288.2%2C18.7L291.8%2C30.0L303.7%2C30.0L294.1%2C36.9L297.8%2C48.2L288.2%2C41.2L278.6%2C48.2L282.2%2C36.9L272.6%2C30.0L284.5%2C30.0ZM370.5%2C18.7L374.2%2C30.0L386.0%2C30.0L376.4%2C36.9L380.1%2C48.2L370.5%2C41.2L360.9%2C48.2L364.6%2C36.9L355.0%2C30.0L366.8%2C30.0ZM452.8%2C18.7L456.5%2C30.0L468.4%2C30.0L458.8%2C36.9L462.4%2C48.2L452.8%2C41.2L443.2%2C48.2L446.9%2C36.9L437.3%2C30.0L449.2%2C30.0ZM82.3%2C53.7L86.0%2C65.0L97.9%2C65.0L88.3%2C71.9L91.9%2C83.2L82.3%2C76.2L72.7%2C83.2L76.4%2C71.9L66.8%2C65.0L78.7%2C65.0ZM164.7%2C53.7L168.3%2C65.0L180.2%2C65.0L170.6%2C71.9L174.3%2C83.2L164.7%2C76.2L155.1%2C83.2L158.7%2C71.9L149.1%2C65.0L161.0%2C65.0ZM247.0%2C53.7L250.7%2C65.0L262.5%2C65.0L252.9%2C71.9L256.6%2C83.2L247.0%2C76.2L237.4%2C83.2L241.1%2C71.9L231.5%2C65.0L243.3%2C65.0ZM329.3%2C53.7L333.0%2C65.0L344.9%2C65.0L335.3%2C71.9L338.9%2C83.2L329.3%2C76.2L319.7%2C83.2L323.4%2C71.9L313.8%2C65.0L325.7%2C65.0ZM411.7%2C53.7L415.3%2C65.0L427.2%2C65.0L417.6%2C71.9L421.3%2C83.2L411.7%2C76.2L402.1%2C83.2L405.7%2C71.9L396.1%2C65.0L408.0%2C65.0ZM41.2%2C88.7L44.8%2C100.0L56.7%2C100.0L47.1%2C106.9L50.8%2C118.2L41.2%2C111.2L31.6%2C118.2L35.2%2C106.9L25.6%2C100.0L37.5%2C100.0ZM123.5%2C88.7L127.2%2C100.0L139.0%2C100.0L129.4%2C106.9L133.1%2C118.2L123.5%2C111.2L113.9%2C118.2L117.6%2C106.9L108.0%2C100.0L119.8%2C100.0ZM205.8%2C88.7L209.5%2C100.0L221.4%2C100.0L211.8%2C106.9L215.4%2C118.2L205.8%2C111.2L196.2%2C118.2L199.9%2C106.9L190.3%2C100.0L202.2%2C100.0ZM288.2%2C88.7L291.8%2C100.0L303.7%2C100.0L294.1%2C106.9L297.8%2C118.2L288.2%2C111.2L278.6%2C118.2L282.2%2C106.9L272.6%2C100.0L284.5%2C100.0ZM370.5%2C88.7L374.2%2C100.0L386.0%2C100.0L376.4%2C106.9L380.1%2C118.2L370.5%2C111.2L360.9%2C118.2L364.6%2C106.9L355.0%2C100.0L366.8%2C100.0ZM452.8%2C88.7L456.5%2C100.0L468.4%2C100.0L458.8%2C106.9L462.4%2C118.2L452.8%2C111.2L443.2%2C118.2L446.9%2C106.9L437.3%2C100.0L449.2%2C100.0ZM82.3%2C123.7L86.0%2C135.0L97.9%2C135.0L88.3%2C141.9L91.9%2C153.2L82.3%2C146.2L72.7%2C153.2L76.4%2C141.9L66.8%2C135.0L78.7%2C135.0ZM164.7%2C123.7L168.3%2C135.0L180.2%2C135.0L170.6%2C141.9L174.3%2C153.2L164.7%2C146.2L155.1%2C153.2L158.7%2C141.9L149.1%2C135.0L161.0%2C135.0ZM247.0%2C123.7L250.7%2C135.0L262.5%2C135.0L252.9%2C141.9L256.6%2C153.2L247.0%2C146.2L237.4%2C153.2L241.1%2C141.9L231.5%2C135.0L243.3%2C135.0ZM329.3%2C123.7L333.0%2C135.0L344.9%2C135.0L335.3%2C141.9L338.9%2C153.2L329.3%2C146.2L319.7%2C153.2L323.4%2C141.9L313.8%2C135.0L325.7%2C135.0ZM411.7%2C123.7L415.3%2C135.0L427.2%2C135.0L417.6%2C141.9L421.3%2C153.2L411.7%2C146.2L402.1%2C153.2L405.7%2C141.9L396.1%2C135.0L408.0%2C135.0ZM41.2%2C158.7L44.8%2C170.0L56.7%2C170.0L47.1%2C176.9L50.8%2C188.2L41.2%2C181.2L31.6%2C188.2L35.2%2C176.9L25.6%2C170.0L37.5%2C170.0ZM123.5%2C158.7L127.2%2C170.0L139.0%2C170.0L129.4%2C176.9L133.1%2C188.2L123.5%2C181.2L113.9%2C188.2L117.6%2C176.9L108.0%2C170.0L119.8%2C170.0ZM205.8%2C158.7L209.5%2C170.0L221.4%2C170.0L211.8%2C176.9L215.4%2C188.2L205.8%2C181.2L196.2%2C188.2L199.9%2C176.9L190.3%2C170.0L202.2%2C170.0ZM288.2%2C158.7L291.8%2C170.0L303.7%2C170.0L294.1%2C176.9L297.8%2C188.2L288.2%2C181.2L278.6%2C188.2L282.2%2C176.9L272.6%2C170.0L284.5%2C170.0ZM370.5%2C158.7L374.2%2C170.0L386.0%2C170.0L376.4%2C176.9L380.1%2C188.2L370.5%2C181.2L360.9%2C188.2L364.6%2C176.9L355.0%2C170.0L366.8%2C170.0ZM452.8%2C158.7L456.5%2C170.0L468.4%2C170.0L458.8%2C176.9L462.4%2C188.2L452.8%2C181.2L443.2%2C188.2L446.9%2C176.9L437.3%2C170.0L449.2%2C170.0ZM82.3%2C193.7L86.0%2C205.0L97.9%2C205.0L88.3%2C211.9L91.9%2C223.2L82.3%2C216.2L72.7%2C223.2L76.4%2C211.9L66.8%2C205.0L78.7%2C205.0ZM164.7%2C193.7L168.3%2C205.0L180.2%2C205.0L170.6%2C211.9L174.3%2C223.2L164.7%2C216.2L155.1%2C223.2L158.7%2C211.9L149.1%2C205.0L161.0%2C205.0ZM247.0%2C193.7L250.7%2C205.0L262.5%2C205.0L252.9%2C211.9L256.6%2C223.2L247.0%2C216.2L237.4%2C223.2L241.1%2C211.9L231.5%2C205.0L243.3%2C205.0ZM329.3%2C193.7L333.0%2C205.0L344.9%2C205.0L335.3%2C211.9L338.9%2C223.2L329.3%2C216.2L319.7%2C223.2L323.4%2C211.9L313.8%2C205.0L325.7%2C205.0ZM411.7%2C193.7L415.3%2C205.0L427.2%2C205.0L417.6%2C211.9L421.3%2C223.2L411.7%2C216.2L402.1%2C223.2L405.7%2C211.9L396.1%2C205.0L408.0%2C205.0ZM41.2%2C228.7L44.8%2C240.0L56.7%2C240.0L47.1%2C246.9L50.8%2C258.2L41.2%2C251.2L31.6%2C258.2L35.2%2C246.9L25.6%2C240.0L37.5%2C240.0ZM123.5%2C228.7L127.2%2C240.0L139.0%2C240.0L129.4%2C246.9L133.1%2C258.2L123.5%2C251.2L113.9%2C258.2L117.6%2C246.9L108.0%2C240.0L119.8%2C240.0ZM205.8%2C228.7L209.5%2C240.0L221.4%2C240.0L211.8%2C246.9L215.4%2C258.2L205.8%2C251.2L196.2%2C258.2L199.9%2C246.9L190.3%2C240.0L202.2%2C240.0ZM288.2%2C228.7L291.8%2C240.0L303.7%2C240.0L294.1%2C246.9L297.8%2C258.2L288.2%2C251.2L278.6%2C258.2L282.2%2C246.9L272.6%2C240.0L284.5%2C240.0ZM370.5%2C228.7L374.2%2C240.0L386.0%2C240.0L376.4%2C246.9L380.1%2C258.2L370.5%2C251.2L360.9%2C258.2L364.6%2C246.9L355.0%2C240.0L366.8%2C240.0ZM452.8%2C228.7L456.5%2C240.0L468.4%2C240.0L458.8%2C246.9L462.4%2C258.2L452.8%2C251.2L443.2%2C258.2L446.9%2C246.9L437.3%2C240.0L449.2%2C240.0ZM82.3%2C263.7L86.0%2C275.0L97.9%2C275.0L88.3%2C281.9L91.9%2C293.2L82.3%2C286.2L72.7%2C293.2L76.4%2C281.9L66.8%2C275.0L78.7%2C275.0ZM164.7%2C263.7L168.3%2C275.0L180.2%2C275.0L170.6%2C281.9L174.3%2C293.2L164.7%2C286.2L155.1%2C293.2L158.7%2C281.9L149.1%2C275.0L161.0%2C275.0ZM247.0%2C263.7L250.7%2C275.0L262.5%2C275.0L252.9%2C281.9L256.6%2C293.2L247.0%2C286.2L237.4%2C293.2L241.1%2C281.9L231.5%2C275.0L243.3%2C275.0ZM329.3%2C263.7L333.0%2C275.0L344.9%2C275.0L335.3%2C281.9L338.9%2C293.2L329.3%2C286.2L319.7%2C293.2L323.4%2C281.9L313.8%2C275.0L325.7%2C275.0ZM411.7%2C263.7L415.3%2C275.0L427.2%2C275.0L417.6%2C281.9L421.3%2C293.2L411.7%2C286.2L402.1%2C293.2L405.7%2C281.9L396.1%2C275.0L408.0%2C275.0ZM41.2%2C298.7L44.8%2C310.0L56.7%2C310.0L47.1%2C316.9L50.8%2C328.2L41.2%2C321.2L31.6%2C328.2L35.2%2C316.9L25.6%2C310.0L37.5%2C310.0ZM123.5%2C298.7L127.2%2C310.0L139.0%2C310.0L129.4%2C316.9L133.1%2C328.2L123.5%2C321.2L113.9%2C328.2L117.6%2C316.9L108.0%2C310.0L119.8%2C310.0ZM205.8%2C298.7L209.5%2C310.0L221.4%2C310.0L211.8%2C316.9L215.4%2C328.2L205.8%2C321.2L196.2%2C328.2L199.9%2C316.9L190.3%2C310.0L202.2%2C310.0ZM288.2%2C298.7L291.8%2C310.0L303.7%2C310.0L294.1%2C316.9L297.8%2C328.2L288.2%2C321.2L278.6%2C328.2L282.2%2C316.9L272.6%2C310.0L284.5%2C310.0ZM370.5%2C298.7L374.2%2C310.0L386.0%2C310.0L376.4%2C316.9L380.1%2C328.2L370.5%2C321.2L360.9%2C328.2L364.6%2C316.9L355.0%2C310.0L366.8%2C310.0ZM452.8%2C298.7L456.5%2C310.0L468.4%2C310.0L458.8%2C316.9L462.4%2C328.2L452.8%2C321.2L443.2%2C328.2L446.9%2C316.9L437.3%2C310.0L449.2%2C310.0Z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E")}
.flag-es{background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20750%20500%22%3E%20%3Crect%20width%3D%22750%22%20height%3D%22500%22%20fill%3D%22%23c60b1e%22%2F%3E%20%3Crect%20width%3D%22750%22%20height%3D%22250%22%20y%3D%22125%22%20fill%3D%22%23ffc400%22%2F%3E%3C%2Fsvg%3E")}
