/* ============================================================
   PSICOLOGIA PRETA — DESIGN SYSTEM · components.css
   ------------------------------------------------------------
   @layer components — os componentes COMUNS aos 4 tipos de página:
   nav, marca, toggle sol/lua, drawer mobile + scrim, botões
   (ember/line), hambúrguer, footer, cookie/LGPD, barra de progresso,
   scroll-cue, e os primitivos de formulário/seleção compartilhados
   (search input, chips, grade de UF, hairlines).

   Nenhuma cor hard-coded: tudo via tokens.css. Componentes
   ESPECÍFICOS de uma página (folha de leitura, rail de cadernos,
   formulário de cadastro de 4 etapas, finder/cards) vivem inline
   na sua própria @layer page no template correspondente.
   ============================================================ */

@layer components {
  /* ---------------- NAV + MARCA ---------------- */
  .nav{position:fixed;top:0;left:0;right:0;z-index:200;
    background:var(--glass-nav);
    backdrop-filter:saturate(1.3) blur(16px);-webkit-backdrop-filter:saturate(1.3) blur(16px);
    border-bottom:1px solid var(--hair-dim);transition:background-color .9s linear,border-color .6s linear;}
  .nav-in{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);
    padding:var(--sp-3) var(--pad);max-width:var(--wrap);margin:0 auto;}
  .brand{display:flex;align-items:center;gap:var(--sp-3);min-width:0;}
  /* a marca: um ponto de luz dentro de um círculo aberto — alguém presente num quarto */
  .brand .mk{width:30px;height:30px;flex-shrink:0;position:relative;display:grid;place-items:center;}
  .brand .mk i{position:absolute;inset:0;border-radius:50%;border:1.4px solid var(--ink-dim);}
  .brand .mk i:last-child{inset:auto;width:9px;height:9px;border:none;border-radius:50%;
    background:var(--honey);box-shadow:0 0 12px 2px var(--honey-glow);animation:emberPulse 3.4s var(--ease) infinite;}
  .brand .wm{font-family:var(--f-sans);font-weight:700;font-size:1.16rem;letter-spacing:-.02em;line-height:1;
    font-stretch:85%;white-space:nowrap;}
  .brand .wm em{font-style:normal;font-weight:400;color:var(--honey);}
  .nav-links{display:none;}
  .nav-cta{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0;}
  /* link "voltar" usado pela shell do app (sem drawer) */
  .nav-back{font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.1em;text-transform:uppercase;
    color:var(--ink-soft);white-space:nowrap;transition:color var(--dur-fast);}
  .nav-back:hover{color:var(--honey);}

  /* ---- TOGGLE SOL/LUA (canônico, idêntico aos sites da família) ----
     track-pílula com thumb mel que desliza; sol no day (thumb à esquerda),
     lua no night (thumb à direita). aria-pressed = NIGHT ativo. Alvo >=44px,
     foco-visível mel herdado da casa. É um <button> nativo (Enter/Espaço). */
  .theme-toggle{position:relative;width:60px;height:32px;min-height:44px;min-width:44px;
    display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:6px;
    border-radius:100px;}
  .tt-track{position:relative;width:60px;height:32px;border-radius:100px;
    background:var(--bg-lift);border:1px solid var(--hair);
    transition:background-color var(--dur-fast),border-color var(--dur-fast);}
  .tt-thumb{position:absolute;top:50%;left:4px;width:24px;height:24px;border-radius:50%;
    transform:translateY(-50%);display:grid;place-items:center;
    background:var(--honey);box-shadow:0 0 12px 1px var(--honey-glow);
    transition:left var(--dur) var(--ease-soft),background-color var(--dur-fast);}
  [data-theme="night"] .tt-thumb{left:32px;}
  .tt-thumb svg{width:14px;height:14px;display:block;color:var(--honey-ink);}
  .tt-sun{display:none;} .tt-moon{display:block;}
  [data-theme="day"] .tt-sun{display:block;} [data-theme="day"] .tt-moon{display:none;}
  .theme-toggle:hover .tt-track{border-color:var(--honey);}
  .theme-toggle:hover .tt-thumb{background:var(--honey-lift);}

  /* ---- BOTÕES ---- */
  .btn-ember{font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.1em;text-transform:uppercase;
    background:var(--honey);color:var(--honey-ink);padding:12px 16px;min-height:44px;font-weight:600;border-radius:100px;
    display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
    transition:transform var(--dur-fast) var(--ease-soft),box-shadow var(--dur-fast) var(--ease),background-color var(--dur-fast);}
  .btn-ember:hover{transform:translateY(-2px);box-shadow:0 12px 30px -10px var(--honey-glow);background:var(--honey-lift);}
  .btn-ember.lg{padding:16px 24px;min-height:54px;font-size:var(--fs-xs);}
  .btn-line{font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.1em;text-transform:uppercase;
    color:var(--ink-soft);padding:12px 14px;min-height:44px;border:1px solid var(--hair);border-radius:100px;white-space:nowrap;
    transition:color var(--dur-fast),border-color var(--dur-fast);}
  .btn-line:hover{color:var(--honey);border-color:var(--honey);}
  .btn-line.hide-sm{display:none;}
  @media(min-width:520px){.btn-line.hide-sm{display:inline-flex;}}

  /* ---- HAMBÚRGUER (vira X quando aberto) ---- */
  .hamb{display:inline-flex;flex-direction:column;gap:5px;padding:10px;min-height:44px;min-width:44px;
    align-items:center;justify-content:center;}
  .hamb span{width:22px;height:1.8px;background:var(--ink);border-radius:2px;
    transition:transform var(--dur-fast) var(--ease),opacity var(--dur-fast);}
  .hamb[aria-expanded="true"] span:nth-child(1){transform:translateY(6.8px) rotate(45deg);}
  .hamb[aria-expanded="true"] span:nth-child(2){opacity:0;}
  .hamb[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.8px) rotate(-45deg);}

  @media(min-width:940px){
    .nav-links{display:flex;gap:var(--sp-6);align-items:center;}
    .nav-links a{font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.14em;text-transform:uppercase;
      color:var(--ink-soft);transition:color var(--dur-fast);position:relative;padding:4px 0;}
    .nav-links a::after{content:'';position:absolute;left:0;right:100%;bottom:-3px;height:1px;background:var(--honey);
      transition:right var(--dur-fast) var(--ease);}
    .nav-links a:hover,.nav-links a.active{color:var(--ink);}
    .nav-links a:hover::after,.nav-links a.active::after{right:0;}
    .hamb{display:none;}
  }

  /* ---- DRAWER MOBILE + SCRIM ---- */
  #drawer{position:fixed;inset:0 0 0 auto;width:min(88vw,360px);background:var(--bg-2);
    border-left:1px solid var(--hair);z-index:300;transform:translateX(100%);
    transition:transform var(--dur) var(--ease-soft);display:flex;flex-direction:column;
    padding:var(--sp-16) var(--sp-6) var(--sp-6);gap:var(--sp-1);}
  #drawer.open{transform:translateX(0);}
  #drawer a{font-family:var(--f-sans);font-size:1.9rem;font-weight:560;font-stretch:88%;padding:var(--sp-3) 0;
    border-bottom:1px solid var(--hair-dim);letter-spacing:-.02em;}
  #drawer a em{font-style:normal;color:var(--honey);}
  #drawer a:last-of-type{border-bottom:none;}
  #drawer .coord{margin-bottom:var(--sp-5);}
  #drawer .close{position:absolute;top:var(--sp-5);right:var(--sp-5);font-family:var(--f-mono);
    font-size:var(--fs-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
    padding:10px;min-height:44px;}
  #scrim{position:fixed;inset:0;background:var(--scrim);z-index:299;opacity:0;visibility:hidden;
    transition:opacity var(--dur);backdrop-filter:blur(2px);}
  #scrim.open{opacity:1;visibility:visible;}

  /* ---- BARRA DE PROGRESSO DE LEITURA (artigo; inerte se ausente) ---- */
  #progress{position:fixed;top:0;left:0;height:2px;width:0;
    background:linear-gradient(90deg,var(--honey-deep),var(--honey-lift));
    z-index:250;box-shadow:0 0 10px 0 var(--honey-glow);transition:width .1s linear;}

  /* ---- SCROLL-CUE (hero/topo; "desça devagar") ---- */
  .scroll-cue{position:absolute;left:var(--pad);bottom:var(--sp-6);z-index:3;
    font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.2em;text-transform:uppercase;
    color:var(--ink-faint);display:flex;align-items:center;gap:11px;}
  .scroll-cue i{width:1px;height:30px;background:var(--hair);position:relative;overflow:hidden;}
  .scroll-cue i::after{content:'';position:absolute;inset:0;background:var(--honey);
    animation:softDrop 2.2s var(--ease) infinite;}

  /* ---- PRIMITIVOS DE FILTRO/SELEÇÃO (busca, chips, grade de UF) ----
     usados pela home (finder) e disponíveis a qualquer página de busca. */
  .search-need{width:100%;max-width:100%;background:var(--field-bg);border:1px solid var(--hair);color:var(--ink);
    padding:15px 16px;min-height:54px;font-family:var(--f-sans);font-size:var(--fs-body);border-radius:12px;
    transition:border-color var(--dur-fast),box-shadow var(--dur-fast),background-color var(--dur-fast);}
  .search-need::placeholder{color:var(--ink-faint);}
  .search-need:focus{outline:none;border-color:var(--honey);background:var(--field-bg-focus);box-shadow:0 0 0 4px var(--honey-glow);}
  .chips{display:flex;flex-wrap:wrap;gap:7px;}
  .chip{font-family:var(--f-mono);font-size:var(--fs-xs);letter-spacing:.02em;
    border:1px solid var(--hair);color:var(--ink-soft);padding:10px 14px;min-height:42px;
    display:inline-flex;align-items:center;gap:7px;border-radius:100px;background:transparent;
    transition:all var(--dur-fast) var(--ease);}
  .chip:hover{border-color:var(--ink-dim);color:var(--ink);}
  .chip[aria-pressed="true"]{background:var(--honey);border-color:var(--honey);color:var(--honey-ink);font-weight:500;
    box-shadow:0 6px 16px -8px var(--honey-glow);}
  .chip .x{opacity:0;width:0;overflow:hidden;transition:opacity var(--dur-fast);}
  .chip[aria-pressed="true"] .x{opacity:.9;width:auto;}
  .uf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(46px,1fr));gap:6px;}
  .uf{font-family:var(--f-mono);font-size:var(--fs-xs);text-align:center;padding:11px 4px;min-height:44px;
    border:1px solid var(--hair);color:var(--ink-soft);border-radius:8px;transition:all var(--dur-fast);background:transparent;}
  .uf:hover{border-color:var(--ink-dim);color:var(--ink);}
  .uf[aria-pressed="true"]{background:var(--honey);border-color:var(--honey);color:var(--honey-ink);font-weight:500;}

  /* ---- FOOTER (grade institucional) ---- */
  .footer{border-top:1px solid var(--hair-dim);padding:var(--sp-16) 0 var(--sp-8);}
  .footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-8);margin-bottom:var(--sp-12);}
  .footer .brandcol{grid-column:1/-1;}
  .footer .wm{font-family:var(--f-sans);font-weight:700;font-size:1.5rem;font-stretch:85%;letter-spacing:-.02em;}
  .footer .wm em{font-style:normal;color:var(--honey);font-weight:400;}
  .footer .ftag{font-family:var(--f-sans);font-weight:360;color:var(--ink-soft);margin-top:var(--sp-3);max-width:34ch;line-height:1.5;}
  .footer h4{font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.14em;text-transform:uppercase;
    color:var(--ink-dim);margin-bottom:var(--sp-4);font-weight:500;}
  .footer .fcol a{display:block;color:var(--ink-soft);margin-bottom:11px;font-size:var(--fs-sm);transition:color var(--dur-fast);}
  .footer .fcol a:hover{color:var(--honey);}
  .footer-bot{border-top:1px solid var(--hair-dim);padding-top:var(--sp-6);display:flex;justify-content:space-between;
    flex-wrap:wrap;gap:var(--sp-3);font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.04em;color:var(--ink-dim);}
  .footer-bot a{color:var(--honey);}
  @media(min-width:760px){.footer-grid{grid-template-columns:1.7fr 1fr 1fr 1fr;}.footer .brandcol{grid-column:auto;}}
  /* footer compacto (uma linha) — usado pela shell do app */
  .footer-in{max-width:var(--wrap);margin:0 auto;padding:0 var(--pad);
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4);
    font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.04em;color:var(--ink-dim);}
  .footer-in a{color:var(--honey);}

  /* ---- COOKIE / LGPD ---- */
  #cookie{position:fixed;left:0;right:0;bottom:0;z-index:400;background:var(--cookie-bg);color:var(--ink);
    border-top:1px solid var(--honey);transform:translateY(110%);transition:transform var(--dur) var(--ease-soft);}
  #cookie.show{transform:translateY(0);}
  .cookie-in{max-width:var(--wrap);margin:0 auto;padding:var(--sp-4) var(--pad);display:flex;flex-wrap:wrap;
    align-items:center;gap:var(--sp-4);justify-content:space-between;}
  .cookie-in p{font-family:var(--f-sans);font-weight:360;font-size:var(--fs-sm);max-width:62ch;line-height:1.5;}
  .cookie-in a{color:var(--honey-lift);border-bottom:1px solid var(--honey-lift);}
  .cookie-act{display:flex;gap:var(--sp-2);flex-wrap:wrap;}
  .ck-btn{font-family:var(--f-mono);font-size:var(--fs-mono);letter-spacing:.08em;text-transform:uppercase;
    padding:12px 18px;min-height:46px;border:1px solid var(--hair);color:var(--ink-soft);border-radius:100px;}
  .ck-btn.solid{background:var(--honey);border-color:var(--honey);color:var(--honey-ink);font-weight:600;}
}
