/* ═══ Portal da Mentoria · Floresta Governada ═══ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;500;600&family=Inter:wght@400;500;600&display=swap');

:root {
  --void: #081a0e;
  --deep: #0e2e18;
  --forest: #1B3A2D;
  --emerald: #166534;
  --jade: #22804a;
  --sage: #4ade80;
  --gold: #C9A84C;
  --gold-warm: #e8a820;
  --gold-bright: #F0C040;
  --gold-pale: #fce88a;
  --soul: #F5F0E8;
  --secondary: #A89968;
  --muted: #6B7F72;
  --p1: #4ade80; --p2: #C9A84C; --p3: #8B5CF6;
  --p4: #38bdf8; --p5: #f59e0b; --p6: #f472b6;
  --radius: 14px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  background: var(--void);
  color: var(--soul);
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  min-height: 100vh;
}

h1, h2, h3 { font-family: 'Cormorant Garamond', serif; font-weight: 400; letter-spacing: 0.03em; }

.veio-ouro { width: 64px; height: 1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); margin: 1.2rem auto; }

/* fundo com respiração de floresta */
.fundo-floresta {
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(34,128,74,.18), transparent),
    radial-gradient(ellipse 60% 40% at 80% 110%, rgba(201,168,76,.07), transparent),
    var(--void);
}

.card {
  background: linear-gradient(160deg, rgba(27,58,45,.55), rgba(14,46,24,.75));
  border: 1px solid rgba(201,168,76,.18);
  border-radius: var(--radius);
  padding: 1.6rem;
}

.btn {
  display: inline-block;
  background: linear-gradient(135deg, var(--gold), var(--gold-warm));
  color: var(--void);
  font-weight: 600;
  font-size: .95rem;
  border: none;
  border-radius: 10px;
  padding: .8rem 1.8rem;
  cursor: pointer;
  letter-spacing: .02em;
  transition: filter .2s, transform .15s;
}
.btn:hover { filter: brightness(1.1); transform: translateY(-1px); }
.btn-ghost {
  background: transparent;
  color: var(--gold);
  border: 1px solid rgba(201,168,76,.4);
}

input, textarea, select {
  width: 100%;
  background: rgba(8,26,14,.7);
  border: 1px solid rgba(201,168,76,.25);
  border-radius: 10px;
  color: var(--soul);
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  padding: .75rem 1rem;
  outline: none;
  transition: border-color .2s;
}
input:focus, textarea:focus { border-color: var(--gold); }
label { display: block; font-size: .82rem; color: var(--secondary); margin: .9rem 0 .3rem; letter-spacing: .04em; text-transform: uppercase; }

.erro { color: #f87171; font-size: .88rem; margin-top: .8rem; min-height: 1.2em; }
.ok-msg { color: var(--sage); font-size: .88rem; margin-top: .8rem; }

/* topo */
.topo {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 2rem;
  border-bottom: 1px solid rgba(201,168,76,.14);
}
.topo .marca { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; color: var(--gold); letter-spacing: .06em; }
.topo .aluna-nome { font-size: .85rem; color: var(--muted); }
.topo a { color: var(--muted); text-decoration: none; font-size: .85rem; }
.topo a:hover { color: var(--gold); }

.container { max-width: 1080px; margin: 0 auto; padding: 2.5rem 1.5rem; }

/* clareiras (cards de portal) */
.clareira {
  position: relative;
  border-radius: var(--radius);
  padding: 1.5rem;
  border: 1px solid rgba(201,168,76,.15);
  background: linear-gradient(160deg, rgba(27,58,45,.5), rgba(8,26,14,.85));
  transition: transform .2s, border-color .2s;
  display: block; text-decoration: none; color: var(--soul);
}
.clareira.aberta:hover { transform: translateY(-3px); border-color: var(--cor, var(--gold)); cursor: pointer; }
.clareira.aberta { box-shadow: 0 0 32px -14px var(--cor, var(--gold)); }
.clareira.fechada { opacity: .45; filter: saturate(.3); }
.clareira .icone { font-size: 1.7rem; }
.clareira h3 { font-size: 1.3rem; margin: .5rem 0 .2rem; color: var(--cor, var(--soul)); }
.clareira .sub { font-size: .82rem; color: var(--muted); }
.clareira .cadeado { position: absolute; top: 1.1rem; right: 1.2rem; color: var(--muted); font-size: .95rem; }

.grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.2rem; }

.tag { display: inline-block; font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; color: var(--gold); border: 1px solid rgba(201,168,76,.35); border-radius: 999px; padding: .15rem .7rem; }
.tag.breve { color: var(--muted); border-color: rgba(107,127,114,.4); }

table { width: 100%; border-collapse: collapse; font-size: .9rem; }
th { text-align: left; color: var(--secondary); font-weight: 500; font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; padding: .6rem .8rem; border-bottom: 1px solid rgba(201,168,76,.2); }
td { padding: .65rem .8rem; border-bottom: 1px solid rgba(201,168,76,.08); }

@media (max-width: 640px) {
  .container { padding: 1.5rem 1rem; }
  .topo { padding: 1rem; }
}
