/* portal.css — layout e componentes do Portal MR. Mobile-first.
   Linguagem visual herdada do brandbook: navy profundo, aço metálico em
   momentos de marca, grão sutil, tipografia com hierarquia radical. */

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--portal-bg);
  color: var(--portal-text);
  font-family: var(--font-body);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow-x: hidden;
}
::selection { background: var(--steel); color: #fff; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input { font-family: inherit; }
img { display: block; max-width: 100%; }

/* ---- atmosfera de marca (fundo) ---- */
.ambient { position: fixed; inset: 0; z-index: 0; pointer-events: none; }
.ambient::before {
  content: ""; position: absolute; width: 70vw; height: 70vw; max-width: 900px; max-height: 900px;
  top: -22vw; right: -16vw;
  background: radial-gradient(circle, color-mix(in srgb, var(--steel-bright) 40%, transparent), transparent 62%);
}
.ambient::after {
  content: ""; position: absolute; width: 60vw; height: 60vw; max-width: 760px; max-height: 760px;
  bottom: -18vw; left: -14vw;
  background: radial-gradient(circle, color-mix(in srgb, var(--steel) 26%, transparent), transparent 60%);
}
.grain {
  position: fixed; inset: 0; z-index: 1; opacity: 0.045; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- tipografia utilitária ---- */
h1, h2, h3, h4, .display { font-family: var(--font-display); font-weight: var(--fw-heading); letter-spacing: var(--tracking-heading); line-height: 1.06; }
.serif { font-family: var(--font-serif); font-style: italic; font-weight: 400; }
.mono { font-family: var(--font-mono); }
.eyebrow {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.3em;
  text-transform: uppercase; color: var(--portal-text-faint);
}

/* =========================================================
   TELA DE LOGIN — split: painel de marca + formulário
   ========================================================= */
.auth {
  position: relative; z-index: 2; min-height: 100vh;
  display: grid; grid-template-columns: 1fr;
}
@media (min-width: 940px) { .auth { grid-template-columns: 1.05fr 1fr; } }

/* painel de marca (gradiente = momento de marca, atrás de logo, não de texto corrido) */
.auth-brand {
  position: relative; overflow: hidden;
  background: var(--portal-nav-bg);
  padding: 54px 30px;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  text-align: center;
  border-bottom: 1px solid var(--portal-line);
}
@media (min-width: 940px) {
  .auth-brand { padding: 64px 54px; border-bottom: none; border-right: 1px solid var(--portal-line); }
}
.auth-brand::before {
  content: ""; position: absolute; width: 520px; height: 520px; border-radius: 50%;
  top: -160px; right: -150px;
  background: radial-gradient(circle, color-mix(in srgb, var(--steel-bright) 30%, transparent), transparent 65%);
}
.auth-brand .inner { position: relative; z-index: 2; max-width: 480px; display: flex; flex-direction: column; align-items: center; }

/* palco da logo: leve aura em platina atrás do monograma */
.auth-brand .logo-stage { position: relative; display: flex; justify-content: center; margin-bottom: 32px; }
.auth-brand .logo-stage::before {
  content: ""; position: absolute; inset: -26% -16%;
  background: radial-gradient(ellipse at center, rgba(199, 207, 214, 0.18), rgba(199, 207, 214, 0.05) 46%, transparent 70%);
  filter: blur(10px); z-index: 0;
}
.auth-brand img.logo {
  position: relative; z-index: 1;
  width: 360px; max-width: 84%;
  /* leve profundidade 3D: sombra escura projetada (sem glow claro) */
  filter:
    drop-shadow(0 6px 13px rgba(0, 0, 0, 0.45))
    drop-shadow(0 2px 4px rgba(0, 0, 0, 0.34));
}
.auth-brand h1 { font-size: clamp(1.85rem, 3.6vw, 2.9rem); margin: 6px 0 16px; max-width: 17ch; }
.auth-brand h1 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--portal-text-faint); }
.auth-brand p { color: var(--portal-text-dim); max-width: 44ch; font-size: 1.02rem; }
.auth-creds { display: flex; gap: 30px; margin-top: 34px; padding-top: 22px; border-top: 1px solid var(--portal-line); flex-wrap: wrap; justify-content: center; }
.auth-creds .k { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--portal-text-faint); display: block; margin-bottom: 5px; }
.auth-creds .v { font-size: 0.9rem; }

/* lado do formulário */
.auth-form-wrap {
  display: flex; align-items: center; justify-content: center;
  padding: 44px 26px 56px;
}
.auth-card { width: 100%; max-width: 400px; }
.auth-card .step-label { margin-bottom: 8px; }
.auth-card h2 { font-size: 1.7rem; margin-bottom: 8px; }
.auth-card .sub { color: var(--portal-text-dim); font-size: 0.95rem; margin-bottom: 30px; }

.field { margin-bottom: 18px; }
.field label {
  display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--portal-text-faint); margin-bottom: 9px;
}
.field .control { position: relative; }
.field input {
  width: 100%; background: var(--navy-800); border: 1px solid var(--portal-line);
  color: var(--portal-text); padding: 14px 16px; border-radius: var(--r-sm);
  font-size: 1rem; transition: border-color 0.25s var(--ease), box-shadow 0.25s var(--ease);
}
.field input::placeholder { color: var(--doc-ink-soft); }
.field input:focus { outline: none; border-color: var(--steel); box-shadow: 0 0 0 3px color-mix(in srgb, var(--steel) 22%, transparent); }
.field .toggle-eye {
  position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  width: 38px; height: 38px; display: flex; align-items: center; justify-content: center;
  color: var(--portal-text-dim); border-radius: 8px; transition: color 0.2s, background 0.2s;
}
.field .toggle-eye:hover { color: var(--portal-text); background: color-mix(in srgb, var(--portal-text-faint) 8%, transparent); }
.field .toggle-eye svg { width: 19px; height: 19px; }

/* botão principal — base aço, com brilho metálico sutil no topo */
.btn-primary {
  width: 100%; padding: 15px 20px; border-radius: var(--r-sm);
  background: linear-gradient(180deg, var(--steel-bright), var(--steel));
  color: #fff; font-weight: 600; font-size: 1rem; letter-spacing: 0.01em;
  box-shadow: 0 10px 26px color-mix(in srgb, var(--steel) 40%, transparent), inset 0 1px 0 rgba(237, 255, 255, 0.28);
  transition: transform 0.18s var(--ease), box-shadow 0.25s var(--ease), opacity 0.2s;
  display: flex; align-items: center; justify-content: center; gap: 10px; margin-top: 6px;
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 34px color-mix(in srgb, var(--steel) 50%, transparent), inset 0 1px 0 rgba(237, 255, 255, 0.32); }
.btn-primary:active { transform: translateY(0); }
.btn-primary:disabled { opacity: 0.55; cursor: progress; transform: none; }

.btn-ghost {
  width: 100%; padding: 13px 20px; border-radius: var(--r-sm);
  border: 1px solid var(--portal-line-strong); color: var(--portal-text-dim); font-size: 0.92rem;
  transition: border-color 0.25s, color 0.25s; margin-top: 12px;
}
.btn-ghost:hover { border-color: var(--portal-text-faint); color: var(--portal-text); }

.auth-aux { display: flex; justify-content: space-between; align-items: center; margin-top: 22px; gap: 14px; font-size: 0.86rem; }
.auth-aux a { color: var(--portal-text-faint); transition: color 0.2s; }
.auth-aux a:hover { color: var(--steel-bright); }
.auth-switch { margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--portal-line); font-size: 0.9rem; color: var(--portal-text-dim); text-align: center; }
.auth-switch button { color: var(--steel-bright); font-weight: 600; }
.auth-switch button:hover { text-decoration: underline; }

/* mensagens de feedback */
.alert { padding: 13px 16px; border-radius: var(--r-sm); font-size: 0.9rem; margin-bottom: 20px; display: none; line-height: 1.45; }
.alert.show { display: block; }
.alert.error { background: rgba(217, 99, 127, 0.12); border: 1px solid rgba(217, 99, 127, 0.34); color: #f0b6c3; }
.alert.ok { background: rgba(127, 214, 168, 0.10); border: 1px solid rgba(127, 214, 168, 0.32); color: var(--green); }

/* =========================================================
   APP SHELL — topbar + barra lateral + conteúdo
   ========================================================= */
.app { position: relative; z-index: 2; min-height: 100vh; }

.topbar {
  position: sticky; top: 0; z-index: 30; height: var(--topbar-h);
  display: flex; align-items: center; gap: 14px; padding: 0 18px;
  background: color-mix(in srgb, var(--portal-nav-bg) 88%, transparent); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--portal-line);
}
.topbar .menu-btn { width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; border-radius: var(--r-sm); color: var(--portal-text); transition: background 0.2s; }
.topbar .menu-btn:hover { background: color-mix(in srgb, var(--portal-text-faint) 8%, transparent); }
.topbar .menu-btn svg { width: 22px; height: 22px; }
@media (min-width: 900px) { .topbar .menu-btn { display: none; } }
.topbar .brand { display: flex; align-items: center; gap: 12px; }
.topbar .brand img { height: 38px; filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.5)); }

/* Monograma de marca — usado quando o profissional não subiu logo. Veste o gradiente, a fonte
   e o raio da PERSONALIDADE da marca (não da MR): cada cliente ganha uma assinatura própria. */
.brand-mono {
  display: inline-flex; align-items: center; justify-content: center;
  height: 38px; min-width: 38px; padding: 0 11px;
  border-radius: var(--r-sm);
  background: var(--grad-aco); color: #fff;
  font-family: var(--font-display); font-weight: var(--fw-heading);
  letter-spacing: var(--tracking-heading);
  font-size: 1.12rem; line-height: 1;
  border: 1px solid color-mix(in srgb, #fff 16%, transparent);
  box-shadow: var(--shadow-soft), inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.32);
  user-select: none;
}
.rail .rail-head .brand-mono { height: 40px; min-width: 40px; font-size: 1.18rem; }

/* Wordmark de marca — quando o tenant não subiu logo de login, o nome dele escrito na fonte de
   display da marca (gradiente de marca no texto). Mata o logo do MR na tela de entrada. */
.brand-wordmark {
  display: inline-block; font-family: var(--font-display); font-weight: var(--fw-heading);
  font-size: clamp(1.5rem, 6vw, 2.1rem); letter-spacing: var(--tracking-heading); line-height: 1.04;
  background: var(--grad-aco); -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: var(--steel-bright);
}

/* Tela de simulação expirada/ausente (modo demo sem sessão válida) */
.sim-expirada {
  position: relative; z-index: 1; max-width: 560px; margin: 0 auto; min-height: 100dvh;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  gap: 15px; padding: 32px 24px; text-align: center;
}
.sim-expirada .se-eyebrow {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--portal-text-faint);
}
.sim-expirada h1 {
  font-family: var(--font-display); font-weight: var(--fw-heading); letter-spacing: var(--tracking-heading);
  font-size: clamp(1.8rem, 6vw, 2.6rem); line-height: 1.05; color: var(--portal-text); margin: 0;
}
.sim-expirada p { color: var(--portal-text-dim); font-size: 1rem; line-height: 1.6; max-width: 48ch; margin: 0; }
.sim-expirada button {
  margin-top: 10px; padding: 13px 28px; border: none; cursor: pointer; border-radius: var(--r-pill);
  font-family: var(--font-body); font-weight: 600; font-size: 0.95rem; color: #fff;
  background: linear-gradient(180deg, var(--steel-bright), var(--steel)); box-shadow: var(--shadow-soft);
  transition: filter 0.18s var(--ease);
}
.sim-expirada button:hover { filter: brightness(1.07); }
.topbar .spacer { flex: 1; }
.topbar .who { display: flex; align-items: center; gap: 11px; }
.topbar .who .avatar {
  width: 38px; height: 38px; border-radius: 50%; overflow: hidden;
  background: var(--grad-aco); display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 700; color: #fff; font-size: 0.95rem;
  border: 1px solid var(--portal-line-strong); flex-shrink: 0;
}
.topbar .who .avatar img { width: 100%; height: 100%; object-fit: cover; }
.topbar .who .meta { display: none; line-height: 1.2; }
@media (min-width: 560px) { .topbar .who .meta { display: block; } }
.topbar .who .meta .nm { font-weight: 600; font-size: 0.9rem; }
.topbar .who .meta .rl { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--portal-text-faint); }

.shell { display: flex; align-items: stretch; }

/* barra lateral (rail) */
.rail {
  position: fixed; top: 0; left: 0; bottom: 0; width: var(--rail); z-index: 40;
  background: var(--portal-nav-bg); border-right: 1px solid var(--portal-line);
  padding: 22px 16px; display: flex; flex-direction: column;
  transform: translateX(-105%); transition: transform 0.32s var(--ease);
  overflow-y: auto;
}
.rail.open { transform: translateX(0); box-shadow: var(--shadow-lift); }
@media (min-width: 900px) {
  .rail { transform: none; top: var(--topbar-h); box-shadow: none; }
}
.rail .rail-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 26px; padding: 0 6px; }
.rail .rail-head img { height: 38px; filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.5)); }
.rail .rail-close { width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; border-radius: 8px; color: var(--portal-text-dim); }
.rail .rail-close:hover { background: color-mix(in srgb, var(--portal-text-faint) 8%, transparent); color: var(--portal-text); }
.rail .rail-close svg { width: 18px; height: 18px; }
@media (min-width: 900px) { .rail .rail-head { display: none; } }

.nav-section-label { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); padding: 0 12px; margin-bottom: 12px; opacity: 0.8; }
.nav-list { display: flex; flex-direction: column; gap: 3px; }
.nav-item {
  display: flex; align-items: center; gap: 13px; padding: 12px 12px; border-radius: var(--r-sm);
  color: var(--portal-text-dim); font-size: 0.94rem; font-weight: 500; position: relative;
  transition: background 0.2s, color 0.2s;
}
.nav-item svg { width: 21px; height: 21px; flex-shrink: 0; color: var(--portal-text-faint); transition: color 0.2s, transform 0.2s; }
.nav-item:hover { background: color-mix(in srgb, var(--portal-text-faint) 6%, transparent); color: var(--portal-text); }
.nav-item:hover svg { transform: translateX(1px); }
.nav-item.active { background: linear-gradient(100deg, color-mix(in srgb, var(--steel) 26%, transparent), color-mix(in srgb, var(--steel) 4%, transparent)); color: #fff; }
.nav-item.active svg { color: var(--steel-bright); }
.nav-item.active::before { content: ""; position: absolute; left: -16px; top: 8px; bottom: 8px; width: 3px; border-radius: 0 3px 3px 0; background: var(--steel-bright); }

/* selo de notificação (estilo WhatsApp) — nº de dúvidas pendentes sobre o ícone da aba "Dúvidas dos pacientes" */
.nav-ico { position: relative; display: inline-flex; flex-shrink: 0; }
.nav-badge {
  position: absolute; top: -6px; right: -7px; min-width: 16px; height: 16px; padding: 0 4px; box-sizing: border-box;
  display: inline-flex; align-items: center; justify-content: center; border-radius: 8px;
  background: #ef4444; color: #fff; font-family: var(--font-mono); font-size: 0.62rem; font-weight: 700; line-height: 1;
  box-shadow: 0 0 0 2px var(--portal-bg); pointer-events: none;
}

/* alça de arrastar (6 pontinhos) por aba — cada usuário reordena o próprio menu; Início fica fixo */
.nav-row { display: flex; align-items: center; gap: 2px; }
.nav-row .nav-item { flex: 1 1 auto; min-width: 0; }
.nav-row.dragging { opacity: 0.55; background: color-mix(in srgb, var(--steel-bright) 8%, transparent); border-radius: var(--r-sm); }
.nav-drag {
  flex: none; display: inline-flex; align-items: center; justify-content: center;
  width: 34px; min-height: 40px; border: 0; background: none; color: var(--portal-text-faint);
  cursor: grab; border-radius: var(--r-sm); touch-action: none; opacity: 0.45;
  transition: opacity 0.16s var(--ease), color 0.16s var(--ease), background 0.16s var(--ease);
}
.nav-drag:hover { opacity: 1; color: var(--portal-text); background: rgba(237, 255, 255, 0.06); }
.nav-drag:active { cursor: grabbing; }
.nav-drag svg { width: 16px; height: 16px; }
/* grupos do menu (accordion) — Nutrição / Personal Trainer */
.nav-grupo { display: flex; flex-direction: column; }
.nav-grupo-row { display: flex; align-items: center; gap: 2px; }
.nav-grupo-row .nav-grupo-cab { flex: 1 1 auto; min-width: 0; }
.nav-grupo-cab { background: none; border: 0; width: 100%; text-align: left; font: inherit; cursor: pointer; }
.nav-grupo-cab .nav-chev { width: 15px; height: 15px; margin-left: auto; color: var(--portal-text-faint); transition: transform .24s var(--ease); flex-shrink: 0; }
.nav-grupo.aberto .nav-grupo-cab .nav-chev { transform: rotate(180deg); }
.nav-subs { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .24s var(--ease); }
.nav-grupo.aberto .nav-subs { grid-template-rows: 1fr; }
.nav-subs-in { overflow: hidden; min-height: 0; display: flex; flex-direction: column; gap: 3px; padding: 3px 0 2px; }
/* sub-aba arrastável: link ocupa a linha, alça de 6 pontinhos à direita (só reordena dentro do grupo) */
.nav-sub-row { display: flex; align-items: center; gap: 2px; }
.nav-sub-row .nav-sub { flex: 1 1 auto; min-width: 0; }
.nav-drag-sub { width: 30px; min-height: 36px; opacity: 0.55; }
.nav-drag-sub:hover { opacity: 1; }
.nav-sub { display: flex; align-items: center; gap: 11px; padding: 9px 12px 9px 24px; border-radius: var(--r-sm); color: var(--portal-text-dim); font-size: 0.9rem; position: relative; transition: background .2s, color .2s; }
.nav-sub svg { width: 18px; height: 18px; flex-shrink: 0; color: var(--portal-text-faint); transition: color .2s, transform .2s; }
.nav-sub:hover { background: color-mix(in srgb, var(--portal-text-faint) 6%, transparent); color: var(--portal-text); }
.nav-sub:hover svg { transform: translateX(1px); }
.nav-sub.active { background: linear-gradient(100deg, color-mix(in srgb, var(--steel) 22%, transparent), color-mix(in srgb, var(--steel) 3%, transparent)); color: #fff; }
.nav-sub.active svg { color: var(--steel-bright); }
.nav-sub.active::before { content: ""; position: absolute; left: -16px; top: 7px; bottom: 7px; width: 3px; border-radius: 0 3px 3px 0; background: var(--steel-bright); }

.rail-foot { margin-top: auto; padding-top: 18px; border-top: 1px solid var(--portal-line); }
.rail-foot .logout { display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: var(--r-sm); color: var(--portal-text-dim); width: 100%; font-size: 0.92rem; transition: background 0.2s, color 0.2s; }
.rail-foot .logout:hover { background: rgba(217, 99, 127, 0.10); color: #f0b6c3; }
.rail-foot .logout svg { width: 20px; height: 20px; }

/* backdrop do drawer no mobile */
.scrim { position: fixed; inset: 0; z-index: 35; background: rgba(4, 9, 17, 0.6); backdrop-filter: blur(2px); opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s; }
.scrim.show { opacity: 1; visibility: visible; }
@media (min-width: 900px) { .scrim { display: none; } }

/* área de conteúdo */
.content { flex: 1; min-width: 0; padding: 26px 18px 80px; }
@media (min-width: 900px) { .content { margin-left: var(--rail); padding: 38px 42px 90px; } }
.content-inner { max-width: var(--content-max); margin: 0 auto; }

.view-head { margin-bottom: 30px; }
.view-head .eyebrow { display: block; margin-bottom: 12px; }
.view-head h2 { font-size: clamp(1.7rem, 4vw, 2.5rem); }
.view-head p { color: var(--portal-text-dim); margin-top: 12px; max-width: 56ch; font-size: 1.02rem; }

/* saudação do dashboard */
.greet {
  position: relative; overflow: hidden; border: 1px solid var(--portal-line); border-radius: var(--r-lg);
  background: linear-gradient(150deg, color-mix(in srgb, var(--steel) 16%, transparent), color-mix(in srgb, var(--portal-fill) 30%, transparent));
  padding: 32px 30px; margin-bottom: 34px;
}
.greet::before { content: ""; position: absolute; width: 300px; height: 300px; border-radius: 50%; top: -130px; right: -80px; background: radial-gradient(circle, color-mix(in srgb, var(--steel-bright) 24%, transparent), transparent 65%); }
.greet .inner { position: relative; z-index: 2; }
.greet h2 { font-size: clamp(1.5rem, 3.4vw, 2.2rem); margin-bottom: 10px; }
.greet h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--portal-text-faint); }
.greet p { color: var(--portal-text-dim); max-width: 54ch; }

/* grade de atalhos no início */
.tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (min-width: 680px) { .tiles { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 980px) { .tiles { grid-template-columns: repeat(4, 1fr); } }
.tile {
  border: 1px solid var(--portal-line); border-radius: var(--r-md); background: var(--portal-card-bg);
  padding: 22px 20px; display: flex; flex-direction: column; gap: 14px; min-height: 132px;
  transition: border-color 0.25s var(--ease), transform 0.25s var(--ease);
}
.tile:hover { border-color: var(--steel); transform: translateY(-3px); }
.tile .ic { width: 44px; height: 44px; border-radius: 11px; display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--steel) 16%, transparent); color: var(--portal-icon); }
.tile .ic svg { width: 23px; height: 23px; }
.tile .tl { font-family: var(--font-display); font-weight: 600; font-size: 1.04rem; margin-top: auto; }
.tile .ds { font-size: 0.82rem; color: var(--portal-text-dim); }
/* Início agrupada por seção (Nutrição / Personal Trainer / Geral) */
.home-sec { margin-top: 30px; }
.home-sec:first-of-type { margin-top: 6px; }
.home-sec-tit { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--portal-text-faint); margin-bottom: 14px; }
.home-sec-tit svg { width: 19px; height: 19px; color: var(--portal-icon); flex-shrink: 0; }
.home-sec-tit::after { content: ""; flex: 1; height: 1px; background: linear-gradient(90deg, var(--portal-line), transparent); }

/* estado vazio premium das abas (fundação) */
.empty {
  border: 1px solid var(--portal-line); border-radius: var(--r-lg); background: var(--portal-card-bg);
  padding: 56px 34px; text-align: center; display: flex; flex-direction: column; align-items: center;
}
.empty .badge {
  width: 76px; height: 76px; border-radius: 20px; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(160deg, color-mix(in srgb, var(--steel) 24%, transparent), color-mix(in srgb, var(--steel) 5%, transparent));
  border: 1px solid var(--portal-line-strong); color: var(--steel-bright); margin-bottom: 26px;
}
.empty .badge svg { width: 36px; height: 36px; }
.empty h3 { font-size: 1.4rem; margin-bottom: 12px; }
.empty p { color: var(--portal-text-dim); max-width: 46ch; margin-bottom: 6px; }
.empty .soon { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); margin-top: 20px; padding: 7px 14px; border: 1px solid var(--portal-line); border-radius: var(--r-pill); }

/* tela de carregamento inicial */
.boot { position: fixed; inset: 0; z-index: 60; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 26px; background: var(--portal-bg); }
.boot img { width: 150px; opacity: 0.92; animation: breathe 2.4s var(--ease) infinite; }
.boot .bar { width: 168px; height: 3px; border-radius: 3px; background: var(--portal-line); overflow: hidden; }
.boot .bar i { display: block; height: 100%; width: 40%; border-radius: 3px; background: var(--grad-aco); animation: slide 1.25s var(--ease) infinite; }
@keyframes breathe { 0%, 100% { opacity: 0.5; transform: scale(0.985); } 50% { opacity: 1; transform: scale(1); } }
@keyframes slide { 0% { transform: translateX(-120%); } 100% { transform: translateX(320%); } }

.fade-in { animation: fadeIn 0.5s var(--ease) backwards; }   /* backwards (não both): o transform volta a none após a animação, p/ não criar containing block que quebra o watermark fixed */
@keyframes fadeIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

/* spinner no botão */
.spin { width: 18px; height: 18px; border: 2px solid rgba(255,255,255,0.4); border-top-color: #fff; border-radius: 50%; animation: rot 0.7s linear infinite; }
@keyframes rot { to { transform: rotate(360deg); } }

/* =========================================================
   BIBLIOTECA DE E-BOOKS — grade de capas tipográficas
   (sem foto de banco: a capa é um momento de marca)
   ========================================================= */
.book-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
@media (min-width: 560px) { .book-grid { gap: 20px; } }
@media (min-width: 760px) { .book-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1200px) { .book-grid { grid-template-columns: repeat(4, 1fr); } }

.book { display: flex; flex-direction: column; }

/* a capa — gradiente metálico + monograma gravado + título com hierarquia */
.book .cover {
  position: relative; overflow: hidden; isolation: isolate;
  display: flex; flex-direction: column; aspect-ratio: 3 / 4;
  padding: 20px 18px; border: 1px solid var(--portal-line-strong);
  border-radius: var(--r-md) var(--r-md) 5px 5px;
  background:
    radial-gradient(130% 90% at 100% 0%, color-mix(in srgb, var(--steel-bright) 24%, transparent), transparent 56%),
    linear-gradient(158deg, var(--navy-600) 0%, var(--navy-700) 56%, var(--navy-900) 100%);
  box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(237, 255, 255, 0.14);
  transition: transform 0.28s var(--ease), border-color 0.28s var(--ease), box-shadow 0.28s var(--ease);
}
/* faixa de brilho metálico no topo, em soft-light pra "lâmina" de aço */
.book .cover::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: linear-gradient(155deg, rgba(155, 187, 224, 0.30), transparent 42%);
  mix-blend-mode: soft-light;
}
.book .cover:hover { transform: translateY(-4px); border-color: var(--steel); box-shadow: var(--shadow-lift), inset 0 1px 0 rgba(237, 255, 255, 0.2); }

/* monograma MR gravado no canto, marca-d'água discreta */
.book .cover .mark {
  position: absolute; right: -22px; bottom: -18px; width: 158px; z-index: 0;
  opacity: 0.12; filter: grayscale(1) brightness(1.6); pointer-events: none;
  transition: opacity 0.28s var(--ease);
}
.book .cover:hover .mark { opacity: 0.2; }

.book .cover .cat {
  position: relative; z-index: 1;
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--platinum);
  padding-right: 44px; /* reserva a zona do selo "PDF" (absoluto, top/right 13px) — evita sobreposição em categorias longas */
}
.book .cover h3 {
  position: relative; z-index: 1; margin-top: auto;
  font-family: var(--font-display); font-weight: 700; line-height: 1.1;
  font-size: clamp(1.02rem, 2.4vw, 1.28rem); letter-spacing: -0.015em;
  text-wrap: balance; color: var(--portal-text);
}
.book .cover .note {
  position: relative; z-index: 1; margin-top: 7px;
  font-size: 0.78rem; line-height: 1.4; color: var(--portal-text-dim);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.book .cover .seal {
  position: absolute; top: 13px; right: 13px; z-index: 1;
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em;
  color: var(--portal-text-faint); padding: 4px 8px; border: 1px solid var(--portal-line-strong);
  border-radius: var(--r-pill); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); backdrop-filter: blur(4px);
}

/* ações abrir / baixar */
.book .foot { display: flex; gap: 8px; margin-top: 11px; }
.book .foot a {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  padding: 10px 12px; border-radius: var(--r-sm); font-size: 0.82rem; font-weight: 600;
  transition: transform 0.18s var(--ease), border-color 0.22s, color 0.22s, box-shadow 0.22s;
}
.book .foot a svg { width: 16px; height: 16px; }
.book .foot .bk-open {
  flex: 1; color: #fff; background: linear-gradient(180deg, var(--steel-bright), var(--steel));
  box-shadow: inset 0 1px 0 rgba(237, 255, 255, 0.26), 0 7px 18px color-mix(in srgb, var(--steel) 32%, transparent);
}
.book .foot .bk-open:hover { transform: translateY(-1px); box-shadow: inset 0 1px 0 rgba(237, 255, 255, 0.3), 0 11px 24px color-mix(in srgb, var(--steel) 42%, transparent); }
.book .foot .bk-dl { border: 1px solid var(--portal-line-strong); color: var(--portal-text-dim); }
.book .foot .bk-dl:hover { border-color: var(--portal-text-faint); color: var(--portal-text); }
.book .foot .bk-dl span { display: none; }
@media (min-width: 380px) { .book .foot .bk-dl span { display: inline; } }

/* capa fotográfica — a foto do próprio e-book com véu navy pra tipografia ler */
.book .cover .photo {
  position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%;
  object-fit: cover; filter: saturate(1.1) contrast(1.04);
  transition: transform 0.55s var(--ease);
}
.book .cover .veil {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(8, 18, 32, 0.55) 0%,
    rgba(8, 18, 32, 0.12) 30%,
    rgba(8, 18, 32, 0.16) 50%,
    rgba(7, 16, 29, 0.84) 78%,
    rgba(6, 13, 24, 0.95) 100%
  );
}
.book.has-photo .cover::before { opacity: 0.45; } /* lâmina metálica mais discreta sobre foto */
.book.has-photo .cover:hover .photo { transform: scale(1.045); }
/* fotos com topo claro (salada, marmita): sombra garante a leitura sem escurecer a foto inteira */
.book.has-photo .cover .cat { text-shadow: 0 1px 10px rgba(6, 13, 24, 0.9), 0 0 3px rgba(6, 13, 24, 0.65); }
.book.has-photo .cover h3 { text-shadow: 0 1px 12px rgba(6, 13, 24, 0.75); }
.book.has-photo .cover .note { text-shadow: 0 1px 10px rgba(6, 13, 24, 0.75); }

/* skeleton de carregamento */
.book.is-skeleton .cover {
  aspect-ratio: 3 / 4; border-radius: var(--r-md); border: 1px solid var(--portal-line); padding: 0;
  background: linear-gradient(110deg, var(--navy-700) 28%, var(--navy-600) 48%, var(--navy-700) 68%);
  background-size: 220% 100%; animation: shimmer 1.4s linear infinite; box-shadow: none;
}
.book.is-skeleton .cover::before { display: none; }
.book.is-skeleton .foot { margin-top: 11px; }
.sk-pill { height: 36px; border-radius: var(--r-sm); background: var(--navy-700); flex: 1; }
.sk-pill.alt { max-width: 92px; flex: none; }
@keyframes shimmer { to { background-position: -220% 0; } }

/* ===== Administração — gestão da biblioteca ===== */
.admin-block {
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-md);
  background: linear-gradient(165deg, rgba(26, 51, 80, 0.55), rgba(10, 26, 46, 0.72));
  box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(237, 255, 255, 0.1);
  padding: 22px 20px;
}
.admin-block .ab-head h3 {
  font-family: var(--font-display); font-weight: 700; font-size: 1.05rem;
  letter-spacing: -0.01em; color: var(--portal-text);
}
.admin-block .ab-head p {
  margin-top: 6px; max-width: 62ch;
  font-size: 0.82rem; line-height: 1.5; color: var(--portal-text-dim);
}
/* botão circular de minimizar/expandir cada seção da Administração */
.ab-head { position: relative; padding-right: 84px; }
/* alça de arrastar a seção inteira — fica à esquerda do botão minimizar (−/+) */
.ab-head .ab-drag { position: absolute; top: -2px; right: 42px; width: 36px; height: 36px; border-radius: 50%; opacity: 0.6; }
.ab-head .ab-drag:hover { opacity: 1; background: rgba(237, 255, 255, 0.06); }
.ab-head .ab-drag:active { cursor: grabbing; }
.ab-toggle {
  position: absolute; top: -2px; right: 0; width: 36px; height: 36px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--portal-line-strong); background: rgba(237, 255, 255, 0.04); color: var(--portal-text-dim);
  cursor: pointer; transition: color 0.18s var(--ease), border-color 0.18s var(--ease), background 0.18s var(--ease);
}
.ab-toggle:hover { color: var(--portal-text); border-color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 12%, transparent); }
.ab-toggle svg { width: 16px; height: 16px; }
.admin-block.is-collapsed { padding-top: 16px; padding-bottom: 16px; }
.admin-block.is-collapsed > *:not(.ab-head) { display: none; }
.admin-block.is-collapsed .ab-head p { display: none; }
/* card colapsado é baixo: centraliza o −/+ e a alça no card (senão grudam na borda de baixo e parecem "saindo") */
.admin-block.is-collapsed .ab-head .ab-toggle,
.admin-block.is-collapsed .ab-head .ab-drag { top: 50%; transform: translateY(-50%); }
.admin-row {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 13px 2px; border-bottom: 1px solid var(--portal-line);
}
.admin-row:first-of-type { margin-top: 14px; border-top: 1px solid var(--portal-line); }
.admin-row:last-child { border-bottom: 0; }
.ar-acoes { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: none; }
.admin-row .ar-info, .an-aval-top .ar-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.admin-row .ar-info strong, .an-aval-top .ar-info strong {
  font-family: var(--font-display); font-weight: 600; font-size: 0.93rem; color: var(--portal-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.admin-row .ar-info span, .an-aval-top .ar-info span {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--portal-text-faint);
}
.admin-row .ar-info span em { color: var(--portal-text-dim); font-style: normal; }

/* marquee: nome que não cabe rola — desktop no hover, toque sozinho (JS mede o overflow e liga .is-mq/.mq-go) */
.mq-text { overflow: hidden; }
.mq-text > .mq-run { display: block; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.mq-text.is-mq.mq-go > .mq-run {
  display: inline-block; max-width: none; overflow: visible; text-overflow: clip;
  will-change: transform; animation: mq-roll var(--mq-dur, 6s) linear infinite alternate;
}
@keyframes mq-roll {
  0%, 16% { transform: translateX(0); }
  84%, 100% { transform: translateX(var(--mq-shift, 0px)); }
}
@media (prefers-reduced-motion: reduce) {
  .mq-text.is-mq.mq-go > .mq-run { display: block; overflow: hidden; text-overflow: ellipsis; animation: none; }
}

/* switch de liberação */
.switch { display: flex; align-items: center; gap: 9px; cursor: pointer; flex: none; }
.switch input { position: absolute; opacity: 0; pointer-events: none; }
.switch .sw-track {
  position: relative; width: 42px; height: 23px; border-radius: var(--r-pill);
  background: rgba(237, 255, 255, 0.08); border: 1px solid var(--portal-line-strong);
  transition: background 0.25s var(--ease), border-color 0.25s var(--ease);
}
.switch .sw-thumb {
  position: absolute; top: 2px; left: 2px; width: 17px; height: 17px; border-radius: 50%;
  background: var(--portal-text-dim);
  transition: transform 0.25s var(--ease), background 0.25s var(--ease);
}
.switch input:checked + .sw-track { background: color-mix(in srgb, var(--steel-bright) 50%, transparent); border-color: var(--steel); }
.switch input:checked + .sw-track .sw-thumb { transform: translateX(19px); background: #fff; }
.switch input:disabled + .sw-track { opacity: 0.5; }
.switch input:focus-visible + .sw-track { outline: 2px solid var(--steel-bright); outline-offset: 2px; }
.switch .sw-label {
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--portal-text-dim);
}

/* ===== Leitor de e-book embutido — a leitura acontece DENTRO do portal ===== */
.leitor {
  position: fixed; inset: 0; z-index: 200; display: flex; flex-direction: column;
  background:
    radial-gradient(120% 70% at 80% -10%, color-mix(in srgb, var(--steel-bright) 10%, transparent), transparent 55%),
    linear-gradient(170deg, var(--navy-800) 0%, var(--navy-900) 52%, color-mix(in srgb, var(--portal-fill) 78%, #000) 100%);
}
/* barra superior compartilhada: leitor de PDF e leitura da dieta (.dieta-view) */
:is(.leitor, .dieta-view) .lt-bar {
  display: flex; align-items: center; gap: 12px; flex: none;
  padding: 10px 14px; border-bottom: 1px solid var(--portal-line-strong);
  background: color-mix(in srgb, var(--portal-fill) 78%, transparent); backdrop-filter: blur(10px);
}
:is(.leitor, .dieta-view) .lt-btn {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; flex: none; border-radius: var(--r-sm);
  border: 1px solid var(--portal-line-strong); background: rgba(237, 255, 255, 0.05);
  color: var(--portal-text); font-size: 1.05rem; line-height: 1; cursor: pointer;
  transition: border-color 0.2s var(--ease), background 0.2s var(--ease);
}
:is(.leitor, .dieta-view) .lt-btn:hover { border-color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 16%, transparent); }
:is(.leitor, .dieta-view) .lt-btn svg { width: 17px; height: 17px; }
:is(.leitor, .dieta-view) .lt-titulo { min-width: 0; flex: 1; display: flex; flex-direction: column; gap: 1px; }
:is(.leitor, .dieta-view) .lt-titulo strong {
  font-family: var(--font-display); font-weight: 600; font-size: 0.95rem; color: var(--portal-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
:is(.leitor, .dieta-view) .lt-titulo span {
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--portal-text-faint);
}
:is(.leitor, .dieta-view) .lt-acoes { display: flex; gap: 8px; flex: none; }
.leitor .lt-corpo { flex: 1; overflow: auto; -webkit-overflow-scrolling: touch; }
.leitor .lt-paginas { display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 18px 8px 40px; }
.leitor .lt-pag {
  background: var(--gold-bg); border-radius: 2px;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.5), 0 4px 12px rgba(0, 0, 0, 0.35);
}
.leitor .lt-pag canvas { display: block; border-radius: 2px; }

/* status de carregamento (download com progresso) */
.leitor .lt-status {
  min-height: 60vh; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 16px; padding: 24px; text-align: center;
}
.leitor .lt-status p { font-size: 0.92rem; color: var(--portal-text-dim); }
.leitor .lt-status .lt-erro { color: var(--portal-text); max-width: 40ch; }
.leitor .lt-spin {
  width: 34px; height: 34px; border-radius: 50%;
  border: 2.5px solid color-mix(in srgb, var(--portal-text-faint) 25%, transparent); border-top-color: var(--steel-bright);
  animation: lt-girar 0.9s linear infinite;
}
@keyframes lt-girar { to { transform: rotate(360deg); } }
.leitor .lt-track {
  width: min(320px, 70vw); height: 4px; border-radius: var(--r-pill);
  background: rgba(237, 255, 255, 0.08); overflow: hidden;
}
.leitor .lt-fill {
  height: 100%; width: 0; border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--steel), var(--steel-bright));
  transition: width 0.2s linear;
}

/* ===== Central do administrador ===== */
.admin-grid { display: flex; flex-direction: column; gap: 18px; }

/* busca + cadastro de pacientes */
.pa-busca {
  display: flex; align-items: center; gap: 10px; margin-bottom: 6px;
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-pill);
  background: color-mix(in srgb, var(--portal-fill) 55%, transparent); padding: 4px 8px 4px 16px;
}
.pa-busca .lupa { display: flex; color: var(--portal-text-faint); }
.pa-busca .lupa svg { width: 17px; height: 17px; }
.pa-busca input {
  flex: 1; min-width: 0; background: none; border: 0; outline: 0;
  color: var(--portal-text); font-size: 0.92rem; font-family: inherit;
  min-height: 40px; /* alvo de toque/foco ≥40px no mobile (era ~18px) */
}
.pa-busca input::placeholder { color: var(--portal-text-dim); opacity: 0.7; }
.pa-cadastro { display: flex; flex-direction: column; gap: 10px; margin: 12px 0 6px; padding: 14px; border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); background: color-mix(in srgb, var(--portal-fill) 30%, transparent); }
.cad-sec { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--portal-text-faint); }
.cad-grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(148px, 1fr)); gap: 8px; }
.cad-grade .cad-wide { grid-column: 1 / -1; }
.cad-cep-fb { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.04em; color: var(--portal-text-faint); min-height: 15px; margin-top: -4px; }
.cad-cep-fb.ok { color: #9fe3c0; }
.cad-cep-fb.erro { color: var(--gold-mid); }
.pa-cadastro input {
  width: 100%; padding: 11px 14px; border-radius: var(--r-sm);
  border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 55%, transparent);
  color: var(--portal-text); font-size: 0.9rem; font-family: inherit; outline: 0;
}
.pa-cadastro input:focus { border-color: var(--steel); }
.cad-ok { display: flex; flex-direction: column; gap: 7px; align-items: flex-start; padding: 13px 15px; border-radius: var(--r-md); border: 1px solid rgba(127, 214, 168, 0.4); background: rgba(127, 214, 168, 0.08); margin: 8px 0; }
.cad-ok strong { color: #c2ecd3; font-size: 0.96rem; }
.cad-ok span { color: var(--portal-text-dim); font-size: 0.85rem; }
/* biblioteca: botão de adicionar + escolha de arquivos do novo e-book */
.bk-topo { margin: 12px 0 2px; }
.bk-arquivos { display: flex; flex-wrap: wrap; gap: 12px 22px; }
.bk-file { display: flex; align-items: center; gap: 10px; min-width: 0; }
.bk-file .ex-arquivo-nome { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 220px; }

.btn-mini {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px; line-height: 1;
  padding: 9px 15px; min-height: 44px; border-radius: var(--r-pill); border: 0; cursor: pointer;
  background: linear-gradient(150deg, var(--steel-bright), var(--steel));
  color: #fff; font-weight: 600; font-size: 0.8rem; font-family: inherit;
  transition: transform 0.18s var(--ease), box-shadow 0.18s var(--ease);
}
.btn-mini svg { width: 15px; height: 15px; flex: none; }
.btn-mini:hover { transform: translateY(-1px); box-shadow: 0 9px 20px color-mix(in srgb, var(--steel) 40%, transparent); }
.btn-mini:disabled { opacity: 0.55; cursor: default; transform: none; box-shadow: none; }
.btn-mini.ghost { background: rgba(237, 255, 255, 0.06); border: 1px solid var(--portal-line-strong); color: var(--portal-text-dim); }
.btn-mini.ghost:hover { color: var(--portal-text); border-color: var(--portal-text-faint); box-shadow: none; }

/* paciente */
.paciente { border-bottom: 1px solid var(--portal-line); padding: 4px 0; }
.paciente:last-child { border-bottom: 0; }
.pa-linha { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 2px; flex-wrap: wrap; }
.pa-acoes { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.badge-status {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); color: var(--portal-text-dim);
}
.badge-status.ok { color: #9fe3c0; border-color: rgba(127, 214, 168, 0.45); background: rgba(127, 214, 168, 0.08); }
.badge-status.off { color: #f0a9a9; border-color: rgba(240, 169, 169, 0.4); background: rgba(240, 169, 169, 0.07); }
.badge-status.mid { color: var(--champagne, var(--gold)); border-color: color-mix(in srgb, var(--gold) 40%, transparent); }

/* ficha de abas por paciente */
.ficha-abas {
  margin: 4px 0 12px; padding: 14px; border: 1px solid var(--portal-line);
  border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 45%, transparent);
}
.fa-presets { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.fa-presets span { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--portal-text-faint); }
.fa-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 8px 14px; margin-bottom: 14px; }
.aba-check { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 0.85rem; color: var(--portal-text-dim); }
.aba-check input { accent-color: var(--steel-bright); width: 15px; height: 15px; }
.aba-check input:checked + span { color: var(--portal-text); }
.fa-feedback { margin-left: 10px; font-size: 0.78rem; color: var(--portal-text-faint); }
/* Tipo de aluno (Nutrição / Personal / ambos) — seletor proeminente + ajuste fino recolhível */
.fa-tipo { display: flex; flex-direction: column; gap: 9px; margin-bottom: 14px; }
.fa-tipo-lbl { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--portal-text-faint); }
.fa-tipo-opts { display: flex; gap: 8px; flex-wrap: wrap; }
.fa-tipo-opt { min-height: 42px; padding: 0 16px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); color: var(--portal-text-dim); cursor: pointer; font-size: 0.86rem; transition: border-color .18s var(--ease), background .18s var(--ease), color .18s var(--ease); }
.fa-tipo-opt:hover { border-color: var(--portal-text-faint); color: var(--portal-text); }
.fa-tipo-opt.ativa { border-color: var(--steel-bright); background: linear-gradient(100deg, color-mix(in srgb, var(--steel) 28%, transparent), color-mix(in srgb, var(--steel) 6%, transparent)); color: #fff; }
.fa-fino { margin-top: 2px; }
.fa-fino > summary { font-size: 0.82rem; color: var(--portal-text-faint); cursor: pointer; padding: 6px 0; }
.fa-fino > summary:hover { color: var(--portal-text); }
.fa-fino[open] > summary { margin-bottom: 10px; }
.pa-selos { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
.pa-selos .pa-lgpd { margin-top: 0; }
.badge-tipo { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 3px 8px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); color: var(--portal-text-faint); white-space: nowrap; }
.badge-tipo.nutricao { color: var(--gold-mid); border-color: color-mix(in srgb, var(--gold) 45%, transparent); background: color-mix(in srgb, var(--gold) 7%, transparent); }
.badge-tipo.personal { color: var(--steel-light); border-color: color-mix(in srgb, var(--steel-bright) 45%, transparent); background: color-mix(in srgb, var(--steel-bright) 7%, transparent); }
.badge-tipo.completo { color: #cfd6dd; border-color: rgba(199, 207, 214, 0.35); background: rgba(199, 207, 214, 0.05); }
.badge-acesso { font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 8px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); white-space: nowrap; }
.badge-acesso.pendente { color: var(--gold-mid); border-color: color-mix(in srgb, var(--gold-mid) 40%, transparent); background: color-mix(in srgb, var(--gold-mid) 7%, transparent); }
.badge-acesso.enviado { color: var(--steel-light); border-color: color-mix(in srgb, var(--steel-bright) 40%, transparent); background: color-mix(in srgb, var(--steel-bright) 8%, transparent); }

/* punho de arrastar */
.drag-handle {
  display: flex; align-items: center; justify-content: center; flex: none;
  width: 36px; height: 40px; border: 0; background: none; color: var(--portal-text-dim);
  cursor: grab; border-radius: var(--r-sm); touch-action: none;
}
.drag-handle:hover { color: var(--portal-text); background: rgba(237, 255, 255, 0.05); }
.drag-handle svg { width: 16px; height: 16px; }
.drag-handle.is-fixo { cursor: default; color: var(--portal-text-dim); opacity: 0.28; }
.drag-handle.is-fixo:hover { background: none; color: var(--portal-text-dim); }
[data-drag-item].dragging { opacity: 0.55; background: color-mix(in srgb, var(--steel-bright) 8%, transparent); border-radius: var(--r-sm); }
[data-drag-item] { user-select: none; }

/* link de convite (cadastro / novo acesso / solicitações) */
.convite { display: flex; gap: 8px; margin: 8px 0 4px; }
.convite input {
  flex: 1; min-width: 0; padding: 10px 12px; border-radius: var(--r-sm);
  border: 1px solid rgba(127, 214, 168, 0.4); background: rgba(127, 214, 168, 0.06);
  color: var(--portal-text); font-family: var(--font-mono); font-size: 0.72rem; outline: 0;
}
.solic-link:not(:empty) { padding: 6px 2px 12px; }
/* painel de envio do acesso (Entrega 2 do onboarding) */
.env-acesso { display: flex; flex-direction: column; gap: 10px; margin-top: 8px; padding: 14px; border: 1px solid color-mix(in srgb, var(--steel-bright) 35%, transparent); border-radius: var(--r-md); background: color-mix(in srgb, var(--steel-bright) 6%, transparent); }
.env-acesso .convite { margin: 0; }
.env-canais { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.env-aviso { font-size: 0.78rem; color: var(--portal-text-faint); font-style: italic; }
.btn-mini:disabled { opacity: 0.4; cursor: not-allowed; }
.mm-nota { font-size: 0.78rem; color: var(--portal-text-dim); }
.mm-nota strong { color: var(--portal-text); }

/* ===== Plano alimentar ===== */
.obj-badge {
  display: inline-flex; flex-direction: column; gap: 1px; padding: 8px 14px;
  border: 1px solid color-mix(in srgb, var(--gold) 55%, transparent); border-radius: var(--r-sm);
  background: color-mix(in srgb, var(--gold) 9%, transparent);
}
.obj-badge strong { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold); }
.obj-badge span { font-size: 0.72rem; color: var(--gold-mid); }

.plano-card {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 18px 20px; margin-bottom: 12px;
  background: linear-gradient(165deg, rgba(26, 51, 80, 0.5), rgba(10, 26, 46, 0.7));
}
.plano-card.destaque { border-color: color-mix(in srgb, var(--gold) 45%, transparent); box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(237, 255, 255, 0.1); }
.plano-card .pc-info { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.plano-card .pc-atual { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: #9fe3c0; }
.plano-card h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.06rem; color: var(--portal-text); }
.plano-card .pc-acoes { display: flex; gap: 8px; flex-wrap: wrap; }
.plano-hist-titulo { margin: 20px 0 10px; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); }
.dieta-vigencia { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; color: var(--portal-text-dim); }

/* ===== Plano alimentar — leitura (PROTOCOLO EDITORIAL, papel champagne) ===== */
.dieta-view { position: fixed; inset: 0; z-index: 200; display: flex; flex-direction: column; background: linear-gradient(170deg, var(--navy-800), var(--navy-900) 60%); }
.dieta-scroll { flex: 1; overflow: auto; padding: 28px 14px 64px; }
.dieta-folha { max-width: 760px; margin: 0 auto; }

/* papel: canto vivo sobre o navy, sem sombra — a fita champagne no topo é a lombada do dossiê */
.dieta {
  --ink-line: color-mix(in srgb, var(--portal-fill) 14%, transparent);
  --ink-strong: color-mix(in srgb, var(--portal-fill) 55%, transparent);
  position: relative; overflow: hidden;
  background: var(--doc-paper); color: var(--doc-ink);
  border-top: 3px solid var(--gold);
  border-radius: 0; box-shadow: none;
  padding: clamp(26px, 6vw, 56px) clamp(20px, 5vw, 52px) clamp(38px, 8vw, 64px);
}
/* conteúdo acima do monograma fantasma */
.dieta > * { position: relative; z-index: 1; }

/* assinatura 2: monograma MR fantasma atrás do masthead */
.dieta::before {
  content: var(--brand-sigla, "");
  position: absolute; z-index: 0;
  top: clamp(8px, 2vw, 18px); right: clamp(10px, 3vw, 26px);
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(88px, 18vw, 150px); line-height: 0.8; letter-spacing: -0.06em;
  color: color-mix(in srgb, var(--gold-ink) 8%, transparent);
  pointer-events: none; user-select: none;
}

/* assinatura 3: colofão mono no pé do documento */
.dieta::after {
  content: var(--brand-colofao, "");
  position: relative; z-index: 1; display: block;
  margin-top: 56px; padding-top: 12px; border-top: 1px solid var(--ink-line);
  font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.26em;
  color: color-mix(in srgb, var(--portal-fill) 45%, transparent);
}

/* masthead — a tipografia comanda o documento */
.dieta-cabeca { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; flex-wrap: wrap; border-bottom: 1px solid var(--ink-strong); padding-bottom: 18px; margin-bottom: 30px; }
.dieta-cabeca h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.65rem, 6vw, 2.35rem); letter-spacing: -0.03em; line-height: 1.04; color: var(--navy-900); }
.dieta-cabeca .dieta-vigencia { color: var(--gold-ink); letter-spacing: 0.18em; }

/* objetivo = tinta champagne, nunca caixa preenchida */
.dieta .obj-badge { background: transparent; border: 1px solid color-mix(in srgb, var(--gold-ink) 45%, transparent); border-radius: 2px; padding: 7px 12px; }
.dieta .obj-badge strong { color: var(--gold-ink); }
.dieta .obj-badge span { color: var(--gold-ink); }

/* orientações — quadro champagne (invertido do navy): alivia o peso, cores da marca em azul */
.dieta-orientacoes {
  background: linear-gradient(165deg, color-mix(in srgb, var(--gold) 58%, #150d02), color-mix(in srgb, var(--gold) 40%, #120b02)); color: color-mix(in srgb, var(--gold) 38%, #ffffff);
  border: 1px solid color-mix(in srgb, var(--gold) 32%, transparent); border-radius: 8px;
  padding: 18px 20px; margin-bottom: 26px;
  box-shadow: 0 16px 30px -20px rgba(0, 0, 0, 0.55), inset 0 1px 0 rgba(243, 232, 205, 0.1);
}
.dieta-orientacoes h4 { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-mid); margin-bottom: 10px; }
.dieta-orientacoes ul { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.dieta-orientacoes li { position: relative; padding-left: 18px; font-size: 0.92rem; font-weight: 600; line-height: 1.6; max-width: 60ch; }
.dieta-orientacoes li::before { content: ""; position: absolute; left: 0; top: 0.72em; width: 12px; height: 1px; background: var(--gold-mid); }

/* ===== Meus suplementos — botão no masthead + lista com as marcas ===== */
.dc-acoes { display: flex; flex-direction: row; align-items: center; gap: clamp(20px, 6vw, 52px); flex-wrap: wrap; }
.btn-suplementos {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: color-mix(in srgb, var(--gold) 38%, #ffffff); background: linear-gradient(150deg, var(--navy-600), var(--navy-900));
  border: 1px solid color-mix(in srgb, var(--gold) 32%, transparent); border-radius: 999px; padding: 9px 15px;
  box-shadow: inset 0 1px 0 rgba(243, 232, 205, 0.1), 0 8px 18px -10px rgba(0, 0, 0, 0.5);
  transition: transform 0.16s var(--ease), box-shadow 0.16s var(--ease);
}
.btn-suplementos:hover { transform: translateY(-1px); box-shadow: inset 0 1px 0 rgba(243, 232, 205, 0.12), 0 12px 22px -10px rgba(0, 0, 0, 0.6); }
.btn-suplementos svg { width: 15px; height: 15px; color: var(--gold-mid); }

.sup-lista { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.sup-item { border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 14px 16px; background: linear-gradient(165deg, rgba(26, 51, 80, 0.4), rgba(10, 26, 46, 0.66)); }
.sup-topo { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.sup-nome { font-family: var(--font-display); font-weight: 700; font-size: 1.04rem; color: var(--portal-text); }
.sup-dose { font-family: var(--font-mono); font-size: 0.8rem; letter-spacing: 0.04em; color: #9fe3c0; border: 1px solid rgba(127, 214, 168, 0.4); border-radius: var(--r-pill); padding: 4px 11px; white-space: nowrap; }
.sup-quando { font-family: var(--font-serif); font-style: italic; font-size: 0.86rem; color: var(--portal-text-dim); margin-top: 5px; }
.sup-marcas { margin-top: 11px; }
.sup-marcas-lb { display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); margin-bottom: 7px; }
.sup-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.sup-marca { font-family: var(--font-body); font-size: 0.82rem; color: color-mix(in srgb, var(--gold) 38%, #ffffff); background: color-mix(in srgb, var(--gold) 12%, transparent); border: 1px solid color-mix(in srgb, var(--gold) 40%, transparent); border-radius: var(--r-pill); padding: 4px 12px; }
.sup-livre { font-size: 0.84rem; color: var(--portal-text-dim); font-style: italic; margin-top: 8px; }

.df-sup-secao { margin: 14px 0 4px; padding-top: 12px; border-top: 1px solid var(--portal-line); }
.df-sup-titulo { display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--portal-text-faint); margin-bottom: 10px; }
.df-sup-titulo small { text-transform: none; letter-spacing: 0; color: var(--portal-text-dim); font-size: 0.92em; }
.df-sup { border: 1px solid var(--portal-line); border-radius: var(--r-sm); padding: 12px; margin-bottom: 10px; background: color-mix(in srgb, var(--portal-fill) 30%, transparent); }

/* refeição = MÓDULO de performance: elevação sutil + cabeçalho técnico */
.dieta-refeicoes { display: flex; flex-direction: column; gap: 16px; }
.ref-card {
  border: 1px solid color-mix(in srgb, var(--portal-fill) 7%, transparent); border-radius: 9px; overflow: hidden;
  background: var(--doc-paper-2); padding: 0; margin: 0; break-inside: avoid;
  box-shadow: 0 1px 1px color-mix(in srgb, var(--portal-fill) 4%, transparent), 0 16px 30px -20px color-mix(in srgb, var(--portal-fill) 28%, transparent);
}
/* cabeçalho do módulo: faixa champagne + numeral em selo navy */
.ref-card > header {
  display: flex; align-items: center; gap: 14px; margin: 0; padding: 15px 20px;
  background: linear-gradient(100deg, rgba(205, 172, 110, 0.16), rgba(205, 172, 110, 0.04));
  border-bottom: 1px solid color-mix(in srgb, var(--gold-ink) 22%, transparent);
}
.ref-num {
  flex: none; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 800; font-size: 1.4rem; line-height: 1; color: var(--seal-tx, #fff);
  background: linear-gradient(150deg, var(--navy-700), var(--navy-900)); border-radius: 9px;
  box-shadow: inset 0 1px 0 rgba(237, 255, 255, 0.14);
}
.ref-card > header > div { min-width: 0; flex: 1; }
.ref-card h5 { font-family: var(--font-display); font-weight: 700; font-size: 1.12rem; letter-spacing: -0.01em; line-height: 1.15; color: var(--navy-900); }
.ref-card header p {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--gold-ink); margin-top: 3px;
}

/* corpo do módulo: itens como ficha técnica, divisória fina entre eles */
.ref-card > .ref-itens { padding: 6px 20px; }
.ref-itens { list-style: none; display: flex; flex-direction: column; }
.ref-itens li { display: block; padding: 13px 0; border-bottom: 1px solid color-mix(in srgb, var(--portal-fill) 7%, transparent); font-size: 0.95rem; line-height: 1.55; max-width: 62ch; color: var(--doc-ink); }
.ref-itens li:last-child { border-bottom: 0; }

/* macro reativado: eyebrow de ficha técnica — a assinatura de plano profissional */
.dieta .ref-rotulo {
  display: block; font-family: var(--font-mono); font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-ink); margin-bottom: 4px;
}
.dieta .ref-texto { display: block; }

/* alternativas dentro do item — selo "ou" fatia a frase em escolhas escaneáveis */
.dieta .ou {
  font-style: normal; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold-ink); border: 1px solid color-mix(in srgb, var(--gold-ink) 40%, transparent); border-radius: 2px;
  padding: 1px 5px 2px; margin: 0 3px; white-space: nowrap; vertical-align: 0.14em;
}

/* opções de refeição — caixas lado a lado: a leitura escolhe o caminho */
.dieta .ref-opcoes { display: grid; grid-template-columns: 1fr; gap: 12px; margin: 0; padding: 14px 20px 6px; }
@media (min-width: 620px) { .dieta .ref-opcoes.par { grid-template-columns: 1fr 1fr; } }
.dieta .opcao {
  background: transparent; border: 1px solid color-mix(in srgb, var(--gold-ink) 30%, transparent); border-radius: 7px; overflow: hidden;
  padding: 0; break-inside: avoid;
}
.dieta .opcao > header {
  display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; margin: 0;
  padding: 9px 13px; background: rgba(205, 172, 110, 0.1); border-bottom: 1px solid color-mix(in srgb, var(--gold-ink) 22%, transparent);
}
.dieta .opcao-titulo {
  font-family: var(--font-mono); font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--navy-900);
}
.dieta .opcao-nota { font-family: var(--font-serif); font-style: italic; font-size: 0.78rem; color: var(--gold-ink); }
.dieta .opcao .ref-itens { padding: 4px 13px 8px; }
.dieta .opcao .ref-itens li { padding: 9px 0; }
/* caixas lado a lado dispensam o divisor textual "ou" */
.dieta .opcao-ou { display: none; }

/* obs — voz do Matheus: aparte navy, dentro do módulo (autoridade que pausa a leitura) */
.dieta .ref-obs {
  margin: 2px 20px 16px; padding: 12px 14px;
  border-left: 0; background: var(--navy-700); border-radius: 7px;
}
.dieta .ref-obs-label {
  display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: color-mix(in srgb, var(--gold) 46%, #ffffff); margin-bottom: 4px;
}
.dieta .ref-obs p { font-family: var(--font-serif); font-style: italic; font-size: 0.9rem; line-height: 1.5; color: #dfe2e0; }
.dieta .ref-obs p + p { margin-top: 5px; }

/* capítulos (Sábado/Domingo/Refeição livre) — divisor de seção com régua navy */
.dieta .dieta-secao { margin-top: 34px; }
.dieta .secao-cabeca { position: relative; display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; border-top: 0; padding: 0 0 12px; margin-bottom: 16px; border-bottom: 2px solid var(--navy-900); break-after: avoid; }
.dieta .secao-cabeca::before { display: none; }
.dieta .secao-cabeca h4 { font-family: var(--font-display); font-weight: 800; font-size: 1.36rem; letter-spacing: -0.02em; color: var(--navy-900); }
.dieta .secao-intro { margin: 0 0 0 auto; font-family: var(--font-serif); font-style: italic; font-size: 0.86rem; color: var(--gold-ink); }

/* refeições de seção: sem número de série — selo navy com traço champagne */
.dieta .ref-marca { flex: none; width: 44px; height: 44px; border-radius: 9px; align-self: auto; margin: 0; position: relative; background: linear-gradient(150deg, var(--navy-700), var(--navy-900)); box-shadow: inset 0 1px 0 rgba(237, 255, 255, 0.14); }
.dieta .ref-marca::after { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 15px; height: 2px; background: var(--gold-mid); }

/* formulário de dieta (admin) */
.mm-card.mm-largo { width: min(860px, 100%); }
.dieta-form label { display: flex; flex-direction: column; gap: 4px; font-size: 0.74rem; color: var(--portal-text-faint); }
.dieta-form input, .dieta-form select, .dieta-form textarea, .duvida-texto {
  padding: 10px 12px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong);
  background: color-mix(in srgb, var(--portal-fill) 55%, transparent); color: var(--portal-text); font-family: inherit; font-size: 0.88rem; outline: 0; width: 100%;
}
.dieta-form input:focus, .dieta-form select:focus, .dieta-form textarea:focus, .duvida-texto:focus { border-color: var(--steel); }
.df-linha { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.df-linha label { flex: 1 1 150px; }
.df-bloco { margin-bottom: 10px; }
.df-refeicao { border: 1px solid var(--portal-line); border-radius: var(--r-sm); padding: 12px; margin: 10px 0; }
.df-refeicao legend { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--portal-text-faint); padding: 0 6px; display: flex; gap: 8px; align-items: center; }
.df-item { display: flex; gap: 8px; margin-bottom: 8px; }
.df-item .df-rotulo { flex: 0 0 168px; }
.df-item .df-texto { flex: 1; }
.df-x { flex: none; width: 36px; min-height: 36px; border: 0; border-radius: var(--r-sm); background: rgba(240, 169, 169, 0.12); color: #f0a9a9; cursor: pointer; }
.df-x svg { width: 13px; height: 13px; }
.duvida-acoes { display: flex; align-items: center; gap: 12px; margin-top: 12px; flex-wrap: wrap; }
.duvida-msg { font-size: 0.84rem; color: var(--portal-text); margin-top: 4px; font-style: italic; }
.solic-row.duvida .ar-info { min-width: 0; }

/* etiqueta da parte da dieta na dúvida (pop-ups do admin e do paciente) — sempre em linha própria */
.duvida-ref {
  display: block; width: fit-content; margin-top: 3px;
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--gold-mid); border: 1px solid color-mix(in srgb, var(--gold) 45%, transparent); background: color-mix(in srgb, var(--gold) 10%, transparent);
  border-radius: 4px; padding: 3px 8px;
}

/* dúvida no pop-up do admin vira coluna: pergunta em cima, resposta embaixo */
.solic-row.duvida { display: block; }
.resp-area { margin-top: 9px; display: flex; flex-direction: column; gap: 4px; }
.resp-area .duvida-acoes { margin-top: 6px; }

/* pop-up "O Matheus respondeu" (paciente) */
.resp-card {
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-sm);
  background: color-mix(in srgb, var(--portal-fill) 45%, transparent); padding: 14px; margin-top: 10px;
}
.resp-pergunta { font-size: 0.8rem; color: var(--portal-text-dim); font-style: italic; margin: 7px 0 10px; }
.resp-bloco {
  border-left: 3px solid var(--steel); border-radius: 0 var(--r-sm) var(--r-sm) 0;
  background: color-mix(in srgb, var(--steel-bright) 9%, transparent); padding: 10px 12px;
}
.resp-bloco .resp-de {
  display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--steel-bright); margin-bottom: 4px;
}
.resp-bloco p { font-size: 0.9rem; line-height: 1.5; color: var(--portal-text); }

/* ===== Abas de dúvidas: histórico do aluno + central do Matheus ===== */
/* selo de status (verde = respondida · âmbar = em espera) — usado no card do admin */
.dv-status {
  display: inline-block; width: fit-content;
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase;
  border-radius: var(--r-pill); padding: 4px 11px;
}
.dv-status.ok { color: #9fe3c0; border: 1px solid rgba(127, 214, 168, 0.45); background: rgba(127, 214, 168, 0.1); }
.dv-status.wait { color: var(--gold-mid); border: 1px solid color-mix(in srgb, var(--gold) 55%, transparent); background: color-mix(in srgb, var(--gold) 13%, transparent); }

/* resumo no topo da central do Matheus */
.dv-resumo { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.dv-resumo:empty { display: none; }
.dv-chip {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.06em;
  border-radius: var(--r-pill); padding: 5px 12px; border: 1px solid var(--portal-line-strong); color: var(--portal-text-dim);
}
.dv-chip.wait { color: var(--gold-mid); border-color: color-mix(in srgb, var(--gold) 45%, transparent); }
.dv-chip.ok { color: #9fe3c0; border-color: rgba(127, 214, 168, 0.4); }

/* lista de dúvidas do admin */
.dv-lista { display: flex; flex-direction: column; gap: 14px; }
.dv-card {
  display: flex; flex-direction: column; gap: 9px;
  border: 1px solid var(--portal-line-strong); border-left-width: 3px; border-radius: var(--r-md);
  padding: 16px 18px; background: linear-gradient(165deg, rgba(26, 51, 80, 0.4), rgba(10, 26, 46, 0.66));
}
.dv-card.is-wait { border-left-color: var(--gold); }
.dv-card.is-ok { border-left-color: #7fd6a8; }
.dv-paciente { display: flex; flex-direction: column; gap: 1px; }
.dv-paciente strong { font-family: var(--font-display); font-weight: 700; font-size: 0.98rem; color: var(--portal-text); }
.dv-paciente span { font-size: 0.72rem; color: var(--portal-text-faint); }
.dv-pergunta { font-size: 0.92rem; line-height: 1.5; color: var(--portal-text); font-style: italic; }
.dv-resposta { display: flex; flex-direction: column; gap: 6px; margin-top: 2px; }
.dv-resp-label {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--portal-text-faint);
}

/* histórico do aluno (reusa .resp-card) */
.dv-historico { display: flex; flex-direction: column; gap: 14px; }
.dv-historico .resp-card { margin-top: 0; }
.resp-topo { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.resp-topo .duvida-ref { margin-top: 0; }
.resp-data { font-family: var(--font-mono); font-size: 0.7rem; color: var(--portal-text-dim); letter-spacing: 0.04em; }

/* ===== Fiquei com dúvida — bandeirinhas na dieta em miniatura ===== */
.dv-mini {
  background: var(--gold-bg); border-radius: 6px; padding: 12px 14px; margin-bottom: 12px;
  max-height: 320px; overflow: auto; box-shadow: inset 0 0 0 1px var(--gold-line);
}
.dv-grupo + .dv-grupo { margin-top: 12px; }
.dv-grupo-titulo {
  display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--gold-ink); padding: 3px 0 6px;
  border-bottom: 1px solid var(--gold-line); margin-bottom: 4px;
}
.dv-linha {
  display: flex; align-items: center; gap: 10px; padding: 6px; border-radius: 4px;
  cursor: pointer; transition: background 0.15s var(--ease);
}
.dv-linha:hover { background: var(--gold-bg); }
.dv-linha.marcada { background: var(--gold-bg); }
.dv-linha.opcao { margin-left: 28px; }
.dv-num {
  flex: none; width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--navy-900); color: color-mix(in srgb, var(--gold) 46%, #ffffff); font-family: var(--font-mono); font-size: 0.58rem;
}
.dv-num.traco { background: none; }
.dv-num.traco::before { content: ""; width: 12px; height: 2px; background: var(--navy-900); }
.dv-rotulos { min-width: 0; flex: 1; display: flex; flex-direction: column; gap: 1px; }
.dv-rotulos strong { font-family: var(--font-display); font-weight: 700; font-size: 0.84rem; color: var(--navy-900); }
.dv-rotulos span { font-size: 0.7rem; color: var(--gold-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* a bandeirinha: apagada (contorno) → vermelha (pano preenchido) com um pop curto */
.dv-flag {
  flex: none; width: 34px; height: 34px; border: 0; border-radius: 50%;
  background: none; color: var(--gold-mid); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: color 0.18s var(--ease), background 0.18s var(--ease);
}
.dv-flag svg { width: 18px; height: 18px; }
.dv-flag .pano { fill: transparent; transition: fill 0.18s var(--ease); }
.dv-flag:hover { background: rgba(184, 55, 46, 0.08); color: #b8372e; }
.dv-flag[aria-pressed="true"] { color: #b8372e; }
.dv-flag[aria-pressed="true"] .pano { fill: #b8372e; }
.dv-flag[aria-pressed="true"] svg { animation: dv-pop 0.22s var(--ease); }
@keyframes dv-pop { 40% { transform: scale(1.3) rotate(-5deg); } }

.dv-campos { display: flex; flex-direction: column; gap: 10px; }
.dv-campo label { display: flex; flex-direction: column; gap: 5px; }
.dv-campo-ref {
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gold-mid);
}
.dv-vazio { font-size: 0.8rem; color: var(--portal-text-dim); font-style: italic; }

/* ===== Ficha de treino — leitura (PROTOCOLO EDITORIAL, papel azul) ===== */
/* badge do treino no card navy = mesmo dourado da dieta (pedido do Manir) — herda o .obj-badge base champagne */
.tr-resumo { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.04em; color: var(--portal-text-faint); margin-top: 2px; }

/* papel: canto vivo, fita de aço no topo */
.ficha {
  --ink-line: color-mix(in srgb, var(--portal-fill) 14%, transparent);
  --ink-strong: color-mix(in srgb, var(--portal-fill) 55%, transparent);
  position: relative; overflow: hidden;
  background: #f6f5f0; color: var(--doc-ink);
  border-top: 3px solid var(--steel);
  border-radius: 0; box-shadow: none;
  padding: clamp(26px, 6vw, 56px) clamp(20px, 5vw, 52px) clamp(38px, 8vw, 64px);
}
.ficha > * { position: relative; z-index: 1; }

/* monograma MR fantasma em aço */
.ficha::before {
  content: var(--brand-sigla, "");
  position: absolute; z-index: 0;
  top: clamp(8px, 2vw, 18px); right: clamp(10px, 3vw, 26px);
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(88px, 18vw, 150px); line-height: 0.8; letter-spacing: -0.06em;
  color: color-mix(in srgb, var(--steel) 7%, transparent);
  pointer-events: none; user-select: none;
}

/* colofão */
.ficha::after {
  content: var(--brand-colofao, "");
  position: relative; z-index: 1; display: block;
  margin-top: 56px; padding-top: 12px; border-top: 1px solid var(--ink-line);
  font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.26em;
  color: color-mix(in srgb, var(--portal-fill) 45%, transparent);
}

/* masthead */
.ficha-cabeca { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; flex-wrap: wrap; border-bottom: 1px solid var(--ink-strong); padding-bottom: 18px; margin-bottom: 30px; }
.ficha-cabeca h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.65rem, 6vw, 2.35rem); letter-spacing: -0.03em; line-height: 1.04; color: var(--navy-900); }
.ficha-cabeca .dieta-vigencia { color: var(--doc-ink-soft); letter-spacing: 0.18em; }

/* objetivo no papel = mesmo dourado da dieta (pedido do Manir) */
.ficha .obj-badge.tr { background: transparent; border: 1px solid color-mix(in srgb, var(--gold-ink) 45%, transparent); border-radius: 2px; padding: 7px 12px; }
.ficha .obj-badge.tr strong { color: var(--gold-ink); }
.ficha .obj-badge.tr span { color: var(--gold-ink); }

/* notas — mesmo lingote bronze da dieta (pedido do Manir: igualar ao quadro do plano alimentar) */
.ficha-notas {
  background: linear-gradient(165deg, color-mix(in srgb, var(--gold) 58%, #150d02), color-mix(in srgb, var(--gold) 40%, #120b02)); color: color-mix(in srgb, var(--gold) 38%, #ffffff);
  border: 1px solid color-mix(in srgb, var(--gold) 32%, transparent); border-radius: 8px;
  padding: 18px 20px; margin-bottom: 26px;
  box-shadow: 0 16px 30px -20px rgba(0, 0, 0, 0.55), inset 0 1px 0 rgba(243, 232, 205, 0.1);
}
.ficha-notas h4 { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-mid); margin-bottom: 10px; }
.ficha-notas ul { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.ficha-notas li { position: relative; padding-left: 18px; font-size: 0.92rem; font-weight: 600; line-height: 1.6; max-width: 60ch; }
.ficha-notas li::before { content: ""; position: absolute; left: 0; top: 0.72em; width: 12px; height: 1px; background: var(--gold-mid); }

/* dia de treino = MÓDULO de performance: elevação + cabeçalho técnico aço */
.ficha-dias { display: flex; flex-direction: column; gap: 16px; }
.treino-dia {
  border: 1px solid color-mix(in srgb, var(--portal-fill) 7%, transparent); border-radius: 9px; overflow: hidden;
  background: #fbfcfe; padding: 0; break-inside: avoid;
  box-shadow: 0 1px 1px color-mix(in srgb, var(--portal-fill) 4%, transparent), 0 16px 30px -20px color-mix(in srgb, var(--portal-fill) 26%, transparent);
}
.treino-dia > header {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 0; padding: 15px 20px;
  background: linear-gradient(100deg, color-mix(in srgb, var(--steel-bright) 12%, transparent), color-mix(in srgb, var(--steel-bright) 3%, transparent));
  border-bottom: 1px solid color-mix(in srgb, var(--steel) 20%, transparent);
}
.td-tag { flex: none; font-family: var(--font-mono); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: #fff; background: linear-gradient(150deg, var(--navy-600), var(--navy-900)); padding: 7px 12px; border-radius: 7px; box-shadow: inset 0 1px 0 rgba(237, 255, 255, 0.14); }
.treino-dia h5 { font-family: var(--font-display); font-weight: 700; font-size: 1.12rem; color: var(--navy-900); }

/* exercícios — linhas de ficha técnica com divisória, dados em chips de aço */
.ex-lista { list-style: none; display: flex; flex-direction: column; padding: 4px 20px 8px; }
.ex-linha { display: flex; gap: 14px; align-items: baseline; padding: 14px 0; border-bottom: 1px solid color-mix(in srgb, var(--portal-fill) 7%, transparent); }
.ex-linha:last-child { border-bottom: 0; }
.ex-num { flex: none; min-width: 26px; font-family: var(--font-mono); font-weight: 700; font-size: 0.8rem; color: var(--steel); font-variant-numeric: tabular-nums; }
.ex-corpo { min-width: 0; flex: 1; }
.ex-nome { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1rem; color: var(--doc-ink); }
.ex-dados { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 7px; }
.ex-dado { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.02em; color: var(--steel); background: transparent; border: 1px solid color-mix(in srgb, var(--steel) 35%, transparent); border-radius: 5px; padding: 3px 9px; }
.ex-dado.forte { background: linear-gradient(150deg, var(--steel), var(--steel-ink)); color: #fff; border-color: transparent; box-shadow: inset 0 1px 0 rgba(237, 255, 255, 0.14); }
.ex-dado.pausa { color: var(--doc-ink-soft); background: transparent; border-color: color-mix(in srgb, var(--doc-ink-soft) 25%, transparent); }
.ex-obs { font-size: 0.84rem; line-height: 1.45; color: var(--doc-ink-soft); margin-top: 7px; font-style: italic; }
/* atalho "ver execução" — única ação viva do papel, segue pílula */
.ex-exec {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 8px; cursor: pointer;
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--steel); background: transparent; border: 1px solid color-mix(in srgb, var(--steel) 40%, transparent);
  border-radius: var(--r-pill); padding: 5px 11px; transition: background 0.16s var(--ease), border-color 0.16s var(--ease);
}
.ex-exec:hover { background: color-mix(in srgb, var(--steel-bright) 10%, transparent); border-color: var(--steel-bright); }
.ex-exec svg { width: 13px; height: 13px; }

/* form do treino (admin) — reusa .df-linha/.df-bloco/.df-refeicao/.df-x da dieta */
.treino-form label { display: flex; flex-direction: column; gap: 4px; font-size: 0.74rem; color: var(--portal-text-faint); }
.treino-form input, .treino-form select, .treino-form textarea {
  padding: 10px 12px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong);
  background: color-mix(in srgb, var(--portal-fill) 55%, transparent); color: var(--portal-text); font-family: inherit; font-size: 0.88rem; outline: 0; width: 100%;
}
.treino-form input:focus, .treino-form select:focus, .treino-form textarea:focus { border-color: var(--steel); }
.ex-form { border: 1px solid var(--portal-line); border-radius: var(--r-sm); padding: 10px; margin-bottom: 8px; background: color-mix(in srgb, var(--portal-fill) 30%, transparent); }
.ex-form-l1 { display: flex; gap: 8px; margin-bottom: 8px; }
.ex-form-l1 .ex-nome-in { flex: 1; }
.ex-form-l2 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-bottom: 8px; }
@media (max-width: 540px) { .ex-form-l2 { grid-template-columns: repeat(2, 1fr); } }

/* ===== Identifique o exercício (aluno) ===== */
.ix-grupo { margin-top: 18px; }
.ix-grupo-titulo { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); margin-bottom: 8px; padding-bottom: 6px; border-bottom: 1px solid var(--portal-line); }
.ix-lista { display: flex; flex-direction: column; gap: 8px; }
.ix-item {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left; cursor: pointer;
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 13px 16px;
  background: linear-gradient(165deg, rgba(26, 51, 80, 0.4), rgba(10, 26, 46, 0.62)); color: var(--portal-text);
  transition: border-color 0.18s var(--ease), transform 0.18s var(--ease);
}
.ix-item:hover { border-color: var(--portal-text-faint); transform: translateX(2px); }
.ix-corpo { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.ix-nome { font-family: var(--font-display); font-weight: 700; font-size: 0.96rem; color: var(--portal-text); }
.ix-aparelho { font-size: 0.8rem; color: var(--portal-text-faint); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ix-seta { flex: none; color: var(--steel); display: flex; }
.ix-seta svg { width: 16px; height: 16px; }

/* detalhe do exercício (modal) */
.ix-grupo-tag { display: inline-block; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--steel-light); border: 1px solid color-mix(in srgb, var(--steel-bright) 40%, transparent); background: color-mix(in srgb, var(--steel-bright) 10%, transparent); border-radius: 4px; padding: 3px 9px; margin-bottom: 12px; }
.ix-maquina, .ix-instrucoes { margin-bottom: 14px; }
.ix-maquina-label { display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--portal-text-faint); margin-bottom: 5px; }
.ix-maquina p { font-family: var(--font-display); font-weight: 600; font-size: 1.04rem; color: var(--portal-text); }
.ix-instrucoes p { font-size: 0.9rem; line-height: 1.5; color: var(--portal-text-dim); }
.ix-video { position: relative; aspect-ratio: 16 / 9; border-radius: var(--r-sm); overflow: hidden; background: #000; border: 1px solid var(--portal-line-strong); margin-top: 6px; }
.ix-video iframe, .ix-video video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.ix-sem-video { font-size: 0.86rem; color: var(--portal-text-dim); font-style: italic; padding: 10px 0; }

/* catálogo de exercícios — form (admin) */
.ex-cad { border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 16px; margin-bottom: 14px; background: color-mix(in srgb, var(--portal-fill) 40%, transparent); }
.ex-cad label { display: flex; flex-direction: column; gap: 4px; font-size: 0.74rem; color: var(--portal-text-faint); }
.ex-cad input[type="text"], .ex-cad select, .ex-cad textarea {
  padding: 10px 12px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong);
  background: color-mix(in srgb, var(--portal-fill) 55%, transparent); color: var(--portal-text); font-family: inherit; font-size: 0.88rem; outline: 0; width: 100%;
}
.ex-cad input:focus, .ex-cad select:focus, .ex-cad textarea:focus { border-color: var(--steel); }
.ex-video-cad { border: 1px dashed var(--portal-line-strong); border-radius: var(--r-sm); padding: 12px; margin: 10px 0; }
.ex-video-ou { display: flex; align-items: center; gap: 10px; margin: 8px 0; }
.ex-video-ou::before, .ex-video-ou::after { content: ""; flex: 1; height: 1px; background: var(--portal-line); }
.ex-video-ou span { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); }
.ex-upload { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ex-arquivo-nome { font-size: 0.78rem; color: var(--portal-text-faint); }

/* ===== Substituição de alimentos ===== */
.sub-card {
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 22px 20px;
  background: linear-gradient(165deg, rgba(26, 51, 80, 0.55), rgba(10, 26, 46, 0.72));
}
.sub-form { display: flex; gap: 14px; flex-wrap: wrap; }
.sub-campo { flex: 1 1 200px; display: flex; flex-direction: column; gap: 5px; font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--portal-text-faint); }
.sub-campo.qtd { flex: 0 1 170px; }
.sub-campo select, .sub-qtd input {
  padding: 12px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong);
  background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font-family: var(--font-body, inherit); font-size: 0.92rem; outline: 0; width: 100%;
}
.sub-qtd { position: relative; display: block; }
.sub-qtd i { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-style: normal; color: var(--portal-text-dim); }
.sub-resultado { margin-top: 18px; }
.sub-ok { border: 1px solid rgba(127, 214, 168, 0.4); border-radius: var(--r-sm); background: rgba(127, 214, 168, 0.07); padding: 18px; }
.sub-conta { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 6px; }
.sub-num { font-family: var(--font-display); font-weight: 800; font-size: 2rem; color: #9fe3c0; }
.sub-de { font-size: 1rem; color: var(--portal-text); }
.sub-ok p { font-size: 0.86rem; color: var(--portal-text-dim); }
.sub-aviso { border: 1px solid color-mix(in srgb, var(--gold) 50%, transparent); border-radius: var(--r-sm); background: color-mix(in srgb, var(--gold) 8%, transparent); padding: 16px 18px; }
.sub-aviso strong { color: var(--gold-mid); display: block; margin-bottom: 5px; }
.sub-aviso p { font-size: 0.85rem; line-height: 1.5; color: var(--portal-text-dim); }
.sub-aviso.neutro { border-color: var(--portal-line-strong); background: rgba(237, 255, 255, 0.04); color: var(--portal-text-dim); font-size: 0.86rem; }
.sub-nota { margin-top: 12px; font-size: 0.76rem; color: var(--portal-text-dim); opacity: 0.85; }

/* ===== Análises corporais — cards de evolução + gráficos SVG + tabela comparativa MR ===== */
.ev-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(148px, 1fr)); gap: 12px; margin-bottom: 8px; }
.ev-card { border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 14px 16px; background: linear-gradient(165deg, rgba(26, 51, 80, 0.45), rgba(10, 26, 46, 0.7)); display: flex; flex-direction: column; gap: 5px; }
.ev-card-lb { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--portal-text-faint); }
.ev-card-num { font-family: var(--font-display); font-weight: 800; font-size: 1.7rem; color: var(--portal-text); line-height: 1; }
.ev-card-num i { font-style: normal; font-size: 0.86rem; font-weight: 600; color: var(--portal-text-dim); margin-left: 3px; }
.ev-card-delta { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.02em; }
.ev-card-delta.pos { color: #7fd6a8; }
.ev-card-delta.neg { color: #e08aa0; }
.ev-card-delta.neutro { color: var(--portal-text-dim); }

.an-titulo { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); margin: 28px 0 13px; }

.ev-grade { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 14px; }
.ev-graf { border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 14px 16px 10px; background: linear-gradient(165deg, rgba(20, 40, 62, 0.5), color-mix(in srgb, var(--portal-fill) 66%, transparent)); }
.ev-graf figcaption { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.ev-tit { font-family: var(--font-display); font-weight: 700; font-size: 0.98rem; color: var(--portal-text); }
.ev-tit i { font-style: normal; font-family: var(--font-mono); font-size: 0.6rem; color: var(--portal-text-dim); margin-left: 5px; letter-spacing: 0.04em; }
.ev-delta { font-family: var(--font-mono); font-size: 0.72rem; font-weight: 600; white-space: nowrap; }
.ev-graf svg { width: 100%; height: auto; display: block; overflow: visible; }
.ev-val { fill: var(--portal-text); font-family: var(--font-mono); font-size: 11px; font-weight: 600; }
.ev-eixo { fill: var(--portal-text-dim); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; }
.ev-graf.vazio { display: flex; flex-direction: column; gap: 6px; }
.ev-sem { color: var(--portal-text-dim); font-size: 0.84rem; font-style: italic; }

.an-tabela-wrap { overflow-x: auto; border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); -webkit-overflow-scrolling: touch; }
.an-tabela { width: 100%; border-collapse: collapse; font-size: 0.84rem; min-width: 380px; }
.an-tabela th, .an-tabela td { padding: 9px 13px; text-align: right; white-space: nowrap; border-bottom: 1px solid var(--portal-line); }
.an-tabela thead td { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.04em; color: var(--steel-bright); }
.an-tabela thead th { text-align: left; color: var(--portal-text-faint); font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; }
.an-tabela tbody th { text-align: left; font-weight: 600; color: var(--portal-text); font-family: var(--font-body); }
.an-tabela tbody th i { font-style: normal; color: var(--portal-text-dim); font-weight: 400; font-size: 0.9em; }
.an-tabela td { color: var(--portal-text); font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.an-tabela tr.sec th, .an-tabela tr.sec td { color: var(--portal-text-dim); }
.an-tabela tbody tr:last-child th, .an-tabela tbody tr:last-child td { border-bottom: 0; }

.an-admin-lista { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
/* blocos recolhíveis da aba análises (Evolução / Comparativo / Fotos) + avaliações no admin */
.an-bloco { margin-bottom: 6px; }
.an-bloco-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.an-bloco-head .an-titulo { margin: 0; }
.an-min { width: 30px; height: 30px; flex: none; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); color: var(--portal-text-faint); cursor: pointer; transition: color .16s var(--ease), border-color .16s var(--ease); }
.an-min:hover { color: var(--portal-text); border-color: var(--portal-text-faint); }
.an-min svg { width: 14px; height: 14px; }
/* form de avaliação manual (admin) — campos do AVANUTRI + resultados ao vivo */
.av-form { display: flex; flex-direction: column; gap: 16px; }
.av-sec { display: flex; flex-direction: column; gap: 10px; }
.av-sec-tit { margin: 0; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--portal-text-faint); }
.av-grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; }
.av-campo { display: flex; flex-direction: column; gap: 5px; font-size: 0.82rem; color: var(--portal-text-dim); min-width: 0; }
.av-campo input, .av-campo select { width: 100%; padding: 9px 10px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font-size: 0.92rem; outline: 0; }
.av-campo input:focus, .av-campo select:focus { border-color: var(--steel); }
.av-nota { margin: 2px 0 0; font-size: 0.76rem; color: var(--portal-text-faint); font-style: italic; }
/* campos que o protocolo de % de gordura escolhido consome — realçados pra guiar a coleta */
.av-campo.req > span { color: var(--gold); }
.av-campo.req > span::after { content: " •"; color: var(--gold); }
.av-campo.req input, .av-campo.req select { border-color: color-mix(in srgb, var(--gold) 55%, transparent); }
.av-result { background: color-mix(in srgb, var(--steel) 7%, transparent); border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 14px; }
.av-res-grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(118px, 1fr)); gap: 12px; }
.av-res { display: flex; flex-direction: column; gap: 3px; }
.av-res-lb { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--portal-text-faint); }
.av-res-num { font-family: var(--font-display); font-weight: 800; font-size: 1.3rem; line-height: 1; color: var(--steel-bright); }
.av-res-num i { font-style: normal; font-size: 0.7rem; font-weight: 600; color: var(--portal-text-faint); margin-left: 2px; }

/* fotos de progresso — comparador antes/depois (aluno) + slots de upload (admin) */
.fp-angs { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.fp-ang { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer; border: 1px solid var(--portal-line-strong); background: transparent; color: var(--portal-text-dim); border-radius: var(--r-pill); padding: 7px 15px; transition: border-color 0.16s var(--ease), color 0.16s var(--ease); }
.fp-ang:hover { border-color: var(--portal-text-faint); color: var(--portal-text); }
.fp-ang.on { background: var(--steel); border-color: var(--steel); color: #fff; }
.fp-comparador { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fp-lado { margin: 0; display: flex; flex-direction: column; gap: 8px; }
.fp-sel { width: 100%; padding: 8px 10px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font-family: var(--font-mono); font-size: 0.74rem; outline: 0; }
.fp-sel:focus { border-color: var(--steel); }
.fp-quadro { position: relative; aspect-ratio: 3 / 4; border-radius: var(--r-md); overflow: hidden; background: linear-gradient(165deg, var(--navy-700), var(--navy-900)); border: 1px solid var(--portal-line-strong); display: flex; align-items: center; justify-content: center; }
.fp-quadro img { width: 100%; height: 100%; object-fit: cover; display: block; }
.fp-sem { font-size: 0.78rem; color: var(--portal-text-dim); font-style: italic; text-align: center; padding: 0 10px; }
.fp-tag { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); text-align: center; }

.an-aval-item { display: flex; flex-direction: column; border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); background: color-mix(in srgb, var(--portal-fill) 42%, transparent); padding: 11px 14px; transition: border-color .16s var(--ease); }
.an-aval-item:hover { border-color: var(--portal-text-faint); }
.an-aval-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.an-aval-corpo { display: flex; flex-direction: column; gap: 8px; padding-top: 10px; margin-top: 11px; border-top: 1px solid var(--portal-line); }
/* relatório de UMA avaliação (PDF por consulta) — pares label/valor em papel claro */
.anr-grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 6px 16px; margin: 6px 0 18px; }
.anr-par { display: flex; flex-direction: column; gap: 2px; padding: 7px 0; border-bottom: 1px solid color-mix(in srgb, var(--portal-fill) 10%, transparent); }
.anr-par span { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--doc-ink-soft); }
.anr-par strong { font-size: 1rem; color: var(--navy-900); font-weight: 700; }
.ar-acoes { display: flex; gap: 8px; align-items: center; }
.fp-upload { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; padding: 10px 0 4px; }
.fp-slot { position: relative; aspect-ratio: 3 / 4; border-radius: var(--r-sm); overflow: hidden; border: 1px dashed var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 40%, transparent); transition: border-color 0.16s var(--ease); }
.fp-slot.tem { border-style: solid; border-color: rgba(127, 214, 168, 0.45); }
.fp-slot-vazio { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 11px; padding: 8px; }
.fp-slot-nome { font-family: var(--font-display); font-weight: 700; font-size: 0.86rem; color: var(--portal-text); }
.fp-slot-escolha { display: flex; flex-direction: column; gap: 6px; width: 100%; }
.fp-slot-mini { display: inline-flex; align-items: center; justify-content: center; gap: 6px; cursor: pointer; border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--steel) 8%, transparent); color: var(--portal-text-dim); border-radius: var(--r-sm); padding: 7px 6px; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.06em; text-transform: uppercase; transition: border-color 0.16s var(--ease), color 0.16s var(--ease), background 0.16s var(--ease); }
.fp-slot-mini:hover { border-color: var(--portal-text-faint); color: var(--portal-text); background: color-mix(in srgb, var(--steel) 16%, transparent); }
.fp-slot-mini svg { width: 15px; height: 15px; color: var(--steel-bright); }
.fp-slot-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.fp-slot-cap { position: absolute; top: 6px; left: 6px; font-family: var(--font-mono); font-size: 0.54rem; letter-spacing: 0.14em; text-transform: uppercase; color: #fff; background: color-mix(in srgb, var(--portal-fill) 72%, transparent); padding: 3px 8px; border-radius: var(--r-pill); }
.fp-slot-acoes { position: absolute; left: 0; right: 0; bottom: 0; display: flex; gap: 1px; }
.fp-slot-btn { flex: 1; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; border: 0; padding: 9px 4px; color: #fff; background: color-mix(in srgb, var(--portal-fill) 82%, transparent); transition: background 0.16s var(--ease); }
.fp-slot-btn svg { width: 15px; height: 15px; }
.fp-slot-btn:hover { background: color-mix(in srgb, var(--steel) 92%, transparent); }
.fp-slot-btn.rem:hover { background: rgba(217, 99, 127, 0.88); }
@media (max-width: 460px) { .fp-comparador { grid-template-columns: 1fr; } }

/* botão "Baixar PDF" no topo da aba de análises */
.an-topo { display: flex; justify-content: flex-end; margin-bottom: 14px; }

/* relatório imprimível das análises (download) — papel branco premium, reusa .dieta-view */
.an-relatorio-view { z-index: 400; }
.an-relatorio { background: #fff; color: var(--doc-ink); border-top: 3px solid var(--steel); padding: clamp(26px, 6vw, 52px) clamp(20px, 5vw, 50px) clamp(34px, 7vw, 56px); }
.an-relatorio .an-topo { display: none; }
.anr-cabeca { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; border-bottom: 1px solid color-mix(in srgb, var(--portal-fill) 50%, transparent); padding-bottom: 16px; margin-bottom: 24px; }
.anr-cabeca h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.5rem, 5vw, 2.1rem); letter-spacing: -0.03em; line-height: 1.05; color: var(--navy-900); }
.anr-cabeca .dieta-vigencia { color: var(--doc-ink-soft); margin-top: 7px; letter-spacing: 0.06em; }
.anr-selo { font-family: var(--font-display); font-weight: 800; font-size: 1.7rem; letter-spacing: -0.04em; color: var(--steel); }
/* marca d'água da logo MR — bem clara, atrás do conteúdo, não atrapalha leitura nem impressão */
.an-relatorio { position: relative; }
.anr-marca { position: absolute; top: clamp(140px, 17%, 215px); left: 0; right: 0; display: flex; justify-content: center; pointer-events: none; z-index: 0; }
.anr-marca img { width: 82%; max-width: 540px; opacity: 0.06; }
.an-relatorio > *:not(.anr-marca) { position: relative; z-index: 1; }
.an-relatorio .ev-card { background: var(--doc-card); border-color: color-mix(in srgb, var(--portal-fill) 10%, transparent); }
.an-relatorio .ev-card-lb { color: var(--doc-ink-soft); }
.an-relatorio .ev-card-num { color: var(--navy-900); }
.an-relatorio .ev-card-num i { color: var(--doc-ink-soft); }
.an-relatorio .ev-card-delta.neutro { color: var(--doc-ink-soft); }
.an-relatorio .an-titulo { color: var(--doc-ink-soft); }
.an-relatorio .ev-graf { background: var(--doc-card); border-color: color-mix(in srgb, var(--portal-fill) 10%, transparent); }
.an-relatorio .ev-tit { color: var(--navy-900); }
.an-relatorio .ev-tit i { color: var(--doc-ink-soft); }
.an-relatorio .ev-val { fill: var(--doc-ink); }
.an-relatorio .ev-eixo { fill: var(--doc-ink-soft); }
.an-relatorio .an-tabela-wrap { border-color: color-mix(in srgb, var(--portal-fill) 15%, transparent); }
.an-relatorio .an-tabela th, .an-relatorio .an-tabela td { border-color: color-mix(in srgb, var(--portal-fill) 10%, transparent); }
.an-relatorio .an-tabela thead th { color: var(--doc-ink-soft); }
.an-relatorio .an-tabela thead td { color: var(--steel); }
.an-relatorio .an-tabela tbody th { color: var(--navy-900); }
.an-relatorio .an-tabela tbody th i { color: var(--doc-ink-soft); }
.an-relatorio .an-tabela td { color: var(--doc-ink); }
.an-relatorio .an-tabela tr.sec th, .an-relatorio .an-tabela tr.sec td { color: var(--doc-ink-soft); }

/* ===== LGPD — aba de consulta + gate de consentimento (1º acesso) ===== */
.lgpd-aceite-tag { display: flex; align-items: center; gap: 9px; margin-bottom: 16px; padding: 11px 15px; border: 1px solid rgba(127, 214, 168, 0.4); background: rgba(127, 214, 168, 0.08); border-radius: var(--r-md); font-size: 0.86rem; color: #9fe3c0; }
.lgpd-pagina { border: 1px solid var(--portal-line-strong); border-radius: var(--r-lg); padding: clamp(20px, 4vw, 34px); background: linear-gradient(165deg, rgba(20, 40, 62, 0.5), color-mix(in srgb, var(--portal-fill) 66%, transparent)); }
.lg-intro { font-size: 0.98rem; line-height: 1.7; color: var(--portal-text); }
.lg-sec { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--portal-line); }
.lg-sec h4 { font-family: var(--font-display); font-weight: 700; font-size: 1.08rem; color: var(--portal-text); margin-bottom: 9px; }
.lg-sec p { font-size: 0.92rem; line-height: 1.65; color: var(--portal-text-dim); }
.lg-sec ul { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-top: 6px; }
.lg-sec li { position: relative; padding-left: 18px; font-size: 0.92rem; line-height: 1.6; color: var(--portal-text-dim); }
.lg-sec li::before { content: ""; position: absolute; left: 0; top: 0.7em; width: 11px; height: 1px; background: var(--steel-bright); }
.lg-intro strong, .lg-sec strong, .lg-rodape strong { color: var(--portal-text); font-weight: 600; }
.lg-nota { margin-top: 10px; font-size: 0.86rem; font-style: italic; color: var(--portal-text-faint); }
.lg-rodape { margin-top: 24px; padding-top: 18px; border-top: 1px solid var(--portal-line-strong); font-size: 0.92rem; line-height: 1.65; color: var(--portal-text); }

.lgpd-gate .auth-card.lgpd-card { width: min(620px, 100%); max-width: 620px; }
.lgpd-doc { max-height: 44vh; overflow-y: auto; margin: 14px 0 4px; padding: 16px 18px; border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); background: color-mix(in srgb, var(--portal-fill) 40%, transparent); }
.lgpd-doc .lg-intro { font-size: 0.9rem; }
.lgpd-doc .lg-sec { margin-top: 18px; padding-top: 15px; }
.lgpd-doc .lg-sec h4 { font-size: 1rem; }
.lgpd-doc::-webkit-scrollbar { width: 8px; }
.lgpd-doc::-webkit-scrollbar-thumb { background: var(--portal-line-strong); border-radius: 4px; }
.lgpd-check { display: flex; align-items: flex-start; gap: 10px; margin: 14px 0; cursor: pointer; font-size: 0.9rem; line-height: 1.5; color: var(--portal-text); }
.lgpd-check input { margin-top: 3px; width: 18px; height: 18px; flex: none; accent-color: var(--steel); cursor: pointer; }
.lgpd-sair { display: block; width: 100%; margin-top: 10px; background: none; border: 0; color: var(--portal-text-dim); font-size: 0.84rem; cursor: pointer; padding: 8px; transition: color 0.16s var(--ease); }
.lgpd-sair:hover { color: var(--portal-text); }
.pa-lgpd { display: inline-block; width: fit-content; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.04em; margin-top: 3px; }
.pa-lgpd.ok { color: #9fe3c0; }
.pa-lgpd.pend { color: var(--gold-mid); }

/* download da dieta/ficha = imprimir o protocolo */
@media print {
  body * { visibility: hidden; }
  .dieta-view, .dieta-view * { visibility: visible; }
  .dieta-view { position: static; background: #fff; }
  .dieta-view .lt-bar { display: none; }
  .dieta-scroll { overflow: visible; padding: 0; }
  .an-relatorio, .an-relatorio * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  /* marca d'água: sai na impressão tão leve quanto na tela (mesma opacidade), atrás do conteúdo */
  .anr-marca img { opacity: 0.06 !important; }

  /* papel vira branco; a fita do acento imprime — é a marca do protocolo */
  .dieta, .ficha {
    background: #fff; box-shadow: none; border-radius: 0;
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  .dieta { border-top: 3px solid var(--gold); }
  .ficha { border-top: 3px solid var(--steel); }
  .dieta::before, .ficha::before { display: none; }

  /* módulos: sem sombra, borda mantida, a faixa do cabeçalho imprime */
  .ref-card, .treino-dia {
    box-shadow: none; background: #fff; border: 1px solid color-mix(in srgb, var(--portal-fill) 25%, transparent);
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  .ref-card > header, .treino-dia > header, .dieta .opcao > header {
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  /* selos viram branco + borda + tinta escura (não dependem de imprimir fundo navy) */
  .ref-num, .ref-marca, .td-tag { background: #fff; color: var(--navy-900); border: 1.5px solid var(--navy-900); box-shadow: none; }
  .ref-marca::after { background: var(--gold-ink); }
  .ex-dado.forte { background: #fff; color: var(--steel); border: 1px solid var(--steel); box-shadow: none; }

  /* blocos navy invertem: tinta sobre branco com borda forte */
  .dieta-orientacoes, .ficha-notas, .dieta .ref-obs { background: #fff; border: 1.5px solid var(--navy-900); color: var(--doc-ink); }
  .dieta-orientacoes h4, .ficha-notas h4 { color: var(--gold-ink); }
  .dieta .ref-obs-label { color: var(--gold-ink); }
  .dieta .ref-obs p { color: var(--doc-ink); }
  .dieta-orientacoes li::before, .ficha-notas li::before { background: var(--gold-ink); }

  .ref-card, .dieta .opcao, .dieta .ref-obs, .ficha .treino-dia, .ex-linha { break-inside: avoid; }
  .ex-exec { display: none; }
}

/* modal padrão MR */
.modal-mr {
  position: fixed; inset: 0; z-index: 300; display: flex; align-items: center; justify-content: center;
  padding: 18px; background: rgba(4, 10, 19, 0.72); backdrop-filter: blur(6px);
}
.modal-mr .mm-card {
  width: min(560px, 100%); max-height: 86vh; overflow: auto;
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-md);
  background: linear-gradient(165deg, var(--navy-700), var(--navy-900) 70%);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6), inset 0 1px 0 rgba(237, 255, 255, 0.12);
  padding: 20px 22px;
}
.modal-mr header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.modal-mr h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.08rem; color: var(--portal-text); }
.mm-explica { font-size: 0.86rem; line-height: 1.5; color: var(--portal-text-dim); margin-bottom: 10px; }
.solic-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 0; border-top: 1px solid var(--portal-line); }

/* botão "tentar de novo" no estado de erro */
.btn-retry {
  margin-top: 22px; padding: 11px 24px; border-radius: var(--r-pill);
  border: 1px solid var(--portal-line-strong); color: var(--portal-text); font-size: 0.88rem; font-weight: 600;
  transition: border-color 0.2s, background 0.2s;
}
.btn-retry:hover { border-color: var(--steel); background: color-mix(in srgb, var(--steel) 12%, transparent); }

/* ===== Financeiro + Pagamento Pix ===== */
/* resumo: blocos "em aberto" / "pago" — empilham no mobile */
.fin-resumo { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-bottom: 20px; }
.fin-bloco {
  position: relative; padding: 18px 20px; border-radius: var(--r-md);
  border: 1px solid var(--portal-line); background: var(--portal-card-bg); box-shadow: var(--shadow-soft); overflow: hidden;
}
.fin-bloco.alerta { border-color: color-mix(in srgb, var(--gold) 40%, transparent); }
.fin-bloco.alerta::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--gold); }
.fin-rotulo { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); }
.fin-num { display: block; font-family: var(--font-display); font-weight: 800; font-size: 1.9rem; color: var(--portal-text); margin: 6px 0 4px; letter-spacing: -0.01em; }
.fin-num.calmo { color: var(--green); }
.fin-sub { font-size: 0.8rem; color: var(--portal-text-dim); }
.fin-sub.ok { color: var(--green); }
.fin-cta { margin: 0 0 18px; }

/* lista / linha de extrato */
.fin-lista { display: flex; flex-direction: column; }
.fin-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px 2px; border-bottom: 1px solid var(--portal-line); }
.fin-row:first-child { border-top: 1px solid var(--portal-line); }
.fin-row:last-child { border-bottom: 0; }
.fin-row-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.fin-row-info strong { font-family: var(--font-display); font-weight: 600; font-size: 0.96rem; color: var(--portal-text); }
.fin-meta { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--portal-text-faint); }
/* nome do paciente acima da cobrança (só na visão do admin) — cor pelo status */
.fin-nome { display: block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700; margin-bottom: 3px; }
.fin-nome.pago { color: #9fe3c0; }
.fin-nome.aberta, .fin-nome.analise { color: var(--gold); }
.fin-nome.atrasada { color: #f0a9a9; }
.fin-nome.cancelada { color: var(--portal-text-dim); }
.fin-row-dir { display: flex; align-items: center; gap: 12px; flex: none; }
.fin-valor { font-family: var(--font-mono); font-size: 0.92rem; font-weight: 600; color: var(--portal-text); }
.fin-selo {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 4px 9px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); color: var(--portal-text-dim); white-space: nowrap;
}
.fin-selo.pago { color: #9fe3c0; border-color: rgba(127, 214, 168, 0.45); background: rgba(127, 214, 168, 0.08); }
.fin-selo.atrasada { color: #f0a9a9; border-color: rgba(240, 169, 169, 0.45); background: rgba(217, 99, 127, 0.08); }
.fin-selo.analise { color: var(--gold-mid); border-color: color-mix(in srgb, var(--gold) 45%, transparent); background: color-mix(in srgb, var(--gold) 8%, transparent); }
.fin-selo.aberta { color: var(--portal-text-faint); }
.fin-selo.cancelada { color: var(--portal-text-dim); opacity: 0.7; }

/* painel financeiro do admin: filtros (busca + chips de status + modo) + grupos por mês */
.fin-controles { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-bottom: 20px; }
.fin-busca { position: relative; flex: 1 1 220px; min-width: 180px; display: flex; align-items: center; }
.fin-busca .lupa { position: absolute; left: 12px; display: inline-flex; color: var(--portal-text-faint); pointer-events: none; }
.fin-busca .lupa svg { width: 16px; height: 16px; }
.fin-busca input { width: 100%; padding: 10px 14px 10px 36px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 55%, transparent); color: var(--portal-text); font-family: inherit; font-size: 0.86rem; outline: 0; }
.fin-busca input:focus { border-color: var(--steel); }
.fin-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.fin-chip {
  display: inline-flex; align-items: center; gap: 7px; padding: 7px 13px; border-radius: var(--r-pill);
  border: 1px solid var(--portal-line-strong); background: rgba(237, 255, 255, 0.04); color: var(--portal-text-dim);
  font-family: inherit; font-size: 0.78rem; font-weight: 600; cursor: pointer;
  transition: color 0.18s var(--ease), border-color 0.18s var(--ease), background 0.18s var(--ease);
}
.fin-chip:hover { color: var(--portal-text); border-color: var(--portal-text-faint); }
.fin-chip.ativa { color: var(--portal-text); border-color: var(--steel); background: color-mix(in srgb, var(--steel-bright) 16%, transparent); }
.fin-chip-n { font-family: var(--font-mono); font-size: 0.64rem; padding: 1px 6px; border-radius: var(--r-pill); background: rgba(237, 255, 255, 0.08); color: var(--portal-text-faint); }
.fin-chip.ativa .fin-chip-n { background: color-mix(in srgb, var(--steel-bright) 30%, transparent); color: var(--portal-text); }
.fin-modos { display: inline-flex; gap: 4px; padding: 3px; border-radius: var(--r-pill); border: 1px solid var(--portal-line); background: color-mix(in srgb, var(--portal-fill) 40%, transparent); }
.fin-modo { padding: 6px 13px; border-radius: var(--r-pill); border: 0; background: none; color: var(--portal-text-dim); font-family: inherit; font-size: 0.76rem; font-weight: 600; cursor: pointer; transition: color 0.18s, background 0.18s; }
.fin-modo:hover { color: var(--portal-text); }
.fin-modo.ativa { color: #fff; background: linear-gradient(150deg, var(--steel-bright), var(--steel)); }
.fin-mesfiltro { display: inline-flex; align-items: center; gap: 8px; }
.fin-mesfiltro > span { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--portal-text-faint); }
.fin-mesfiltro select { padding: 8px 30px 8px 13px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 55%, transparent); color: var(--portal-text); font-family: inherit; font-size: 0.8rem; font-weight: 600; outline: 0; cursor: pointer; appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--portal-text-faint) 50%), linear-gradient(135deg, var(--portal-text-faint) 50%, transparent 50%); background-position: calc(100% - 16px) center, calc(100% - 11px) center; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; }
.fin-mesfiltro select:focus { border-color: var(--steel); }
.fin-mesfiltro select option { background: var(--navy-700); color: var(--portal-text); }
.fin-mes { margin-bottom: 22px; }
.fin-mes-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; padding-bottom: 8px; border-bottom: 1px solid var(--portal-line-strong); }
.fin-mes-head h4 { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; color: var(--portal-text); }
.fin-mes-meta { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--portal-text-faint); }
@media (max-width: 560px) {
  .fin-modos { width: 100%; }
  .fin-modo { flex: 1; }
}

/* cartão de pagamento Pix */
.pix-hero {
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-lg);
  background: var(--portal-card-bg); box-shadow: var(--shadow-soft); padding: 22px; margin-bottom: 8px; overflow: hidden;
}
.pix-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-bottom: 18px; border-bottom: 1px solid var(--portal-line); }
.pix-eyebrow { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--portal-text-faint); }
.pix-head-info h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--portal-text); margin: 6px 0 4px; }
.pix-venc { font-size: 0.82rem; color: var(--portal-text-dim); }
.pix-venc.atraso { color: #f0a9a9; }
.pix-valor { font-family: var(--font-display); font-weight: 800; font-size: 1.7rem; color: var(--steel-bright); white-space: nowrap; }
.pix-pagamento { display: flex; gap: 20px; padding: 20px 0; flex-wrap: wrap; }
.pix-qr {
  flex: none; width: 168px; height: 168px; padding: 11px; border-radius: var(--r-md);
  background: #fff; display: flex; align-items: center; justify-content: center; box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.08);
}
.pix-qr svg { width: 100%; height: 100%; display: block; }
.pix-qr-vazio { font-size: 0.7rem; color: var(--doc-ink-soft); text-align: center; padding: 0 8px; }
.pix-cc-area { flex: 1 1 230px; min-width: 0; display: flex; flex-direction: column; gap: 9px; }
.pix-cc-rotulo { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--portal-text-faint); }
.pix-cc {
  display: block; max-height: 96px; overflow: auto; word-break: break-all;
  padding: 11px 13px; border-radius: var(--r-sm); border: 1px dashed var(--portal-line-strong);
  background: color-mix(in srgb, var(--portal-fill) 55%, transparent); color: var(--portal-text-dim); font-family: var(--font-mono); font-size: 0.72rem; line-height: 1.5;
}
.pix-copiar { align-self: flex-start; }
.pix-rodape { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; padding-top: 18px; border-top: 1px solid var(--portal-line); }
.pix-informado { display: inline-flex; align-items: center; gap: 8px; font-size: 0.84rem; color: var(--green); font-weight: 600; }
.pix-informado::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--green); flex: none; }
.pix-nota { font-size: 0.76rem; color: var(--portal-text-dim); }

/* admin: cobranças do paciente + config Pix + confirmação de pagamentos */
.cob-row { position: relative; padding-left: 14px; }
.cob-row::before { content: ""; position: absolute; left: 0; top: 10px; bottom: 10px; width: 3px; border-radius: var(--r-pill); background: var(--portal-text-faint); }
.cob-row.pago::before { background: var(--green); }
.cob-row.atrasada::before { background: var(--danger); }
.cob-row.analise::before { background: var(--gold); }
.cob-row.cancelada::before { background: var(--portal-text-dim); opacity: 0.5; }
.cob-acoes { display: flex; gap: 8px; flex-wrap: wrap; flex: none; }
.cob-form label { display: flex; flex-direction: column; gap: 4px; font-size: 0.74rem; color: var(--portal-text-faint); }
.cob-form input, .cob-form select {
  padding: 10px 12px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong);
  background: color-mix(in srgb, var(--portal-fill) 55%, transparent); color: var(--portal-text); font-family: inherit; font-size: 0.88rem; outline: 0; width: 100%;
}
.cob-form input:focus, .cob-form select:focus { border-color: var(--steel); }
.cob-form label small { font-size: 0.66rem; font-weight: 400; color: var(--portal-text-dim); margin-top: 1px; }
/* tabela de alimentos (substituição) na Administração */
.alim-grupo-tit { display: block; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--portal-text-faint); margin: 16px 0 2px; }
.alim-grupo:first-child .alim-grupo-tit { margin-top: 4px; }
.alim-row.inativo { opacity: 0.5; }
.alim-row .ar-info span em { color: var(--portal-text-dim); font-style: italic; }
.pix-config { margin-bottom: 6px; }
.pix-preview { margin-top: 10px; font-size: 0.8rem; }
.px-ok { color: var(--green); font-family: var(--font-mono); font-size: 0.74rem; word-break: break-all; }
.px-ok strong { color: var(--portal-text); }
.px-pend { color: var(--portal-text-dim); font-size: 0.82rem; }
.pix-confirmar { margin-top: 18px; }
.pix-confirmar-head { display: flex; align-items: center; gap: 12px; margin-bottom: 4px; }
.pix-confirmar-head h4 { font-family: var(--font-display); font-weight: 700; font-size: 0.98rem; color: var(--portal-text); }
.px-alerta {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-mid);
  border: 1px solid color-mix(in srgb, var(--gold) 45%, transparent); background: color-mix(in srgb, var(--gold) 10%, transparent); border-radius: var(--r-pill); padding: 3px 10px;
}

/* QR do aluno (gerado ou enviado) + beneficiário + legenda */
.pix-benef { font-size: 0.78rem; color: var(--portal-text-dim); margin-top: 4px; }
.pix-qr-wrap { display: flex; flex-direction: column; align-items: center; gap: 8px; flex: none; }
.pix-qr-img { width: 100%; height: 100%; object-fit: contain; display: block; }
.pix-qr-cap { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--portal-text-faint); max-width: 168px; text-align: center; line-height: 1.45; }

/* pop-up "sua cobrança chegou" (link enviado pelo Matheus) */
.cob-aviso {
  display: flex; flex-direction: column; gap: 5px; align-items: center; text-align: center;
  padding: 18px; margin: 6px 0 14px; border-radius: var(--r-md);
  border: 1px solid color-mix(in srgb, var(--gold) 40%, transparent); background: color-mix(in srgb, var(--gold) 7%, transparent);
}
.cob-aviso-desc { font-family: var(--font-display); font-weight: 600; font-size: 1rem; color: var(--portal-text); }
.cob-aviso-valor { font-family: var(--font-display); font-weight: 800; font-size: 2rem; color: var(--steel-bright); letter-spacing: -0.01em; }
.cob-aviso-venc { font-size: 0.8rem; color: var(--portal-text-dim); }
.cob-aviso-venc.atraso { color: #f0a9a9; }

/* admin: upload do QR do Pix */
.pix-qr-cad { margin: 12px 0; }
.pix-qr-cad-lb { display: block; font-size: 0.74rem; color: var(--portal-text-faint); margin-bottom: 8px; }
.pix-qr-cad-lb small { color: var(--portal-text-dim); }
.pix-qr-cad-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.pix-qr-prev { width: 88px; height: 88px; object-fit: contain; background: #fff; border-radius: var(--r-sm); padding: 6px; }

@media (max-width: 560px) {
  .pix-pagamento { flex-direction: column; align-items: center; }
  .pix-cc-area { width: 100%; }
  .pix-head { flex-direction: column; }
  .fin-row-dir { flex-direction: column; align-items: flex-end; gap: 6px; }
}

/* ===== Minimizar blocos: form do Matheus (.df-min) + leitura do paciente (.doc-min) ===== */
.df-min, .doc-min {
  display: inline-flex; align-items: center; justify-content: center; flex: none;
  width: 36px; height: 36px; border-radius: 50%; cursor: pointer;
  border: 1px solid var(--portal-line-strong); background: rgba(237, 255, 255, 0.05); color: var(--portal-text-dim);
  transition: color 0.18s var(--ease), border-color 0.18s var(--ease), background 0.18s var(--ease);
}
.df-min:hover, .doc-min:hover { color: var(--portal-text); border-color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 12%, transparent); }
.df-min svg, .doc-min svg { width: 14px; height: 14px; }
/* form do Matheus (fundo escuro) — botão no canto do fieldset */
.df-refeicao { position: relative; }
.df-refeicao > .df-min { position: absolute; top: 8px; right: 8px; }
/* leitura do paciente (papel claro) — botão escuro sobre o claro */
.tem-min { position: relative; }
.tem-min > .doc-min { position: absolute; top: 12px; right: 12px; border-color: color-mix(in srgb, var(--portal-fill) 18%, transparent); background: color-mix(in srgb, var(--portal-fill) 4%, transparent); color: var(--doc-ink-soft); }
.tem-min > .doc-min:hover { color: var(--navy-900); border-color: color-mix(in srgb, var(--portal-fill) 40%, transparent); background: color-mix(in srgb, var(--portal-fill) 9%, transparent); }
.ref-card.tem-min > header, .treino-dia.tem-min > header { padding-right: 40px; }
.dieta-orientacoes.tem-min > h4, .ficha-notas.tem-min > h4 { padding-right: 40px; }
/* O recolher é SÓ de tela — em @media print as regras abaixo não valem, então o PDF/impressão sai COMPLETO */
@media screen {
  .df-refeicao.is-min { padding-bottom: 14px; }
  .df-refeicao.is-min > *:not(legend):not(.df-min) { display: none; }
  .ref-card.is-min > *:not(header):not(.doc-min) { display: none; }
  .dieta-orientacoes.is-min > *:not(h4):not(.doc-min) { display: none; }
  .treino-dia.is-min > *:not(header):not(.doc-min) { display: none; }
  .ficha-notas.is-min > *:not(h4):not(.doc-min) { display: none; }
  .an-bloco.is-min .an-bloco-corpo { display: none; }
  .an-aval-item.is-min .an-aval-corpo { display: none; }
}
@media print {
  .df-min, .doc-min, .ab-toggle, .an-min { display: none !important; }
}

/* ===== Vídeos de dicas: filtros + grid de cards + player ===== */
.dica-filtros { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.dica-chip {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.08em;
  min-height: 36px; padding: 0 14px; border-radius: var(--r-pill);
  border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); color: var(--portal-text-dim);
  cursor: pointer; transition: border-color 0.16s var(--ease), color 0.16s var(--ease), background 0.16s var(--ease);
}
.dica-chip.ativa { color: var(--portal-text); border-color: var(--steel-bright); background: color-mix(in srgb, var(--steel-bright) 14%, transparent); }

.dica-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.dica-card {
  display: flex; flex-direction: column; text-align: left; padding: 0; cursor: pointer;
  border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); overflow: hidden;
  background: linear-gradient(165deg, rgba(26, 51, 80, 0.5), rgba(10, 26, 46, 0.7)); color: inherit;
  transition: transform 0.18s var(--ease), box-shadow 0.18s var(--ease), border-color 0.18s var(--ease);
}
.dica-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); border-color: var(--portal-text-faint); }
.dica-capa { position: relative; display: block; aspect-ratio: 16 / 9; background: var(--navy-900); overflow: hidden; }
.dica-thumb { width: 100%; height: 100%; object-fit: cover; display: block; }
.dica-thumb.sem-thumb { display: flex; align-items: center; justify-content: center; color: var(--portal-text-faint); }
.dica-thumb.sem-thumb svg { width: 38px; height: 38px; }
.dica-play {
  position: absolute; inset: 0; margin: auto; width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: color-mix(in srgb, var(--portal-fill) 62%, transparent); color: #fff;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.4), inset 0 0 0 1px rgba(237, 255, 255, 0.25);
  transition: background 0.18s var(--ease), transform 0.18s var(--ease);
}
.dica-card:hover .dica-play { background: var(--steel-bright); transform: scale(1.06); }
.dica-info { display: flex; flex-direction: column; gap: 5px; padding: 13px 15px 15px; min-width: 0; }
.dica-cat { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--steel-bright); }
.dica-titulo {
  font-family: var(--font-display); font-weight: 700; font-size: 1rem; line-height: 1.25; color: var(--portal-text);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.dica-desc { margin-top: 14px; }
.dica-desc p { font-size: 0.92rem; line-height: 1.6; color: var(--portal-text-dim); }

/* ===== Controle de treinos: calendário mensal ===== */
.aula-sel { display: flex; flex-direction: column; gap: 5px; margin-bottom: 16px; }
.aula-sel > span { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--portal-text-faint); }
.aula-sel select { padding: 12px 14px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font-family: inherit; font-size: 0.95rem; min-height: 44px; outline: 0; }
.cal-topo { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.cal-nav { flex: none; width: 44px; min-height: 44px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--portal-line-strong); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); color: var(--portal-text-dim); cursor: pointer; transition: color .15s var(--ease), border-color .15s var(--ease); }
.cal-nav:hover { color: var(--portal-text); border-color: var(--portal-text-faint); }
.cal-titulo { flex: 1; font-family: var(--font-display); font-weight: 700; font-size: 1.12rem; color: var(--portal-text); text-align: center; }
.cal-grade { display: grid; grid-template-columns: repeat(7, 1fr); gap: 5px; }
.cal-wd { text-align: center; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.08em; color: var(--portal-text-faint); padding-bottom: 4px; }
.cal-vazio { aspect-ratio: 1 / 1; }
.cal-dia { aspect-ratio: 1 / 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px; min-height: 42px; border: 1px solid var(--portal-line); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 40%, transparent); color: var(--portal-text-dim); cursor: pointer; transition: border-color .15s var(--ease), background .15s var(--ease); }
.cal-dia:hover { border-color: var(--portal-text-faint); }
.cal-dia.hoje { box-shadow: inset 0 0 0 1.5px var(--steel-bright); }
.cal-num { font-family: var(--font-mono); font-size: 0.82rem; }
.cal-hora { font-family: var(--font-mono); font-size: 0.62rem; opacity: 0.95; }
.cal-dia.feita { background: rgba(127, 214, 168, 0.16); border-color: rgba(127, 214, 168, 0.5); color: #c2ecd3; }
.cal-dia.repor { background: color-mix(in srgb, var(--steel-bright) 16%, transparent); border-color: color-mix(in srgb, var(--steel-bright) 50%, transparent); color: var(--portal-text-faint); }
.cal-dia.cancelada { background: rgba(217, 99, 127, 0.16); border-color: rgba(217, 99, 127, 0.5); color: #f0b9c4; }
.cal-legenda { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 14px; font-family: var(--font-mono); font-size: 0.68rem; color: var(--portal-text-dim); }
.cal-legenda span { display: inline-flex; align-items: center; gap: 6px; }
.cal-pt { width: 11px; height: 11px; border-radius: 3px; flex: none; }
.cal-pt.feita { background: #7fd6a8; }
.cal-pt.repor { background: var(--steel-bright); }
.cal-pt.cancelada { background: #d9637f; }
.cal-contadores { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 20px; }
.cal-card { border: 1px solid var(--portal-line-strong); border-radius: var(--r-md); padding: 14px 10px; text-align: center; background: color-mix(in srgb, var(--portal-fill) 40%, transparent); }
.cal-card strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 1.8rem; line-height: 1; margin-bottom: 5px; }
.cal-card span { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--portal-text-faint); }
.cal-card.feita strong { color: #7fd6a8; }
.cal-card.repor strong { color: var(--steel-bright); }
.cal-card.cancelada strong { color: #f0a9a9; }
.aula-opts { display: flex; gap: 8px; flex-wrap: wrap; margin: 6px 0 14px; }
.aula-opt { min-height: 40px; padding: 0 14px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); color: var(--portal-text-dim); cursor: pointer; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.04em; }
.aula-opt.ativa.feita { border-color: #7fd6a8; color: #c2ecd3; background: rgba(127, 214, 168, 0.14); }
.aula-opt.ativa.repor { border-color: var(--steel-bright); color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 14%, transparent); }
.aula-opt.ativa.cancelada { border-color: #d9637f; color: #f0b9c4; background: rgba(217, 99, 127, 0.14); }
.aula-status-linha { font-family: var(--font-mono); font-size: 0.82rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 4px 0 8px; }
.aula-status-linha.feita { color: #7fd6a8; }
.aula-status-linha.repor { color: var(--steel-bright); }
.aula-status-linha.cancelada { color: #f0a9a9; }
.aula-status-linha.agendada { color: var(--steel-bright); }
/* estados derivados da agenda padrão */
.cal-dia.agendada { background: color-mix(in srgb, var(--portal-text-faint) 9%, transparent); border-color: var(--portal-line-strong); color: var(--portal-text-faint); }
.cal-dia.folga { opacity: 0.45; }
.cal-dia.folga .cal-num { text-decoration: line-through; }
.cal-pt.agendada { background: var(--steel-metal); }
.aula-opt.ativa.folga { border-color: var(--portal-text-faint); color: var(--portal-text); background: color-mix(in srgb, var(--portal-text-faint) 10%, transparent); }
.aula-sub { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--portal-text-faint); margin-bottom: 12px; }
/* linha de controles do admin (seletor + botão da agenda padrão) */
.aula-controles { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; }
.aula-controles .aula-sel { flex: 1 1 200px; margin-bottom: 0; }
/* editor da agenda padrão */
.ap-dias { display: flex; flex-direction: column; gap: 8px; margin: 6px 0 14px; }
.ap-dia { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border: 1px solid var(--portal-line); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 40%, transparent); cursor: pointer; }
.ap-dia.ativo { border-color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 8%, transparent); }
.ap-dia input[type=checkbox] { width: 18px; height: 18px; accent-color: var(--steel-bright); flex: none; }
.ap-nome { flex: 1; font-family: var(--font-mono); font-size: 0.82rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--portal-text); }
.ap-dia input[type=time] { padding: 8px 10px; border-radius: var(--r-sm); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font-family: var(--font-mono); font-size: 0.85rem; min-height: 40px; outline: 0; }
.ap-dia input[type=time]:disabled { opacity: 0.4; }
/* visão global (todos os alunos): contagem por status no dia + lista do dia + contadores mês/ano */
.cal-grade.glob .cal-dia { aspect-ratio: auto; min-height: 56px; justify-content: flex-start; padding: 5px 2px 4px; gap: 3px; }
.cal-dia-g.vazia { opacity: 0.5; }
.cal-g-cnt { display: flex; gap: 3px; flex-wrap: wrap; justify-content: center; }
.cg { font-family: var(--font-mono); font-size: 0.62rem; font-weight: 700; line-height: 1.4; padding: 0 4px; border-radius: 4px; }
.cg.feita { color: #c2ecd3; background: rgba(127, 214, 168, 0.16); }
.cg.agendada { color: var(--portal-text-faint); background: color-mix(in srgb, var(--portal-text-faint) 12%, transparent); }
.cg.repor { color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 18%, transparent); }
.cg.cancelada { color: #f0b9c4; background: rgba(217, 99, 127, 0.18); }
.cal-cont-grupo { margin-top: 18px; }
.cal-cont-grupo .cal-contadores { margin-top: 8px; }
.cal-cont-tit { display: block; font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--portal-text-faint); }
.dg-lista { display: flex; flex-direction: column; gap: 8px; }
.dg-item { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border: 1px solid var(--portal-line); border-left-width: 3px; border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 40%, transparent); }
.dg-item.feita { border-left-color: #7fd6a8; }
.dg-item.agendada { border-left-color: var(--steel-metal); }
.dg-item.repor { border-left-color: var(--steel-bright); }
.dg-item.cancelada { border-left-color: #d9637f; }
.dg-hora { font-family: var(--font-mono); font-size: 0.82rem; color: var(--portal-text); flex: none; min-width: 44px; }
.dg-nome { flex: 1; min-width: 0; color: var(--portal-text); font-size: 0.92rem; }
.dg-st { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.06em; text-transform: uppercase; }
.dg-st.feita { color: #7fd6a8; }
.dg-st.agendada { color: var(--portal-text-faint); }
.dg-st.repor { color: var(--steel-bright); }
.dg-st.cancelada { color: #f0a9a9; }
/* ----- Controle de consultas: atendida(verde)/remarcada(azul) reusam a paleta do calendário ----- */
.cal-dia.atendida { background: rgba(127, 214, 168, 0.16); border-color: rgba(127, 214, 168, 0.5); color: #c2ecd3; }
.cal-dia.remarcada { background: color-mix(in srgb, var(--steel-bright) 16%, transparent); border-color: color-mix(in srgb, var(--steel-bright) 50%, transparent); color: var(--portal-text-faint); }
.cal-pt.atendida { background: #7fd6a8; }
.cal-pt.remarcada { background: var(--steel-bright); }
.cg.atendida { color: #c2ecd3; background: rgba(127, 214, 168, 0.16); }
.cg.remarcada { color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 18%, transparent); }
.cal-card.atendida strong { color: #7fd6a8; }
.cal-card.remarcada strong { color: var(--steel-bright); }
.dg-item.atendida { border-left-color: #7fd6a8; }
.dg-item.remarcada { border-left-color: var(--steel-bright); }
.dg-st.atendida { color: #7fd6a8; }
.dg-st.remarcada { color: var(--steel-bright); }
.aula-opt.ativa.atendida { border-color: #7fd6a8; color: #c2ecd3; background: rgba(127, 214, 168, 0.14); }
.aula-opt.ativa.remarcada { border-color: var(--steel-bright); color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 14%, transparent); }
.cs-linha { display: flex; gap: 10px; }
.cs-linha .df-bloco { flex: 1; min-width: 0; }
.dg-item.dg-click { width: 100%; text-align: left; cursor: pointer; font: inherit; transition: border-color .15s var(--ease), background .15s var(--ease); }
.dg-item.dg-click:hover { border-color: var(--portal-text-faint); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); }
.dg-obs { color: var(--portal-text-faint); font-style: normal; font-size: 0.82rem; }
.cc-at { font-family: var(--font-display); font-weight: 800; color: var(--portal-text); }
/* pop-up semanal de revisão (admin) */
.rs-lista { display: flex; flex-direction: column; gap: 10px; margin: 6px 0 14px; max-height: 50vh; overflow: auto; }
.rs-aula { border: 1px solid var(--portal-line); border-radius: var(--r-sm); padding: 10px 12px; background: color-mix(in srgb, var(--portal-fill) 40%, transparent); }
.rs-info { display: flex; flex-direction: column; gap: 1px; margin-bottom: 8px; }
.rs-quando { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--portal-text-faint); }
.rs-info strong { color: var(--portal-text); font-size: 0.95rem; }
.rs-opts { display: flex; gap: 6px; flex-wrap: wrap; }
.rs-opt { min-height: 36px; padding: 0 12px; border-radius: var(--r-pill); border: 1px solid var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); color: var(--portal-text-dim); cursor: pointer; font-family: var(--font-mono); font-size: 0.72rem; }
.rs-opt.ativa.feita { border-color: #7fd6a8; color: #c2ecd3; background: rgba(127, 214, 168, 0.14); }
.rs-opt.ativa.repor { border-color: var(--steel-bright); color: var(--portal-text-faint); background: color-mix(in srgb, var(--steel-bright) 14%, transparent); }
.rs-opt.ativa.cancelada { border-color: #d9637f; color: #f0b9c4; background: rgba(217, 99, 127, 0.14); }
.rs-opt.ativa.folga { border-color: var(--portal-text-faint); color: var(--portal-text); background: color-mix(in srgb, var(--portal-text-faint) 10%, transparent); }

/* ───────── importador de pacientes (admin) ───────── */
.imp-drop { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; padding: 16px; border: 1px dashed var(--portal-line-strong); border-radius: var(--r-md); background: color-mix(in srgb, var(--portal-fill) 40%, transparent); }
.imp-arquivo { font-family: var(--font-mono); font-size: 0.74rem; color: var(--portal-text-dim); }
.imp-colar { flex-basis: 100%; margin-top: 2px; }
.imp-colar summary { cursor: pointer; color: var(--portal-text-faint); font-size: 0.82rem; }
.imp-colar textarea, .imp-resultado textarea { width: 100%; margin-top: 8px; padding: 10px 12px; border: 1px solid var(--portal-line); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font-family: var(--font-mono); font-size: 0.78rem; resize: vertical; }
.imp-config { margin-top: 16px; display: flex; flex-direction: column; gap: 16px; }
.imp-map-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 8px 14px; margin-top: 8px; }
.imp-map-row { display: flex; flex-direction: column; gap: 3px; }
.imp-map-row > span { font-size: 0.74rem; color: var(--portal-text-dim); }
.imp-map-row select { padding: 8px 10px; min-height: 40px; border: 1px solid var(--portal-line); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font: inherit; font-size: 0.84rem; }
.imp-previa { display: flex; flex-direction: column; gap: 4px; }
.imp-tab-wrap { overflow: auto; max-height: 320px; border: 1px solid var(--portal-line); border-radius: var(--r-sm); }
.imp-tab { width: 100%; border-collapse: collapse; font-size: 0.8rem; }
.imp-tab th { position: sticky; top: 0; background: var(--navy-700); color: var(--portal-text-faint); text-align: left; padding: 8px 10px; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap; }
.imp-tab td { padding: 7px 10px; border-top: 1px solid var(--portal-line); color: var(--portal-text); white-space: nowrap; max-width: 220px; overflow: hidden; text-overflow: ellipsis; }
.imp-tab tr.imp-row-bad td { background: rgba(217, 99, 127, 0.1); color: #f0b9c4; }
.imp-resultado { margin-top: 16px; display: flex; flex-direction: column; gap: 10px; }
.imp-resumo { display: flex; gap: 8px; flex-wrap: wrap; }
.imp-pill { padding: 5px 12px; border-radius: var(--r-pill); font-family: var(--font-mono); font-size: 0.74rem; border: 1px solid var(--portal-line-strong); }
.imp-pill.ok { color: #c2ecd3; background: rgba(127, 214, 168, 0.16); border-color: rgba(127, 214, 168, 0.4); }
.imp-pill.mid { color: var(--portal-text-dim); background: color-mix(in srgb, var(--portal-text-faint) 10%, transparent); }
.imp-pill.bad { color: #f0b9c4; background: rgba(217, 99, 127, 0.16); border-color: rgba(217, 99, 127, 0.4); }
.imp-pill.off { color: var(--portal-text-dim); opacity: 0.6; }
.imp-erros { font-size: 0.84rem; color: var(--portal-text-dim); }
.imp-erros summary { cursor: pointer; color: var(--danger); }
.imp-erros ul { margin: 8px 0 0; padding-left: 18px; display: flex; flex-direction: column; gap: 4px; }

/* ───────── wizard de identidade da marca (admin) ───────── */
#form-marca { display: flex; flex-direction: column; gap: 28px; }
.wm-grupo { display: flex; flex-direction: column; gap: 14px; padding-bottom: 20px; border-bottom: 1px solid var(--portal-line); }
.wm-grupo:last-of-type { border-bottom: none; }
.wm-grupo h4 { font-family: var(--font-display); font-weight: 700; font-size: 0.9rem; color: var(--portal-text); letter-spacing: 0.03em; margin: 0; display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px; }
.wm-cores-nota { font-family: var(--font-body); font-weight: 400; font-size: 0.8rem; color: var(--portal-text-dim); letter-spacing: 0; }

/* campos de texto */
.wm-linha2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wm-linha2 label { display: flex; flex-direction: column; gap: 5px; font-size: 0.8rem; color: var(--portal-text-dim); }
.wm-linha2 input[type="text"] { padding: 10px 12px; border: 1px solid var(--portal-line-strong); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font: inherit; font-size: 0.9rem; min-height: 40px; outline: 0; transition: border-color .15s var(--ease); }
.wm-linha2 input[type="text"]:focus { border-color: var(--steel); }

/* logos */
.wm-logos { display: flex; flex-direction: column; gap: 20px; }
.wm-logo-bloco { display: flex; align-items: flex-start; gap: 16px; }
.wm-logo-prev { flex: none; width: 160px; height: 80px; border: 1px solid var(--portal-line); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 70%, transparent); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.wm-logo-prev.wm-logo-sm { width: 80px; height: 80px; }
.wm-logo-prev img { max-width: 100%; max-height: 100%; object-fit: contain; display: block; }
.wm-logo-info { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.wm-logo-info strong { font-size: 0.88rem; color: var(--portal-text); }
.wm-logo-info > span { font-size: 0.78rem; color: var(--portal-text-dim); line-height: 1.45; }
.wm-file-btn { cursor: pointer; display: inline-flex; align-items: center; }
.wm-file-nome { font-family: var(--font-mono); font-size: 0.72rem; color: var(--portal-text-faint); word-break: break-all; }

/* cores */
.wm-cores { display: flex; flex-direction: column; gap: 14px; }
.wm-cor { display: flex; flex-direction: column; gap: 6px; }
.wm-cor-rotulo { font-size: 0.8rem; color: var(--portal-text-dim); }
.wm-cor-linha { display: flex; align-items: center; gap: 10px; }
.wm-cor-linha input[type="color"] { flex: none; width: 40px; height: 40px; padding: 3px; border: 1px solid var(--portal-line-strong); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); cursor: pointer; }
.wm-cor-hex { width: 112px; padding: 8px 10px; border: 1px solid var(--portal-line-strong); border-radius: var(--r-sm); background: color-mix(in srgb, var(--portal-fill) 60%, transparent); color: var(--portal-text); font-family: var(--font-mono); font-size: 0.82rem; outline: 0; transition: border-color .15s var(--ease); }
.wm-cor-hex:focus { border-color: var(--steel); }

/* ações */
.wm-acoes { display: flex; flex-direction: column; gap: 10px; padding-top: 4px; }
.wm-fb { font-size: 0.84rem; color: var(--portal-text-dim); margin: 0; min-height: 1.2em; }
.wm-fb.ok { color: var(--green); }
.wm-fb.erro { color: var(--danger); }

@media (max-width: 600px) {
  .wm-linha2 { grid-template-columns: 1fr; }
  .wm-logo-bloco { flex-direction: column; }
  .wm-logo-prev { width: 100%; height: 90px; }
  .wm-logo-prev.wm-logo-sm { width: 80px; height: 80px; }
  .wm-cor-hex { width: 90px; }
}
.imp-erros strong { color: var(--portal-text); }

/* ── Simulador de marca (#/simular) — white-label self-service ────────────── */
.auth-pro { margin-top: 16px; text-align: center; font-size: 0.86rem; color: var(--portal-text-dim); }
.auth-pro span { opacity: 0.8; }
.auth-pro a { color: var(--gold); font-weight: 600; border-bottom: 1px solid color-mix(in srgb, var(--gold) 40%, transparent); }
.auth-pro a:hover { color: var(--gold-mid); }

.sim .auth-card { max-width: 440px; }
.sim-brand h1 em { color: var(--gold); }
.sim-bullets { list-style: none; margin: 26px 0 0; padding: 22px 0 0; border-top: 1px solid var(--portal-line); display: grid; gap: 12px; text-align: left; max-width: 42ch; }
.sim-bullets li { position: relative; padding-left: 26px; color: var(--portal-text-dim); font-size: 0.95rem; }
.sim-bullets li::before { content: ""; position: absolute; left: 0; top: 7px; width: 9px; height: 9px; border-radius: 2px 6px 2px 6px; background: linear-gradient(135deg, var(--steel-bright), var(--steel)); }
.sim-bullets strong { color: var(--portal-text); }

.sim-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 520px) { .sim-grid2 { grid-template-columns: 1fr; gap: 0; } }

/* Dropzone do logo */
.sim-drop { display: block; cursor: pointer; border: 1.5px dashed var(--portal-line-strong); border-radius: var(--r-md); background: color-mix(in srgb, var(--portal-text-faint) 4%, transparent); transition: border-color 0.2s, background 0.2s; }
.sim-drop:hover, .sim-drop:focus-visible, .sim-drop.arrastando { border-color: var(--steel); background: color-mix(in srgb, var(--steel) 10%, transparent); outline: none; }
.sim-drop.tem-logo { border-style: solid; border-color: var(--portal-line-strong); background: color-mix(in srgb, var(--portal-fill) 50%, transparent); }
.sim-drop-body { display: flex; align-items: center; gap: 14px; padding: 18px; min-height: 84px; }
.sim-drop-ic { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; background: color-mix(in srgb, var(--portal-text-faint) 10%, transparent); color: var(--portal-text-faint); flex: none; }
.sim-drop-ic svg { width: 22px; height: 22px; }
.sim-drop-txt { font-size: 0.9rem; color: var(--portal-text-dim); line-height: 1.45; }
.sim-drop-txt strong { color: var(--portal-text); font-weight: 600; }
.sim-drop-txt em { font-style: normal; font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--portal-text-faint); }
.sim-logo-prev { max-height: 56px; max-width: 160px; object-fit: contain; border-radius: 6px; }
.sim-drop-troca { font-size: 0.82rem; color: var(--steel-bright); font-weight: 600; }

/* Seletor de cor + swatches derivados */
.sim-cor { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.sim-cor input[type="color"] { width: 46px; height: 38px; padding: 0; border: 1px solid var(--portal-line-strong); border-radius: 9px; background: none; cursor: pointer; flex: none; }
.sim-cor input[type="color"]::-webkit-color-swatch-wrapper { padding: 3px; }
.sim-cor input[type="color"]::-webkit-color-swatch { border: none; border-radius: 6px; }
.sim-swatches { display: flex; gap: 6px; }
.sim-swatches .sw { width: 26px; height: 26px; border-radius: 7px; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.14); }
.sim-cor-hint { font-size: 0.78rem; color: var(--portal-text-dim); flex: 1 1 100%; }

.sim-go svg { width: 19px; height: 19px; }

/* Barra flutuante da simulação (sobre o portal convertido) */
.sim-bar { position: fixed; left: 50%; bottom: 22px; transform: translateX(-50%); z-index: 9999; display: flex; align-items: center; gap: 18px; padding: 10px 12px 10px 20px; border-radius: var(--r-pill); background: color-mix(in srgb, var(--portal-fill) 86%, transparent); backdrop-filter: blur(14px); border: 1px solid var(--portal-line-strong); box-shadow: var(--shadow-lift); max-width: calc(100vw - 28px); }
.sim-bar-tag { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--portal-text-faint); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sim-bar-acoes { display: flex; gap: 8px; flex: none; }
.sim-bar-acoes button { padding: 9px 16px; border-radius: var(--r-pill); font-size: 0.86rem; font-weight: 600; transition: transform 0.15s, box-shadow 0.2s, color 0.2s, border-color 0.2s; }
.sim-bar-acoes button[data-editar] { border: 1px solid var(--portal-line-strong); color: var(--portal-text-dim); }
.sim-bar-acoes button[data-editar]:hover { color: var(--portal-text); border-color: var(--portal-text-faint); }
.sim-bar-cta { background: linear-gradient(180deg, var(--steel-bright), var(--steel)); color: #fff; box-shadow: 0 8px 20px color-mix(in srgb, var(--steel) 40%, transparent); }
.sim-bar-cta:hover { transform: translateY(-1px); box-shadow: 0 12px 26px color-mix(in srgb, var(--steel) 50%, transparent); }
@media (max-width: 480px) { .sim-bar { bottom: 12px; gap: 10px; padding-left: 14px; } .sim-bar-tag { font-size: 0.6rem; } }

/* ── Portal de DEMONSTRAÇÃO do simulador (#/simular → ver portal) ───────────── */
/* Usa os tokens do portal; os acentos (--steel*) já vêm sobrescritos pela marca do
   visitante via mesclarBranding, então o demo aparece na cor dele. */
.sim-demo{position:relative; z-index:2; max-width:min(800px,94vw); margin:26px auto 120px; background:var(--navy-700); border:1px solid var(--portal-line); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-lift)}
.sd-top{display:flex; align-items:center; gap:14px; padding:18px 22px; background:linear-gradient(180deg,var(--navy-600),var(--navy-700)); border-bottom:1px solid var(--portal-line)}
.sd-logo{height:36px; width:auto; max-width:140px; object-fit:contain; flex:none}
.sd-id .sd-marca{font-family:var(--font-display); font-weight:700; color:var(--portal-text); font-size:1.02rem; line-height:1.1}
.sd-id .sd-prof{font-size:.76rem; color:var(--portal-text-dim)}
.sd-badge{margin-left:auto; font-family:var(--font-mono); font-size:.58rem; letter-spacing:.16em; text-transform:uppercase; color:var(--portal-text-faint); border:1px solid var(--portal-line-strong); border-radius:var(--r-pill); padding:5px 11px; white-space:nowrap}
.sd-tabs{display:flex; gap:2px; padding:0 12px; background:var(--navy-700); border-bottom:1px solid var(--portal-line); overflow-x:auto}
.sd-tab{padding:14px 16px; font-size:.86rem; font-weight:600; color:var(--portal-text-dim); border:none; border-bottom:2px solid transparent; white-space:nowrap; background:none; cursor:pointer; transition:color .2s}
.sd-tab:hover{color:var(--portal-text)}
.sd-tab.on{color:var(--portal-text); border-bottom-color:var(--steel-bright)}
.sd-body{padding:24px; background:var(--navy-800); min-height:400px}
.sd-view{display:none}
.sd-view.on{display:block; animation:sdIn .34s var(--ease)}
@keyframes sdIn{from{opacity:0; transform:translateY(10px)}to{opacity:1; transform:none}}
.sd-h{font-family:var(--font-display); font-size:1.55rem; color:var(--portal-text); margin-bottom:3px}
.sd-sub{font-size:.84rem; color:var(--portal-text-dim); margin-bottom:20px}
.sd-cards{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.sd-card{background:var(--navy-600); border:1px solid var(--portal-line); border-radius:var(--r-md); padding:16px}
.sd-ct{font-family:var(--font-display); font-weight:600; color:var(--portal-text); font-size:.96rem; display:flex; justify-content:space-between; align-items:center; gap:8px; margin-bottom:6px}
.sd-tag{font-family:var(--font-mono); font-size:.56rem; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-bright); font-weight:600; white-space:nowrap}
.sd-card>p{font-size:.86rem; color:var(--portal-text-dim); margin:0}
.sd-pill{display:inline-block; font-size:.6rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:#fff; background:var(--steel); padding:5px 12px; border-radius:var(--r-pill); margin-bottom:9px}
.sd-meal-group{margin-bottom:14px}
.sd-meal{display:flex; justify-content:space-between; gap:10px; padding:9px 0; border-bottom:1px dashed var(--portal-line); font-size:.9rem; color:var(--portal-text-dim)}
.sd-meal:last-child{border-bottom:none}
.sd-meal b{color:var(--portal-text); font-weight:600}
.sd-meal span{font-family:var(--font-mono); font-size:.78rem; white-space:nowrap}
.sd-ex{display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--portal-line)}
.sd-ex:last-child{border-bottom:none}
.sd-exn{width:26px; height:26px; border-radius:7px; background:var(--steel); color:#fff; display:grid; place-items:center; font-family:var(--font-mono); font-weight:600; font-size:.72rem; flex:none}
.sd-exname{flex:1; color:var(--portal-text); font-weight:500; font-size:.92rem}
.sd-exset{font-family:var(--font-mono); font-size:.8rem; color:var(--portal-text-dim)}
.sd-chart{display:flex; align-items:flex-end; gap:10px; height:152px; padding:24px 8px 6px; background:var(--navy-600); border:1px solid var(--portal-line); border-radius:var(--r-md); margin-bottom:16px}
.sd-bar{flex:1; background:linear-gradient(180deg,var(--steel-bright),var(--steel)); border-radius:6px 6px 0 0; position:relative}
.sd-bar span{position:absolute; top:-17px; left:50%; transform:translateX(-50%); font-family:var(--font-mono); font-size:.62rem; color:var(--portal-text-dim)}
.sd-bar small{position:absolute; bottom:-18px; left:50%; transform:translateX(-50%); font-size:.6rem; color:var(--portal-text-dim)}
.sd-metrics{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:26px}
.sd-metric{background:var(--navy-600); border:1px solid var(--portal-line); border-radius:var(--r-md); padding:14px}
.sd-metric .sd-mv{font-family:var(--font-display); font-weight:800; color:var(--portal-text); font-size:1.4rem; line-height:1}
.sd-metric .sd-mv small{font-size:.7rem; color:var(--portal-text-dim)}
.sd-metric .sd-mk{font-size:.6rem; color:var(--portal-text-dim); text-transform:uppercase; letter-spacing:.06em; margin-top:4px}
@media(max-width:560px){
  .sd-cards{grid-template-columns:1fr}
  .sd-metrics{grid-template-columns:1fr 1fr}
  .sd-body{padding:18px}
}

/* ───────── NAV CROMÁTICO ─────────
   O motor de identidade pinta o nav (topbar + rail) com a cor de marca em ALTA saturação
   (--portal-nav-bg). Sobre essa superfície o primeiro plano precisa ser CLARO — o motor entrega
   --portal-nav-text / --portal-nav-icon / --portal-nav-line. Estes overrides (fim do arquivo →
   vencem por ordem de origem) garantem a legibilidade do nav colorido sem tocar no resto do portal.
   Nos fallbacks do tokens.css (nav claro), --portal-nav-text = texto escuro → continua legível. */
.topbar, .rail { color: var(--portal-nav-text); }
.topbar .menu-btn, .rail .rail-close { color: var(--portal-nav-text); }
.topbar .menu-btn:hover, .rail .rail-close:hover { background: color-mix(in srgb, var(--portal-nav-text) 12%, transparent); color: var(--portal-nav-text); }
.topbar .who .meta .nm { color: var(--portal-nav-text); }
.topbar .who .meta .rl, .nav-section-label, .nav-drag { color: color-mix(in srgb, var(--portal-nav-text) 60%, transparent); }
.nav-item { color: color-mix(in srgb, var(--portal-nav-text) 82%, transparent); }
.nav-item svg { color: var(--portal-nav-icon); }
.nav-item:hover { background: color-mix(in srgb, var(--portal-nav-text) 10%, transparent); color: var(--portal-nav-text); }
.nav-item:hover svg { color: var(--portal-nav-text); }
.nav-item.active { background: color-mix(in srgb, var(--portal-nav-text) 16%, transparent); color: var(--portal-nav-text); }
.nav-item.active svg { color: var(--portal-nav-text); }
.nav-item.active::before { background: var(--portal-nav-text); }
.nav-sub { color: color-mix(in srgb, var(--portal-nav-text) 70%, transparent); }
.nav-sub svg { color: var(--portal-nav-icon); }
.nav-sub:hover { background: color-mix(in srgb, var(--portal-nav-text) 8%, transparent); color: var(--portal-nav-text); }
.nav-sub.active { background: color-mix(in srgb, var(--portal-nav-text) 14%, transparent); color: var(--portal-nav-text); }
.nav-sub.active svg { color: var(--portal-nav-text); }
.nav-row.dragging { background: color-mix(in srgb, var(--portal-nav-text) 10%, transparent); }
/* monograma de marca no nav: chip translúcido claro em vez do gradiente de acento (que sumiria) */
.brand-mono { background: color-mix(in srgb, var(--portal-nav-text) 15%, transparent); color: var(--portal-nav-text); border-color: color-mix(in srgb, var(--portal-nav-text) 24%, transparent); text-shadow: none; }
.nav-badge { box-shadow: 0 0 0 2px var(--portal-nav-bg); }

/* ─────────────────────────── PERSONALIDADE ESTRUTURAL ───────────────────────────
   A 3ª dimensão da identidade (além de cor e fonte): RAIO, ESPAÇO, SOMBRA, BORDA, ÍCONE, PESO —
   todos do arquétipo. Dá a SENSAÇÃO: elegant = arredondado, arejado, sombra difusa, SEM borda
   (flutua na sombra), título leve; bold = quase reto, denso, sombra dura/próxima, borda sólida,
   título pesado. No fim do arquivo → vence o hardcoded por ordem de origem. A escala (--r-*) e as
   sombras (--shadow-*) já foram alinhadas no gerador, então as demais views herdam sozinhas; aqui
   ficam os tokens que pedem aplicação explícita (borda, espaço, ícone, peso de display). */

/* superfícies de card/painel: raio, borda e sombra do arquétipo */
.tile, .empty, .greet, .card, .home-card, .pa-cadastro, .cad-ok, .book .cover {
  border-radius: var(--portal-radius-lg);
  border-width: var(--portal-border-width);
  box-shadow: var(--portal-card-shadow);
}
.tile { border-radius: var(--portal-radius); padding: var(--portal-card-pad); }
.card { border-radius: var(--portal-radius); }
.tiles { gap: var(--portal-gap); }
.greet { padding: calc(var(--portal-card-pad) * 1.3) calc(var(--portal-card-pad) * 1.2); }
/* títulos GRANDES (hero) no peso de display + TRACKING do arquétipo — leve+espaçado (elegant),
   pesado+justo (bold). É a micro-decisão que separa "carta escrita à mão" de "presença forte". */
.greet h2, .view-head h1, .empty h3 { font-weight: var(--portal-font-weight-display); letter-spacing: var(--portal-title-tracking); }
/* contêineres de ícone arredondam na escala pequena do arquétipo */
.tile .ic, .empty .badge { border-radius: var(--portal-radius-sm); }
/* ÍCONES de traço: fino (outline) no elegant, grosso (solid) no bold — CSS vence o atributo do SVG */
.nav-item svg, .nav-sub svg, .tile .ic svg, .tile svg, .greet svg,
.home-sec-tit svg, .empty .badge svg, .topbar .menu-btn svg, .rail .rail-close svg {
  stroke-width: var(--portal-icon-stroke);
}

/* ── RESPIRO entre seções: o "ar" que faz o portal da Delli parecer uma carta, não um painel ── */
.home-sec { margin-top: var(--portal-section-gap); }
.home-sec:first-of-type { margin-top: 6px; }
.view + .view, .view-section + .view-section { margin-top: var(--portal-section-gap); }
/* separador de seção: linha fina tênue (arejado) → marcada (denso) */
.home-sec-tit::after { height: var(--portal-sep-height); opacity: var(--portal-sep-opacity); }
/* avatar/imagem: círculo macio (arejado) → squircle (denso), combinando com o raio dos cards */
.topbar .who .avatar { border-radius: var(--portal-avatar-radius); }

/* ── MOTION PERSONALITY: elegância FLUI (400ms suave) · solidez NÃO flui (150ms seco). --portal-dur
   e --ease saem do gerador por presence; o longhand sobrescreve só a duração/easing do transition. ── */
.tile, .card, .btn-primary, .btn-mini, .btn-ghost, .nav-item, .nav-sub, .book .cover,
.ab-toggle, .greet, .tile .ic, .switch .sw-track {
  transition-duration: var(--portal-dur);
  transition-timing-function: var(--ease);
}

/* ── PESO DO MASTHEAD por arquétipo (Fix 2) — o título-marca, os selos, o monograma fantasma e os
   divisores de seção dos documentos seguem --font-weight-masthead (elegant 300 · modern 500 · bold 800)
   em vez do 800 chumbado. No fim → vence o hardcoded. ── */
.dieta-cabeca h3, .ficha-cabeca h3, .dieta::before, .ficha::before,
.ref-num, .dieta .secao-cabeca h4 { font-weight: var(--font-weight-masthead, 800); }

/* ── 3 PAPÉIS TIPOGRÁFICOS (Fix 3) — o documento separa LABEL (técnico) de VOICE (personalidade).
   Cai no --font-mono/--font-serif p/ tenant sem o motor novo (ex.: MR do banco mantém JetBrains/Fraunces). ── */
.dieta .ref-rotulo, .ref-card > header p, .dieta-vigencia, .dieta .obj-badge strong,
.dieta-orientacoes h4, .dieta .opcao-titulo, .dieta .ref-obs-label, .ficha .td-tag,
.ex-dado, .nav-section-label, .home-sec-tit { font-family: var(--font-label, var(--font-mono)); }
.dieta .ref-obs p, .dieta .opcao-nota, .dieta .secao-intro, .sup-quando,
.greet h2 em { font-family: var(--font-voice, var(--font-serif)); }

/* ═══════════════════════ MORFOLOGIA DE COMPONENTES POR ARQUÉTIPO ═══════════════════════
   A FORMA FÍSICA de cada componente muda por arquétipo — não só cor/fonte. O gancho é
   [data-personality="…"] no <html> (ou no wrapper do demo). Keyed por arquétipo: elegant = delicado/
   etéreo/sem caixa · bold = sólido/preenchido/compacto · modern = geométrico/contornado/limpo.
   neutral cai no BASE (o desenho denso original). Aplica nos documentos plano/ficha. */

/* ── 1. SELO NUMERADOR DE REFEIÇÃO (.ref-num) ── */
/* elegant: número solto em itálico (font-voice), 2rem, sem caixa, traço fino embaixo, acento 70% */
[data-personality="elegant"] .ref-num {
  width: auto; min-width: 0; height: auto; padding: 0 1px 3px; align-self: flex-start;
  background: none; box-shadow: none; border-radius: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--portal-accent) 45%, transparent);
  color: color-mix(in srgb, var(--portal-accent) 70%, transparent);
  font-family: var(--font-voice); font-style: italic; font-weight: 400; font-size: 2rem; line-height: 1;
}
/* modern: círculo de borda 1.5px, fundo transparente, número em font-label */
[data-personality="modern"] .ref-num {
  background: none; box-shadow: none; border-radius: 50%;
  border: 1.5px solid color-mix(in srgb, var(--portal-accent) 60%, transparent);
  color: var(--portal-accent); font-family: var(--font-label); font-weight: 600; font-size: 1.04rem;
}
/* bold: selo sólido preenchido, branco, mais reto (base é navy sólido) */
[data-personality="bold"] .ref-num { border-radius: 5px; }

/* ── 2. BADGE DE FASE/OBJETIVO (.obj-badge nos documentos) ── */
/* elegant: texto puro em font-label + tracking, sem caixa, underline de 1px no acento */
[data-personality="elegant"] .dieta .obj-badge, [data-personality="elegant"] .ficha .obj-badge {
  background: none; border: none; border-radius: 0; padding: 2px 0 3px;
  border-bottom: 1px solid color-mix(in srgb, var(--portal-accent) 55%, transparent);
}
[data-personality="elegant"] .obj-badge strong { letter-spacing: 0.1em; color: var(--portal-accent); }
[data-personality="elegant"] .obj-badge span { color: color-mix(in srgb, var(--portal-accent) 65%, var(--doc-ink)); }
/* bold: retângulo sólido preenchido (acento), texto branco, raio 2px */
[data-personality="bold"] .dieta .obj-badge, [data-personality="bold"] .ficha .obj-badge {
  background: var(--portal-accent); border: none; border-radius: 2px; padding: 8px 13px;
}
[data-personality="bold"] .obj-badge strong, [data-personality="bold"] .obj-badge span { color: #fff; }
/* modern: pílula com tinte semi-transparente do acento */
[data-personality="modern"] .dieta .obj-badge, [data-personality="modern"] .ficha .obj-badge {
  background: color-mix(in srgb, var(--portal-accent) 14%, transparent); border: none; border-radius: 999px; padding: 7px 15px;
}
[data-personality="modern"] .obj-badge strong { color: var(--portal-accent); }
[data-personality="modern"] .obj-badge span { color: color-mix(in srgb, var(--portal-accent) 78%, var(--doc-ink)); }

/* ── 3. CARD DE ORIENTAÇÕES (.dieta-orientacoes — o "lingote") ── */
/* elegant: SEM fundo sólido, só borda esquerda 2px de acento, padding generoso */
[data-personality="elegant"] .dieta-orientacoes {
  background: color-mix(in srgb, var(--portal-accent) 4%, var(--doc-paper-2));
  border: none; border-left: 2px solid var(--portal-accent); border-radius: 0;
  box-shadow: none; padding: 16px 22px 16px 24px;
}
[data-personality="elegant"] .dieta-orientacoes h4 { color: var(--portal-accent); }
[data-personality="elegant"] .dieta-orientacoes li { color: var(--doc-ink); font-weight: 400; }
[data-personality="elegant"] .dieta-orientacoes li::before { background: var(--portal-accent); }
/* bold: bloco sólido ESCURO da marca, texto claro, presença forte */
[data-personality="bold"] .dieta-orientacoes {
  background: linear-gradient(165deg, var(--navy-800), var(--navy-900));
  border: 1px solid color-mix(in srgb, var(--portal-accent) 28%, transparent); box-shadow: var(--shadow-soft);
}
[data-personality="bold"] .dieta-orientacoes h4 { color: color-mix(in srgb, var(--portal-accent) 72%, #ffffff); }
[data-personality="bold"] .dieta-orientacoes li { color: #eef2f6; }
[data-personality="bold"] .dieta-orientacoes li::before { background: color-mix(in srgb, var(--portal-accent) 72%, #ffffff); }
/* modern: tinte sutil + borda fina, raio do tema (glass-ish em papel) */
[data-personality="modern"] .dieta-orientacoes {
  background: color-mix(in srgb, var(--portal-accent) 7%, var(--doc-paper));
  border: 1px solid color-mix(in srgb, var(--portal-accent) 22%, transparent); border-radius: 14px; box-shadow: none;
}
[data-personality="modern"] .dieta-orientacoes h4 { color: var(--portal-accent); }
[data-personality="modern"] .dieta-orientacoes li { color: var(--doc-ink); }
[data-personality="modern"] .dieta-orientacoes li::before { background: var(--portal-accent); }

/* ── 4. SEPARADOR ENTRE SEÇÕES (.dieta .secao-cabeca) + espaço entre módulos ── */
[data-personality="elegant"] .dieta .dieta-secao { margin-top: 60px; }
[data-personality="elegant"] .dieta .secao-cabeca { border-bottom: 1px solid color-mix(in srgb, var(--portal-accent) 30%, transparent); }
[data-personality="elegant"] .dieta-refeicoes { gap: 26px; }
[data-personality="bold"] .dieta .dieta-secao { margin-top: 24px; }
[data-personality="bold"] .dieta .secao-cabeca { border-bottom: none; padding-bottom: 4px; }
[data-personality="bold"] .dieta-refeicoes { gap: 11px; }
[data-personality="modern"] .dieta .dieta-secao { margin-top: 40px; }
[data-personality="modern"] .dieta .secao-cabeca { border-bottom: none; padding-bottom: 8px; }
[data-personality="modern"] .dieta-refeicoes { gap: 17px; }

/* ── 5. MONOGRAMA FANTASMA no canto (.dieta::before / .ficha::before) ── */
[data-personality="elegant"] .dieta::before, [data-personality="elegant"] .ficha::before {
  font-size: 8rem; color: color-mix(in srgb, var(--gold-ink) 4%, transparent); top: 10px; right: 18px;
}
[data-personality="bold"] .dieta::before, [data-personality="bold"] .ficha::before {
  font-size: 6rem; color: color-mix(in srgb, var(--gold-ink) 9%, transparent);
}
[data-personality="modern"] .dieta::before, [data-personality="modern"] .ficha::before { content: none; }

/* ── morfologia do MÓDULO de refeição: raio + faixa do cabeçalho por arquétipo ── */
[data-personality="elegant"] .ref-card { border-radius: 16px; }
[data-personality="elegant"] .ref-card > header { background: none; border-bottom: 1px solid color-mix(in srgb, var(--portal-accent) 14%, transparent); padding: 15px 20px 9px; }
[data-personality="bold"] .ref-card { border-radius: 5px; }
[data-personality="modern"] .ref-card { border-radius: 12px; }
[data-personality="modern"] .ref-card > header { background: color-mix(in srgb, var(--portal-accent) 5%, transparent); }

/* ─────────────────────────────────────────────────────────────────────────────
   SEPARADOR DE SEÇÃO ORGÂNICO (.sec-sep)
   Elemento vazio entre seções — o tipo é controlado via [data-portal-sep]
   no <html>: wave (onda SVG em card-bg), space (vazio 80px), line (1px accent),
   none (ausente). A onda SVG é gerada dinamicamente em JS com a cor resolvida.
   ───────────────────────────────────────────────────────────────────────────── */
.sec-sep {
  display: block; overflow: hidden; line-height: 0; flex: none;
  transition: height var(--portal-dur, .22s) ease;
}
[data-portal-sep="wave"] .sec-sep {
  height: 40px;
  background-color: var(--portal-bg);
  background-image: var(--portal-sep-wave, none);
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
[data-portal-sep="space"] .sec-sep { height: 80px; background: none; }
[data-portal-sep="line"] .sec-sep {
  height: 1px;
  background: var(--portal-accent);
  opacity: .2;
  margin: 28px 0;
}
[data-portal-sep="none"] .sec-sep { display: none; }

/* ─────────────────────────────────────────────────────────────────────────────
   TEXTURA DE FUNDO: grain (elegant/welcoming) · radial (premium) · flat (demais)
   Os tokens --portal-bg-texture-* são injetados pelo brand-theme-generator e
   consumidos aqui por qualquer elemento de fundo do conteúdo principal.
   ───────────────────────────────────────────────────────────────────────────── */
.content-inner {
  background-image: var(--portal-bg-texture-img, none);
  background-size: var(--portal-bg-texture-size, auto);
  background-repeat: var(--portal-bg-texture-repeat, repeat);
}

/* ─────────────────────────────────────────────────────────────────────────────
   BRAND ASSETS LAYER — Camada 4
   Watermark via ::after no .content-inner; nav deco e sep icon via DOM (JS).
   Vars injetadas pelo brand-theme-generator quando branding.brand_icon_svg existe.
   ───────────────────────────────────────────────────────────────────────────── */
.content-inner { position: relative; isolation: isolate; }
.content-inner::after {
  content: '';
  position: fixed;            /* fixa na viewport: acompanha o scroll, sempre centralizada na tela */
  inset: 0;
  background-image: var(--portal-brand-wm, none);
  background-size: var(--portal-brand-wm-cover, 72%) auto;  /* marca-d'água GRANDE, centralizada (aspect-ratio preservado = contain) */
  background-repeat: no-repeat;
  background-position: center;
  opacity: var(--portal-brand-wm-opacity, 0);
  /* logo ORIGINAL do tenant: grayscale (só a forma) + blend (multiply claro / screen escuro) → o fundo
     sólido da logo some, sem retângulo. Símbolo/SVG ficam em none/normal (não muda o showcase). */
  filter: var(--portal-brand-wm-filter, none);
  mix-blend-mode: var(--portal-brand-wm-blend, normal);
  pointer-events: none;       /* fantasma — nunca bloqueia clique/scroll do conteúdo */
  z-index: 2;                 /* por cima do conteúdo (a 2-3% não atrapalha a leitura) */
}
/* a marca-d'água vive SÓ na área central, nunca sobre a barra de menu: em desktop a rail é fixa
   (recua a partir dela); em mobile, recua quando o menu abre — encolhe pra parte central */
@media (min-width: 900px) { .content-inner::after { left: var(--rail); } }
.shell:has(.rail.open) .content-inner::after { left: var(--rail); }
.nav-deco {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 6px 16px;
  color: var(--portal-nav-text);
  opacity: .15;
  pointer-events: none;
}
.nav-deco svg { width: 36px; height: 36px; }
.brand-sep-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: -2px 0 10px;
  color: var(--portal-accent);
  pointer-events: none;
}
.brand-sep-icon svg { width: 28px; height: 28px; opacity: .20; }
[data-portal-sep="none"] .brand-sep-icon { display: none !important; }
/* Logo original (<img> direto) ou embutida (<image> em SVG): preserva a proporção (símbolo é quadrado,
   logo não) e fica a ~80% do padrão — a logo inteira é mais densa que um símbolo isolado. */
.nav-deco.brand-asset-img svg,
.nav-deco.brand-asset-img img { width: auto; height: 29px; max-width: 86%; object-fit: contain; display: block; }
.brand-sep-icon.brand-asset-img svg,
.brand-sep-icon.brand-asset-img img { width: auto; height: 22px; max-width: 70%; object-fit: contain; display: block; }

/* ═══════════════ MORFOLOGIA NO DASHBOARD HOME (tiles + hero) por arquétipo ═══════════════
   A FORMA dos documentos levada à HOME, p/ a identidade saltar já no Início — não só nos
   plano/ficha. O radius já vem do token por presence; aqui entra a borda-de-acento DIRECIONAL
   (filete lateral · barra superior · bloco) + sombra + hover. A borda de acento é o que se lê
   nos DOIS modos (claro e escuro), onde a sombra sozinha sumiria. Só toca .tile/.greet —
   exclusivos do Início → zero efeito nos documentos (plano/ficha/análises). */

/* Prefixo html[…] (não só [data-personality]) p/ a especificidade vencer a camada estrutural
   `.tile { border-width: var(--portal-border-width) }`. O diferenciador é a BORDA DE ACENTO
   direcional (lê-se nos dois modos): filete à esquerda · moldura cheia · barra no topo. */

/* ELEGANT — filete lateral, sem caixa pesada; o hover desliza de leve */
html[data-personality="elegant"] .tile,
html[data-personality="elegant"] .greet {
  box-shadow: none;
  border-color: color-mix(in srgb, var(--portal-accent) 13%, transparent);
  border-left: 3px solid var(--portal-accent);
}
html[data-personality="elegant"] .tile:hover {
  transform: translateY(-2px);
  border-left-color: var(--portal-accent);
  box-shadow: 0 8px 22px color-mix(in srgb, var(--portal-accent) 12%, transparent);
}

/* BOLD — bloco emoldurado: moldura de acento cheia (sem filete direcional), sombra dura, cantos
   justos (radius do token); o hover crava. A cor forte da moldura carrega no claro e no escuro. */
html[data-personality="bold"] .tile,
html[data-personality="bold"] .greet {
  border-color: color-mix(in srgb, var(--portal-accent) 55%, transparent);
  box-shadow: 0 8px 18px color-mix(in srgb, #000 22%, transparent);
}
html[data-personality="bold"] .tile:hover {
  transform: translateY(-2px);
  border-color: var(--portal-accent);
  box-shadow: 0 13px 26px color-mix(in srgb, #000 32%, transparent);
}

/* MODERN — barra superior geométrica de acento, sombra difusa, contorno limpo */
html[data-personality="modern"] .tile,
html[data-personality="modern"] .greet {
  border-color: var(--portal-line);
  border-top: 3px solid var(--portal-accent);
  box-shadow: 0 10px 30px color-mix(in srgb, #000 10%, transparent);
}
html[data-personality="modern"] .tile:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 38px color-mix(in srgb, #000 14%, transparent);
}

/* ═══════════════ MORFOLOGIA — FICHA DE TREINO + ANÁLISES (Task 4b) ═══════════════
   A intenção do plano alimentar levada às outras duas abas-documento. Mesmo padrão
   [data-personality]: elegant = delicado/filete · bold = sólido/preenchido · modern = geométrico.
   Escopo .ficha p/ o treino; .ev-* p/ as análises. Não toca .ref-* (plano) nem .tile (home). */

/* ── Ficha de treino: .ex-num (número do exercício) ── */
[data-personality="elegant"] .ficha .ex-num {
  font-style: italic; font-weight: 400; color: var(--portal-accent);
  border-left: 2px solid var(--portal-accent); padding-left: 8px;
}
[data-personality="bold"] .ficha .ex-num {
  display: inline-block; background: var(--portal-accent); color: var(--portal-on-accent);
  font-weight: 800; border-radius: 5px; padding: 2px 7px; text-align: center;
}
[data-personality="modern"] .ficha .ex-num {
  display: inline-block; color: var(--portal-accent); background: transparent; text-align: center;
  border: 1px solid color-mix(in srgb, var(--portal-accent) 50%, transparent); border-radius: 3px; padding: 2px 6px;
}

/* ── Ficha de treino: .td-tag (tag do dia/grupo) ── */
[data-personality="elegant"] .ficha .td-tag {
  background: none; box-shadow: none; color: var(--portal-accent);
  border: 1px solid color-mix(in srgb, var(--portal-accent) 45%, transparent); border-radius: 999px;
}
[data-personality="bold"] .ficha .td-tag {
  background: var(--portal-accent); color: var(--portal-on-accent); border: none; box-shadow: none; border-radius: 999px;
}
[data-personality="modern"] .ficha .td-tag {
  background: color-mix(in srgb, var(--portal-accent) 9%, transparent); box-shadow: none; color: var(--portal-accent);
  border: none; border-left: 3px solid var(--portal-accent); border-radius: 3px;
}

/* ── Ficha de treino: .ex-dado (chip séries/carga/descanso) ── */
[data-personality="elegant"] .ficha .ex-dado {
  font-weight: 400; border-radius: 999px; letter-spacing: 0.04em;
  color: var(--portal-accent); border-color: color-mix(in srgb, var(--portal-accent) 28%, transparent);
}
[data-personality="elegant"] .ficha .ex-dado.forte {
  background: none; color: var(--portal-accent); border: 1px solid var(--portal-accent); box-shadow: none;
}
[data-personality="bold"] .ficha .ex-dado { font-weight: 700; border-radius: 5px; }
[data-personality="bold"] .ficha .ex-dado.forte {
  background: var(--portal-accent); color: var(--portal-on-accent); border-color: transparent;
}
[data-personality="modern"] .ficha .ex-dado {
  border-radius: 2px; border-color: color-mix(in srgb, var(--portal-accent) 38%, transparent);
}
[data-personality="modern"] .ficha .ex-dado.forte {
  background: none; color: var(--portal-accent); box-shadow: none;
  border: 1px solid color-mix(in srgb, var(--portal-accent) 38%, transparent);
  border-left: 3px solid var(--portal-accent); border-radius: 2px;
}

/* ── Análises: .ev-card (card de métrica) ── */
[data-personality="elegant"] .ev-card {
  box-shadow: none; border-radius: 20px; border-color: color-mix(in srgb, var(--portal-accent) 16%, transparent);
}
[data-personality="bold"] .ev-card {
  border-radius: 8px; box-shadow: 0 8px 18px color-mix(in srgb, #000 22%, transparent);
}
[data-personality="modern"] .ev-card {
  border-radius: 12px; border-top: 3px solid var(--portal-accent); box-shadow: 0 10px 28px color-mix(in srgb, #000 9%, transparent);
}

/* ── Análises: .ev-card-num (o número da métrica) ── */
[data-personality="elegant"] .ev-card-num { font-weight: 300; font-size: 2rem; }
[data-personality="bold"] .ev-card-num { font-weight: 800; letter-spacing: -0.01em; }
[data-personality="modern"] .ev-card-num { font-weight: 600; font-size: 1.55rem; font-variant-numeric: tabular-nums; }

/* ── Análises: .ev-graf (gráfico de evolução — equivalente da "barra"; a moldura segue o arquétipo
      e a ESPESSURA DA LINHA varia: fina elegant · grossa bold · média modern) ── */
[data-personality="elegant"] .ev-graf {
  box-shadow: none; border-radius: 20px; border-color: color-mix(in srgb, var(--portal-accent) 16%, transparent);
}
[data-personality="elegant"] .ev-graf polyline { stroke-width: 1.5; }
[data-personality="bold"] .ev-graf {
  border-radius: 8px; box-shadow: 0 8px 18px color-mix(in srgb, #000 22%, transparent);
}
[data-personality="bold"] .ev-graf polyline { stroke-width: 3.6; }
[data-personality="modern"] .ev-graf { border-radius: 12px; border-top: 3px solid var(--portal-accent); }
[data-personality="modern"] .ev-graf polyline { stroke-width: 2.2; }
