/* ===== Bebê Saudável — Área de Membros • Núbia Costa Nutri ===== */
@font-face{
  font-family:'Patricia Gothic Heavy';
  src:url('../fonts/PatriciaGothic-Heavy.ttf') format('truetype');
  font-weight:normal;font-style:normal;font-display:swap;
}
:root{
  color-scheme:light;
  --magenta:#E91E63; --magenta-deep:#C2185B;
  --indigo:#1A237E; --indigo-soft:#3949AB;
  --orange:#FF6F00; --orange-soft:#FFB74D;
  --cream:#FFF8F1; --ink:#1A1A2E; --gray:#5A5A6B; --gray-soft:#EEEAEC;
  --green:#2E7D32; --green-soft:#E8F5E9;
  /* superfícies (trocam no dark) */
  --surface:#ffffff; --surface-2:#FFF6FA;
  --topbar-bg:rgba(255,255,255,.92); --auth-glow:#FFE3EE;
  --r:18px; --max:1080px;
  --shadow:0 12px 40px rgba(26,35,126,.12);
  --shadow-soft:0 4px 16px rgba(26,35,126,.07);
}
[data-theme="dark"]{
  color-scheme:dark;
  --magenta:#FF5C8A; --magenta-deep:#FF85AB;
  --indigo:#AAB4FF; --indigo-soft:#8E9BFF;
  --orange:#FFB74D; --orange-soft:#7a5a2a;
  --cream:#14121b; --ink:#ECEAF2; --gray:#A8A5B8; --gray-soft:#2B2838;
  --green:#74D88A; --green-soft:#16301c;
  --surface:#1E1B29; --surface-2:#241f31;
  --topbar-bg:rgba(20,18,27,.9); --auth-glow:rgba(233,30,99,.16);
  --shadow:0 14px 40px rgba(0,0,0,.55);
  --shadow-soft:0 4px 16px rgba(0,0,0,.45);
}

/* ---- Toggle de tema (claro/escuro) ---- */
.tema-toggle{display:inline-grid;place-items:center;width:38px;height:38px;flex-shrink:0;
  border-radius:10px;border:1.5px solid var(--gray-soft);background:var(--surface);
  color:var(--ink);cursor:pointer;transition:.18s border-color,.18s color}
.tema-toggle:hover{border-color:var(--magenta);color:var(--magenta)}
.tema-toggle .ico{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tema-toggle .ico-sun{display:none}
[data-theme="dark"] .tema-toggle .ico-sun{display:block}
[data-theme="dark"] .tema-toggle .ico-moon{display:none}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--cream);line-height:1.55;font-size:16px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.serif{font-family:'Patricia Gothic Heavy',Georgia,serif}
.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}

/* ---- Top bar ---- */
.topbar{
  position:sticky;top:0;z-index:50;background:var(--topbar-bg);
  backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--gray-soft);
}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:64px;gap:16px}
/* LOGO — lockup horizontal: ícone | nome | profissão+CRN (2 linhas) */
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.brand-icon{width:52px;height:auto;display:block;flex-shrink:0}
.brand-name{height:29px;width:auto;display:block;flex-shrink:0}
.brand-role{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:2px;
  padding-left:12px;border-left:1.5px solid rgba(138,109,46,.32);
  font-family:'Inter',sans-serif;color:#8A6D2E;line-height:1.1;text-transform:uppercase;white-space:nowrap}
.brand-role span:first-child{font-size:11px;font-weight:700;letter-spacing:.03em}
.brand-role span:last-child{font-size:9.5px;font-weight:600;letter-spacing:.08em;opacity:.85}
[data-theme="dark"] .brand-role{color:#D9C49A;border-left-color:rgba(217,196,154,.32)}
/* lockup vertical (tela de login) — sem divisor, centralizado */
.auth .brand-role{border-left:0;padding-left:0;align-items:center;text-align:center}
/* CTA do tira-dúvidas — segue o tema (corrige texto invisível no dark) */
.card.faq-cta{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--gray-soft)}
.nav{display:flex;gap:6px;align-items:center}
.nav a{padding:8px 13px;border-radius:10px;font-weight:600;color:var(--gray);font-size:14px;white-space:nowrap}
.nav a.ativo,.nav a:hover{background:var(--gray-soft);color:var(--ink)}
.nav .sair{color:var(--magenta-deep)}
/* Botão hamburger (só aparece em tablet/celular) */
.nav-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;
  background:none;border:0;border-radius:12px;cursor:pointer;color:var(--ink);flex-shrink:0}
.nav-toggle:hover{background:var(--gray-soft)}
.nav-toggle .ico{width:26px;height:26px;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-toggle .ico-x{display:none}
.topbar.nav-open .nav-toggle .ico-bars{display:none}
.topbar.nav-open .nav-toggle .ico-x{display:block}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;
  border:none;cursor:pointer;font:inherit;font-weight:700;border-radius:12px;
  padding:13px 22px;transition:.18s transform,.18s box-shadow,.18s background}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(135deg,#D81B60,var(--magenta-deep));color:#fff;box-shadow:0 8px 22px rgba(233,30,99,.32)}
.btn-primary:hover{box-shadow:0 12px 30px rgba(233,30,99,.42)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1.5px solid var(--gray-soft)}
.btn-ghost:hover{border-color:var(--magenta);color:var(--magenta-deep)}
.btn-block{width:100%}

/* ---- Cards ---- */
.card{background:var(--surface);border-radius:var(--r);box-shadow:var(--shadow-soft);padding:22px}
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}

/* ---- Hero / welcome ---- */
.hero{padding:40px 0 8px}
.hero h1{font-size:clamp(26px,4vw,40px);line-height:1.1;font-weight:900;color:var(--indigo)}
.hero p{color:var(--gray);margin-top:8px;max-width:640px}
.badge{display:inline-block;background:var(--green-soft);color:var(--green);font-weight:700;
  font-size:12px;padding:5px 12px;border-radius:999px}

/* ---- Material (download) cards ---- */
.material{display:flex;flex-direction:column;gap:12px;border:1.5px solid var(--gray-soft);transition:.18s}
.material:hover{border-color:var(--magenta);transform:translateY(-3px);box-shadow:var(--shadow)}
.material .ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,#FFE0EC,#FFF3E0);font-size:22px}
.material h3{font-size:17px}
.material small{color:var(--gray)}
.material.destaque{border-color:var(--magenta);background:linear-gradient(180deg,var(--surface),var(--surface-2))}
.tag{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  padding:3px 9px;border-radius:999px;background:var(--gray-soft);color:var(--gray)}
.tag.ebook{background:#EDE7F6;color:#4527A0}
.tag.planilha{background:#E3F2FD;color:#1565C0}
.tag.receita{background:#FFF3E0;color:#A8400A}
.tag.bonus{background:var(--green-soft);color:var(--green)}

/* ---- Progress ---- */
.progress{height:12px;border-radius:999px;background:var(--gray-soft);overflow:hidden}
.progress > i{display:block;height:100%;border-radius:999px;
  background:linear-gradient(90deg,var(--magenta),var(--orange));transition:width .5s}

/* ---- Jornada ---- */
.fase{position:relative}
.fase-head{display:flex;align-items:center;gap:14px;cursor:pointer}
.fase-emoji{font-size:30px}
.fase .missao{display:flex;align-items:flex-start;gap:11px;padding:11px 0;border-top:1px solid var(--gray-soft)}
.fase .missao input{width:21px;height:21px;accent-color:var(--magenta);margin-top:2px;cursor:pointer}
.fase .missao label{cursor:pointer;flex:1;display:flex;flex-direction:column;gap:5px}
.fase .missao .missao-texto{font-weight:600}
.fase .missao.feita .missao-texto{color:var(--gray);text-decoration:line-through}
.fase .missao .licao{font-size:13px;color:var(--gray);line-height:1.5;
  background:var(--cream);border-left:3px solid var(--orange-soft);
  padding:7px 11px;border-radius:8px}
.fase .missao.feita .licao{opacity:.7}
/* selo de fase + certificado */
.fase.completa{box-shadow:0 0 0 2px var(--green), var(--shadow-soft)}
.fase-selo{display:flex;gap:12px;align-items:center;background:var(--green-soft);
  border:1px solid #BFE3C7;border-radius:14px;padding:12px 14px;margin-top:8px}
.fase-selo .selo-emoji{font-size:30px;line-height:1}
.fase-selo strong{color:var(--green)}
.certificado{text-align:center;background:linear-gradient(160deg,var(--surface),var(--surface-2));
  border:2px solid var(--magenta);padding:36px 24px}
.certificado .cert-medal{font-size:56px;line-height:1}
.certificado h2{color:var(--indigo);margin:8px 0 10px}
.certificado p{max-width:540px;margin:0 auto 8px}
.quizbox{margin-top:14px;background:var(--cream);border-radius:14px;padding:16px}
.quizbox .op{display:block;width:100%;text-align:left;border:1.5px solid var(--gray-soft);background:var(--surface);color:var(--ink);
  border-radius:11px;padding:11px 14px;margin-top:8px;cursor:pointer;font:inherit;transition:.15s}
.quizbox .op:hover{border-color:var(--magenta)}
.quizbox .op.certa{border-color:var(--green);background:#E8F5E9;color:#1B5E20}
.quizbox .op.errada{border-color:#E53935;background:#FFEBEE;color:#B71C1C}
.selo{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--green)}

/* ---- FAQ ---- */
.faq-busca{display:flex;gap:10px;margin:18px 0}
.faq-busca input{flex:1;border:1.5px solid var(--gray-soft);border-radius:12px;padding:14px 16px;font:inherit;background:var(--surface);color:var(--ink)}
.faq-busca input:focus{outline:none;border-color:var(--magenta)}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{border:1.5px solid var(--gray-soft);background:var(--surface);border-radius:999px;padding:7px 14px;
  font-size:13px;font-weight:600;color:var(--gray);cursor:pointer}
.chip.on{background:var(--magenta);border-color:var(--magenta);color:#fff}
.qa{border:1.5px solid var(--gray-soft);border-radius:14px;margin-bottom:10px;overflow:hidden;background:var(--surface)}
.qa summary{list-style:none;cursor:pointer;padding:16px 18px;font-weight:700;display:flex;justify-content:space-between;gap:12px;align-items:center}
.qa summary::-webkit-details-marker{display:none}
.qa summary .cat{font-size:11px;font-weight:700;color:var(--magenta-deep)}
.qa[open] summary{border-bottom:1px solid var(--gray-soft)}
.qa .ans{padding:14px 18px 18px;color:var(--gray)}
.qa .seta{transition:.2s}
.qa[open] .seta{transform:rotate(180deg)}

/* ---- Forms / login ---- */
.auth{min-height:100dvh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1200px 500px at 50% -10%,var(--auth-glow),transparent),var(--cream)}
.auth .card{width:100%;max-width:430px;padding:30px}
.field{margin-top:14px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.field input{width:100%;border:1.5px solid var(--gray-soft);border-radius:12px;padding:14px 16px;font:inherit;letter-spacing:.04em;background:var(--surface);color:var(--ink)}
.field input:focus{outline:none;border-color:var(--magenta)}
.alert{border-radius:12px;padding:13px 16px;font-size:14px;margin-top:14px}
.alert.erro{background:#FFEBEE;color:#B71C1C}
.alert.sucesso{background:var(--green-soft);color:var(--green)}
.muted{color:var(--gray);font-size:13px}
.demo-btns{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.demo-btns button{font-size:12px;padding:8px 12px;border-radius:10px;border:1.5px dashed var(--magenta);
  background:var(--surface);color:var(--magenta-deep);cursor:pointer;font-weight:600}

/* ---- Footer ---- */
.foot{padding:34px 0;text-align:center;color:var(--gray);font-size:13px}

/* ---- Leitor do e-book (segue o tema da plataforma) ---- */
.reader-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.reader-bar h1{font-family:'Patricia Gothic Heavy',Georgia,serif;font-size:22px;color:var(--indigo);margin:0}
.reader-pg{font-weight:700;color:var(--gray);font-size:14px}
.reader-stage{position:relative;background:var(--surface-2);border:1px solid var(--gray-soft);
  border-radius:18px;padding:18px;display:flex;align-items:center;justify-content:center;
  min-height:52vh;overflow:hidden;-webkit-user-select:none;user-select:none}
.reader-page{position:relative;max-width:100%;line-height:0}
.reader-page img{max-width:100%;max-height:calc(100dvh - 300px);min-height:320px;display:block;
  border-radius:8px;box-shadow:var(--shadow);pointer-events:none;-webkit-user-drag:none}
.reader-wm{position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:8px}
.reader-wm span{position:absolute;color:rgba(233,30,99,.10);font-weight:700;font-size:13px;
  white-space:nowrap;transform:rotate(-30deg)}
.reader-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:18px}
.reader-nav button{width:46px;height:46px;border-radius:50%;background:var(--magenta);color:#fff;
  font-size:22px;border:0;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-soft)}
.reader-nav button:disabled{opacity:.35;cursor:default;box-shadow:none}
.reader-nav .slider{flex:1;max-width:360px}
.reader-nav input[type=range]{width:100%;accent-color:var(--magenta)}
.reader-hint{text-align:center;font-size:12px;color:var(--gray);margin-top:12px}

/* ---- Tables (admin) ---- */
table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th,table.tbl td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--gray-soft)}
table.tbl th{color:var(--gray);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
code.codigo{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--gray-soft);
  padding:4px 8px;border-radius:7px;font-weight:700;letter-spacing:.06em}

/* ---- Responsivo ---- */
/* Menu hamburger em tablet e celular */
@media (max-width:1024px){
  .topbar .wrap{gap:10px}
  .brand{flex-shrink:0;margin-right:auto}
  .nav-toggle{display:inline-flex}
  /* nav vira painel suspenso abaixo da barra */
  .nav{position:absolute;top:100%;left:0;right:0;z-index:49;
    flex-direction:column;align-items:stretch;gap:4px;
    background:var(--surface,#fff);border-bottom:1px solid var(--gray-soft);
    box-shadow:0 16px 32px rgba(0,0,0,.10);
    padding:8px 16px 16px;margin:0;
    max-height:calc(100vh - 64px);overflow-y:auto;
    opacity:0;transform:translateY(-8px);pointer-events:none;
    transition:opacity .18s ease,transform .18s ease}
  .topbar.nav-open .nav{opacity:1;transform:none;pointer-events:auto}
  .nav a{padding:13px 12px;font-size:15px;border-radius:11px;width:100%}
  .nav a.ativo,.nav a:hover{background:var(--gray-soft)}
  .nav .sair{margin-top:2px}
  .nav .tema-toggle{align-self:flex-start;margin-top:8px}
  .nav .label-full{display:inline}
}
@media (max-width:760px){
  .cols-2,.cols-3{grid-template-columns:1fr}
}
/* Telas estreitas: logo compacto no topo (CRN permanece no rodapé) */
@media (max-width:600px){
  .topbar .brand-role{display:none}
  .topbar .brand-icon{width:40px}
  .topbar .brand-name{height:23px}
}

/* ===== Desktop + tablet (≥768px): logo no TOPO centralizado e menu numa barra INFERIOR centralizada ===== */
/* (no celular < 768px mantém o hambúrguer/dropdown que já existe) */
@media (min-width:768px){
  /* IMPORTANTE: o backdrop-filter do topbar criava um "containing block" que prendia
     o menu fixo dentro do topbar (jogando-o pro topo, sobre a logo). Removê-lo faz o
     menu fixo ancorar no rodapé da TELA, como deve. */
  .topbar{backdrop-filter:none;-webkit-backdrop-filter:none}
  .topbar .wrap{justify-content:center}
  .nav-toggle{display:none !important}
  .nav{position:fixed;left:0;right:0;bottom:0;top:auto;z-index:50;
    display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;
    background:var(--topbar-bg);-webkit-backdrop-filter:saturate(160%) blur(12px);backdrop-filter:saturate(160%) blur(12px);
    border-top:1px solid var(--gray-soft);border-bottom:0;
    padding:9px 16px calc(9px + env(safe-area-inset-bottom));
    opacity:1;transform:none;pointer-events:auto;box-shadow:0 -6px 24px rgba(40,20,60,.08)}
  .nav a{width:auto;padding:9px 14px;font-size:14px}
  .nav a.ativo,.nav a:hover{background:var(--gray-soft)}
  .nav .sair{margin-top:0}
  .nav .tema-toggle{align-self:center;margin:0 0 0 4px}
  body{padding-bottom:74px}
}
