/* Gaby · dark-mode skin sobre los tokens de Operaria.
   Aplicación oscura de Flow: navy→petrol con luz petrol y la rebeldía naranja
   (el único acento nombrado del Asistente Gerencial). Cero barroco. */

:root {
  /* Fondo navy profundo del brief, como aplicación oscura de --op-navy */
  --cy-bg-0:      #06122A;
  --cy-bg-1:      #08152E;
  --cy-bg-2:      #0F1E3A;

  /* Superficies de vidrio */
  --cy-glass:     rgba(15, 30, 58, 0.55);
  --cy-glass-2:   rgba(255, 255, 255, 0.04);
  --cy-glass-3:   rgba(255, 255, 255, 0.02);
  --cy-border:    rgba(242, 240, 235, 0.10);
  --cy-border-2:  rgba(242, 240, 235, 0.16);

  /* Puente frío (Health es bisagra) */
  --cy-petrol:    #4A9B93;
  --cy-petrol-d:  #1B4D4A;

  /* La rebeldía — naranja del Asistente Gerencial */
  --cy-orange:    #F0883C;
  --cy-orange-d:  #E2652A;

  /* Texto sobre oscuro */
  --cy-text:      #F2F0EB;
  --cy-text-2:    #F0E4D2;
  --cy-muted:     rgba(242, 240, 235, 0.58);
  --cy-faint:     rgba(242, 240, 235, 0.34);

  --cy-blur:      blur(20px) saturate(140%);
  --cy-radius:    var(--op-r-lg);
  --cy-shadow:    0 24px 60px rgba(2, 8, 22, 0.55);
}

/* ---------- Lienzo ---------- */
html, body { height: 100%; }
body {
  margin: 0;
  background: var(--cy-bg-1);
  color: var(--cy-text);
  font-family: var(--op-sans);
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
}

#root { height: 100vh; }

/* Fondo: gradiente navy + glows radiales naranja / petrol en las esquinas */
.cy-stage {
  position: relative;
  height: 100vh;
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(240,136,60,0.10), transparent 46%),
    radial-gradient(120% 90% at 0% 100%, rgba(74,155,147,0.12), transparent 50%),
    linear-gradient(155deg, var(--cy-bg-0) 0%, var(--cy-bg-1) 48%, var(--cy-bg-2) 100%);
  overflow: hidden;
}
/* Intensidad de glow (tweak) */
.cy-stage[data-glow="calm"]   { --cy-glow-mult: 0.55; }
.cy-stage[data-glow="normal"] { --cy-glow-mult: 1; }
.cy-stage[data-glow="warm"]   { --cy-glow-mult: 1.7; }
.cy-glow {
  position: absolute; pointer-events: none; border-radius: 50%;
  filter: blur(96px); opacity: calc(0.42 * var(--cy-glow-mult, 1));
}
.cy-glow--orange { top: -160px; right: -120px; width: 520px; height: 520px;
  background: radial-gradient(circle, rgba(240,136,60,0.55), transparent 68%); }
.cy-glow--petrol { bottom: -260px; left: 120px; width: 640px; height: 640px;
  background: radial-gradient(circle, rgba(74,155,147,0.38), transparent 70%); }
.cy-stage[data-depth="deep"]   { --cy-bg-0: #04101F; }

/* ---------- Shell de 3 zonas ---------- */
.cy-shell {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 244px 1fr;
  height: 100vh;
}

/* ---------- Glass helpers ---------- */
.cy-glass {
  background: var(--cy-glass);
  border: 1px solid var(--cy-border);
  border-radius: var(--cy-radius);
  -webkit-backdrop-filter: var(--cy-blur);
  backdrop-filter: var(--cy-blur);
  box-shadow: var(--cy-shadow);
}
.cy-soft {
  background: var(--cy-glass-2);
  border: 1px solid var(--cy-border);
  border-radius: var(--op-r-md);
}
/* Tarjeta sólida (sin backdrop-filter) para listas/feeds apilados —
   más legible y sin glitches de composición sobre los glows. */
.cy-listcard {
  background: rgba(11, 23, 46, 0.74);
  border: 1px solid var(--cy-border);
  border-radius: var(--cy-radius);
  box-shadow: var(--cy-shadow);
}

/* Mono eyebrow sobre oscuro */
.cy-eyebrow {
  font-family: var(--op-mono);
  font-size: var(--op-fs-micro);
  font-weight: var(--op-w-regular);
  letter-spacing: var(--op-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--cy-muted);
}
.cy-mono {
  font-family: var(--op-mono);
  letter-spacing: var(--op-tracking-mono);
  text-transform: uppercase;
  font-feature-settings: "tnum" 1;
}
.cy-serif {
  font-family: var(--op-serif);
  font-style: italic;
  font-weight: 400;
  line-height: 1.34;
  text-wrap: pretty;
}

/* ---------- Sidebar ---------- */
.cy-side {
  display: flex; flex-direction: column;
  gap: var(--op-sp-5);
  padding: var(--op-sp-6) var(--op-sp-4);
  border-right: 1px solid var(--cy-border);
  background: linear-gradient(180deg, rgba(6,18,42,0.5), rgba(6,18,42,0.0));
  overflow-y: auto;
}
.cy-brand { display: flex; align-items: center; gap: 12px; padding: 0 var(--op-sp-2); }
.cy-brand__word { font-family: var(--op-serif); font-weight: 300; font-size: 1.5rem; letter-spacing: 0.02em; }
.cy-brand__sub { font-size: 8.5px; }

.cy-id {
  display: flex; align-items: center; gap: 12px;
  padding: var(--op-sp-3);
  border-radius: var(--op-r-md);
  background: var(--cy-glass-2);
  border: 1px solid var(--cy-border);
}
.cy-id__avatar {
  width: 38px; height: 38px; border-radius: 50%; flex: none;
  display: grid; place-items: center;
  background: linear-gradient(150deg, var(--cy-orange), var(--cy-orange-d));
  color: #1A0E06; font-family: var(--op-sans); font-weight: 700; font-size: 15px;
}
.cy-id__name { font-weight: 600; font-size: 0.95rem; letter-spacing: -0.01em; }
.cy-id__meta { font-size: 9px; color: var(--cy-muted); margin-top: 2px; }

.cy-navgroup { display: flex; flex-direction: column; gap: 2px; }
.cy-navgroup__label {
  padding: 0 var(--op-sp-3); margin-bottom: 6px;
  font-family: var(--op-mono); font-size: 9px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--cy-faint);
}
.cy-nav {
  position: relative;
  display: flex; align-items: center; gap: 11px;
  padding: 9px var(--op-sp-3);
  border-radius: var(--op-r-sm);
  color: var(--cy-muted);
  font-size: 0.92rem; font-weight: 500;
  cursor: pointer; user-select: none;
  border: 1px solid transparent;
  transition: color var(--op-dur) var(--op-ease), background var(--op-dur) var(--op-ease);
}
.cy-nav:hover { color: var(--cy-text); background: var(--cy-glass-2); }
.cy-nav__icon { width: 18px; height: 18px; flex: none; opacity: 0.85; }
.cy-nav__badge {
  margin-left: auto;
  font-family: var(--op-mono); font-size: 9px; letter-spacing: 0.08em;
  color: var(--cy-orange); background: rgba(240,136,60,0.12);
  border-radius: 999px; padding: 2px 7px;
}
.cy-nav--active {
  color: var(--cy-text);
  background: linear-gradient(90deg, rgba(240,136,60,0.13), rgba(240,136,60,0.02) 70%);
}
.cy-nav--active::before {
  content: ""; position: absolute; left: 0; top: 6px; bottom: 6px; width: 3px;
  border-radius: 999px; background: linear-gradient(180deg, var(--cy-orange), var(--cy-orange-d));
  box-shadow: 0 0 12px rgba(240,136,60,0.6);
}

/* ---------- Main ---------- */
.cy-main { display: flex; flex-direction: column; height: 100vh; overflow: hidden; }
.cy-crumb {
  display: flex; align-items: center; gap: 10px;
  white-space: nowrap;
  padding: var(--op-sp-4) var(--op-sp-7);
  border-bottom: 1px solid var(--cy-border);
  background: rgba(6,18,42,0.35);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  flex: none;
}
.cy-crumb__sep { color: var(--cy-faint); }
.cy-crumb__here { color: var(--cy-text); }
.cy-crumb__spacer { flex: 1; }
.cy-crumb__time { color: var(--cy-muted); font-size: 10px; }

.cy-scroll { flex: 1; overflow-y: auto; padding: var(--op-sp-6) var(--op-sp-7) 120px; }
.cy-wrap { max-width: 1080px; margin: 0 auto; display: flex; flex-direction: column; gap: var(--op-sp-5); }

/* ---------- Cockpit ---------- */
.cy-cockpit {
  display: flex; align-items: center; gap: var(--op-sp-5);
  padding: var(--op-sp-6);
}
.cy-cockpit__text { flex: 1; }
.cy-cockpit__eyebrow { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.cy-cockpit__greet { font-size: clamp(1.4rem, 2.4vw, 2rem); color: var(--cy-text); }
.cy-cockpit__greet em { color: var(--cy-text-2); font-style: italic; }

/* ---------- Grids ---------- */
.cy-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--op-sp-4); }
.cy-split { display: grid; grid-template-columns: 2fr 1fr; gap: var(--op-sp-4); }

/* ---------- KPI ---------- */
.cy-kpi {
  position: relative; padding: var(--op-sp-5) var(--op-sp-5) var(--op-sp-4);
  display: flex; flex-direction: column; gap: 10px;
  overflow: hidden;
  transition: transform var(--op-dur) var(--op-ease), border-color var(--op-dur) var(--op-ease);
}
.cy-kpi:hover { transform: translateY(-2px); border-color: var(--cy-border-2); }
.cy-kpi__line { position: absolute; left: 0; top: 14px; bottom: 14px; width: 2px; border-radius: 999px; }
.cy-kpi--petrol .cy-kpi__line { background: var(--cy-petrol); }
.cy-kpi--orange .cy-kpi__line { background: linear-gradient(180deg, var(--cy-orange), var(--cy-orange-d)); box-shadow: 0 0 10px rgba(240,136,60,0.5); }
.cy-kpi__label { font-family: var(--op-mono); font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cy-muted); }
.cy-kpi__value { font-family: var(--op-sans); font-weight: 700; font-size: 2.5rem; line-height: 1; letter-spacing: -0.02em; }
.cy-kpi__value small { font-size: 0.95rem; font-weight: 500; color: var(--cy-muted); margin-left: 6px; letter-spacing: 0; }
.cy-kpi__unit { font-family: var(--op-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cy-faint); }
.cy-kpi__delta { display: flex; align-items: center; gap: 6px; font-size: 0.8rem; color: var(--cy-muted); margin-top: auto; padding-top: 8px; }
.cy-kpi__delta--up { color: var(--cy-petrol); }
.cy-kpi__delta--orange { color: var(--cy-orange); }

/* KPI variant: filled top accent (tweak "filled") */
.cy-kpis[data-kpi="filled"] .cy-kpi__line { display: none; }
.cy-kpis[data-kpi="filled"] .cy-kpi { padding-left: var(--op-sp-5); }
.cy-kpis[data-kpi="filled"] .cy-kpi::after {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 3px;
  background: var(--cy-petrol); opacity: 0.8;
}
.cy-kpis[data-kpi="filled"] .cy-kpi--orange::after { background: linear-gradient(90deg, var(--cy-orange), var(--cy-orange-d)); }
/* KPI variant: plain (tweak "plain") */
.cy-kpis[data-kpi="plain"] .cy-kpi__line { display: none; }

/* ---------- Chart ---------- */
.cy-chart { padding: var(--op-sp-5); display: flex; flex-direction: column; gap: var(--op-sp-4); }
.cy-chart__head { display: flex; justify-content: space-between; align-items: flex-start; }
.cy-chart__title { font-size: 1.15rem; font-weight: 600; letter-spacing: -0.01em; }
.cy-chart__svg { width: 100%; height: 200px; display: block; }
.cy-chart__nota { font-family: var(--op-serif); font-style: italic; font-size: 1rem; color: var(--cy-muted); }

/* ---------- Insights ---------- */
.cy-insights { padding: var(--op-sp-5); display: flex; flex-direction: column; gap: var(--op-sp-3); }
.cy-insight {
  display: flex; gap: 12px; padding: var(--op-sp-3) var(--op-sp-4);
  border-radius: var(--op-r-md); background: var(--cy-glass-3);
  border: 1px solid var(--cy-border);
}
.cy-insight__dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 8px; flex: none; background: var(--cy-petrol); }
.cy-insight--urgent .cy-insight__dot { background: var(--cy-orange); box-shadow: 0 0 9px rgba(240,136,60,0.7); }
.cy-insight__text { font-family: var(--op-serif); font-style: italic; font-size: 1.02rem; color: var(--cy-text-2); }

/* ---------- Listas genéricas de módulos ---------- */
.cy-section-title { font-size: 1.5rem; font-weight: 600; letter-spacing: -0.015em; }
.cy-lede { color: var(--cy-muted); max-width: 56ch; }

.cy-row {
  display: flex; align-items: center; gap: var(--op-sp-4);
  padding: var(--op-sp-4) var(--op-sp-5);
  cursor: pointer;
  transition: background var(--op-dur) var(--op-ease), border-color var(--op-dur) var(--op-ease);
}
.cy-row:hover { background: var(--cy-glass-2); }
.cy-rows { display: flex; flex-direction: column; }
.cy-rows .cy-row + .cy-row { border-top: 1px solid var(--cy-border); }

/* Pendientes */
.cy-check {
  width: 20px; height: 20px; border-radius: 6px; flex: none;
  border: 1.5px solid var(--cy-border-2); display: grid; place-items: center;
  cursor: pointer; transition: all var(--op-dur) var(--op-ease);
}
.cy-check--on { background: var(--cy-petrol); border-color: var(--cy-petrol); }
.cy-row--done .cy-pend__cliente { text-decoration: line-through; color: var(--cy-faint); }
.cy-pend__cliente { font-weight: 600; font-size: 1rem; }
.cy-pend__accion { color: var(--cy-muted); font-size: 0.88rem; margin-top: 2px; }
.cy-pend__right { margin-left: auto; text-align: right; display: flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.cy-pend__monto { font-family: var(--op-mono); font-size: 0.85rem; color: var(--cy-text); }
.cy-pill {
  font-family: var(--op-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 3px 9px; border-radius: 999px; color: var(--cy-muted);
  white-space: nowrap; flex: none;
  background: var(--cy-glass-2); border: 1px solid var(--cy-border);
}
.cy-pill--hoy { color: var(--cy-orange); background: rgba(240,136,60,0.12); border-color: rgba(240,136,60,0.25); }

/* Agenda */
.cy-agenda__time { width: 64px; flex: none; text-align: right; }
.cy-agenda__hora { font-family: var(--op-mono); font-size: 0.95rem; color: var(--cy-text); }
.cy-agenda__dur { font-family: var(--op-mono); font-size: 9px; color: var(--cy-faint); margin-top: 2px; }
.cy-agenda__bar { width: 3px; align-self: stretch; border-radius: 999px; flex: none; background: var(--cy-border-2); }
.cy-agenda__bar--petrol { background: var(--cy-petrol); }
.cy-agenda__bar--orange { background: linear-gradient(180deg, var(--cy-orange), var(--cy-orange-d)); }
.cy-agenda__titulo { font-weight: 600; font-size: 1rem; }
.cy-agenda__lugar { color: var(--cy-muted); font-size: 0.85rem; margin-top: 2px; }

/* Repos */
.cy-repo__icon { width: 40px; height: 40px; border-radius: 10px; flex: none; display: grid; place-items: center; background: var(--cy-glass-2); border: 1px solid var(--cy-border); color: var(--cy-petrol); }
.cy-repo__name { font-weight: 600; font-size: 1rem; }
.cy-repo__meta { color: var(--cy-faint); font-size: 0.8rem; margin-top: 2px; font-family: var(--op-mono); letter-spacing: 0.08em; }

/* Avatares reutilizables */
.cy-av { display: grid; place-items: center; border-radius: 50%; font-family: var(--op-sans); font-weight: 600; flex: none; }
.cy-av--petrol { background: rgba(74,155,147,0.18); color: var(--cy-petrol); }
.cy-av--orange { background: rgba(240,136,60,0.20); color: var(--cy-orange); }
.cy-av--muted  { background: var(--cy-glass-2); color: var(--cy-muted); }

/* Correo electrónico */
.cy-mail { align-items: flex-start; }
.cy-mail__dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 16px; flex: none; background: var(--cy-orange); box-shadow: 0 0 8px rgba(240,136,60,0.6); }
.cy-mail__dot--read { background: transparent; box-shadow: none; }
.cy-mail__mid { flex: 1; min-width: 0; }
.cy-mail__top { display: flex; align-items: baseline; gap: 12px; }
.cy-mail__de { font-weight: 600; font-size: 0.98rem; }
.cy-mail__time { margin-left: auto; font-family: var(--op-mono); font-size: 10px; color: var(--cy-faint); white-space: nowrap; }
.cy-mail__asunto { font-size: 0.95rem; color: var(--cy-text); margin-top: 3px; }
.cy-mail__snippet { font-size: 0.85rem; color: var(--cy-muted); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Seguimiento de proyectos */
.cy-shared { display: flex; align-items: center; gap: 12px; padding: 0 var(--op-sp-2) var(--op-sp-1); }
.cy-shared__avatars { display: flex; }
.cy-shared__avatars .cy-av { border: 2px solid var(--cy-bg-1); }
.cy-shared__avatars .cy-av + .cy-av { margin-left: -9px; }
.cy-projlist { display: flex; flex-direction: column; gap: var(--op-sp-4); }
.cy-proj { padding: var(--op-sp-5); display: flex; flex-direction: column; gap: 16px; }
.cy-proj__top { display: flex; align-items: center; gap: 14px; }
.cy-proj__accent { width: 3px; align-self: stretch; min-height: 38px; border-radius: 999px; flex: none; background: var(--cy-border-2); }
.cy-proj__accent--petrol { background: var(--cy-petrol); }
.cy-proj__accent--orange { background: linear-gradient(180deg, var(--cy-orange), var(--cy-orange-d)); box-shadow: 0 0 10px rgba(240,136,60,0.5); }
.cy-proj__name { font-weight: 600; font-size: 1.05rem; letter-spacing: -0.01em; }
.cy-proj__meta { font-family: var(--op-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--cy-faint); text-transform: uppercase; margin-top: 4px; }
.cy-proj__people { display: flex; margin-left: auto; }
.cy-proj__av { width: 30px; height: 30px; font-size: 12px; border: 2px solid var(--cy-bg-2); }
.cy-proj__av + .cy-proj__av { margin-left: -9px; }
.cy-proj__bar { height: 6px; border-radius: 999px; background: var(--cy-glass-2); overflow: hidden; }
.cy-proj__fill { display: block; height: 100%; border-radius: 999px; background: var(--cy-petrol); }
.cy-proj__fill--orange { background: linear-gradient(90deg, var(--cy-orange), var(--cy-orange-d)); }
.cy-proj__foot { display: flex; justify-content: space-between; font-size: 10px; letter-spacing: 0.1em; color: var(--cy-muted); text-transform: uppercase; }

/* Personal / Centro toggles + notes */
.cy-note {
  font-family: var(--op-serif); font-style: italic; font-size: 1.15rem;
  color: var(--cy-text-2); line-height: 1.5; max-width: 60ch;
}
.cy-toggle {
  width: 42px; height: 24px; border-radius: 999px; flex: none; position: relative;
  background: var(--cy-glass-2); border: 1px solid var(--cy-border-2); cursor: pointer;
  transition: background var(--op-dur) var(--op-ease);
}
.cy-toggle::after { content: ""; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 50%; background: var(--cy-muted); transition: all var(--op-dur) var(--op-ease); }
.cy-toggle--on { background: rgba(74,155,147,0.3); border-color: var(--cy-petrol); }
.cy-toggle--on::after { left: 20px; background: var(--cy-petrol); }

.cy-feed { display: flex; flex-direction: column; gap: var(--op-sp-3); }
.cy-feed__item { padding: var(--op-sp-4) var(--op-sp-5); }
.cy-feed__head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.cy-feed__autor { font-family: var(--op-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cy-petrol); }
.cy-feed__cuando { font-family: var(--op-mono); font-size: 9px; color: var(--cy-faint); margin-left: auto; }
.cy-feed__text { color: var(--cy-text-2); font-size: 0.98rem; }

/* Ghost button sobre oscuro (override de op-btn--ghost) */
.cy-ghost.op-btn--ghost {
  color: var(--cy-text-2);
  border-color: var(--cy-border-2);
  background: transparent;
  display: inline-flex; align-items: center; gap: 8px;
}
.cy-ghost.op-btn--ghost:hover { background: var(--cy-glass-2); border-color: var(--cy-petrol); color: var(--cy-text); }

/* ---------- Gaby portrait ---------- */
.cy-portrait { display: block; }
.cy-ring { transform-origin: 50px 50px; }
@media (prefers-reduced-motion: no-preference) {
  .cy-ring--spin { animation: cy-spin 18s linear infinite; }
  .cy-ring--spin-rev { animation: cy-spin 24s linear infinite reverse; }
}
@keyframes cy-spin { to { transform: rotate(360deg); } }

/* ---------- Gaby dock (floating) ---------- */
.cy-dock { position: fixed; right: 28px; bottom: 28px; z-index: 60; display: flex; align-items: flex-end; gap: 14px; }
.cy-dock__bubble {
  max-width: 230px; padding: 12px 16px; border-radius: 18px 18px 4px 18px;
  background: var(--cy-glass); border: 1px solid var(--cy-border);
  -webkit-backdrop-filter: var(--cy-blur); backdrop-filter: var(--cy-blur);
  box-shadow: var(--cy-shadow);
  font-family: var(--op-serif); font-style: italic; font-size: 1.02rem; color: var(--cy-text-2);
  margin-bottom: 10px;
}
.cy-avatar-btn {
  position: relative; width: 72px; height: 72px; flex: none; border: none; padding: 0;
  background: none; cursor: pointer;
}
.cy-avatar-dot {
  position: absolute; top: 4px; right: 4px; width: 13px; height: 13px; border-radius: 50%; z-index: 3;
  background: var(--cy-orange); border: 2px solid var(--cy-bg-1);
  box-shadow: 0 0 0 0 rgba(240,136,60,0.6); animation: cy-pulse 2.4s var(--op-ease) infinite;
}
@keyframes cy-pulse {
  0% { box-shadow: 0 0 0 0 rgba(240,136,60,0.55); }
  70% { box-shadow: 0 0 0 12px rgba(240,136,60,0); }
  100% { box-shadow: 0 0 0 0 rgba(240,136,60,0); }
}

/* ---------- Gaby panel ---------- */
.cy-panel {
  position: fixed; right: 28px; bottom: 116px; z-index: 61;
  width: 360px; max-height: 70vh; display: flex; flex-direction: column;
  border-radius: var(--cy-radius);
  overflow: hidden;
  transform-origin: bottom right;
  animation: cy-rise var(--op-dur) var(--op-ease-out);
}
@keyframes cy-rise { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }
.cy-panel__head { display: flex; align-items: center; gap: 12px; padding: var(--op-sp-4) var(--op-sp-5); border-bottom: 1px solid var(--cy-border); }
.cy-panel__name { font-weight: 600; }
.cy-panel__status { font-size: 9px; color: var(--cy-petrol); }
.cy-panel__close { margin-left: auto; background: none; border: none; color: var(--cy-muted); cursor: pointer; padding: 6px; border-radius: 8px; }
.cy-panel__close:hover { color: var(--cy-text); background: var(--cy-glass-2); }
.cy-panel__body { padding: var(--op-sp-5); overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.cy-msg { font-family: var(--op-serif); font-style: italic; font-size: 1.05rem; color: var(--cy-text-2); padding: 10px 14px; border-radius: 14px 14px 14px 4px; background: var(--cy-glass-2); border: 1px solid var(--cy-border); align-self: flex-start; max-width: 90%; }
.cy-msg--me { font-family: var(--op-sans); font-style: normal; font-size: 0.95rem; color: var(--cy-text); border-radius: 14px 14px 4px 14px; align-self: flex-end; background: rgba(240,136,60,0.14); border-color: rgba(240,136,60,0.28); }
.cy-sugs { display: flex; flex-wrap: wrap; gap: 8px; padding: 0 var(--op-sp-5) var(--op-sp-3); }
.cy-sug { font-size: 0.82rem; color: var(--cy-text-2); padding: 6px 12px; border-radius: 999px; background: var(--cy-glass-2); border: 1px solid var(--cy-border); cursor: pointer; transition: all var(--op-dur) var(--op-ease); }
.cy-sug:hover { border-color: var(--cy-petrol); color: var(--cy-text); }
.cy-panel__foot { display: flex; gap: 10px; padding: var(--op-sp-4); border-top: 1px solid var(--cy-border); align-items: center; }
.cy-input {
  flex: 1; background: var(--cy-glass-2); border: 1px solid var(--cy-border-2);
  border-radius: 999px; padding: 10px 16px; color: var(--cy-text);
  font-family: var(--op-sans); font-size: 0.95rem; outline: none;
  transition: border-color var(--op-dur) var(--op-ease), box-shadow var(--op-dur) var(--op-ease);
}
.cy-input::placeholder { color: var(--cy-faint); }
.cy-input:focus { border-color: var(--cy-petrol); box-shadow: 0 0 0 3px rgba(74,155,147,0.22); }
.cy-send {
  width: 40px; height: 40px; flex: none; border-radius: 50%; border: none; cursor: pointer;
  display: grid; place-items: center; color: #1A0E06;
  background: linear-gradient(150deg, var(--cy-orange), var(--cy-orange-d));
  transition: transform var(--op-dur-fast) var(--op-ease), filter var(--op-dur) var(--op-ease);
}
.cy-send:hover { filter: brightness(1.08); }
.cy-send:active { transform: scale(0.94); }

/* ---------- Mobile / iPhone ---------- */
.cy-mobile-top { display: none; }
.cy-mobile-tabs { display: none; }

@media (max-width: 860px) {
  body { overflow: auto; }
  .cy-shell { grid-template-columns: 1fr; height: auto; min-height: 100vh; }
  .cy-side { display: none; }
  .cy-main { height: auto; min-height: 100vh; }
  .cy-mobile-top {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 18px; border-bottom: 1px solid var(--cy-border);
    position: sticky; top: 0; z-index: 40;
    background: rgba(6,18,42,0.8); -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  }
  .cy-crumb { display: none; }
  .cy-scroll { padding: var(--op-sp-5) var(--op-sp-4) 150px; overflow: visible; }
  .cy-kpis { grid-template-columns: 1fr 1fr; }
  .cy-split { grid-template-columns: 1fr; }
  .cy-cockpit { flex-direction: column; align-items: flex-start; gap: var(--op-sp-4); }
  .cy-dock { right: 16px; bottom: 84px; }
  .cy-panel { right: 12px; left: 12px; width: auto; bottom: 150px; max-height: 60vh; }

  .cy-mobile-tabs {
    display: flex; justify-content: space-around; align-items: center;
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 55;
    padding: 8px 6px calc(8px + env(safe-area-inset-bottom));
    background: rgba(6,18,42,0.92); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
    border-top: 1px solid var(--cy-border);
  }
  .cy-tab { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 6px 10px; color: var(--cy-faint); cursor: pointer; background: none; border: none; }
  .cy-tab__icon { width: 22px; height: 22px; }
  .cy-tab__label { font-family: var(--op-mono); font-size: 8px; letter-spacing: 0.1em; text-transform: uppercase; }
  .cy-tab--active { color: var(--cy-orange); }
}

@media (max-width: 480px) {
  .cy-kpis { grid-template-columns: 1fr; }
}

/* Scrollbars discretos */
.cy-scroll::-webkit-scrollbar, .cy-side::-webkit-scrollbar, .cy-panel__body::-webkit-scrollbar { width: 8px; }
.cy-scroll::-webkit-scrollbar-thumb, .cy-side::-webkit-scrollbar-thumb, .cy-panel__body::-webkit-scrollbar-thumb { background: var(--cy-border-2); border-radius: 999px; }
.cy-scroll::-webkit-scrollbar-track { background: transparent; }
