/* ─────────────────────────────────────────────────────────────────
 * Pratika — components.css
 * Componentes compartilhados entre páginas (importar DEPOIS de design-tokens.css)
 * ───────────────────────────────────────────────────────────────── */

/* ── Container ─────────────────────────────────────────────────── */
.container { max-width: 1120px; margin: 0 auto; padding: 0 var(--s-5); }
.container--narrow { max-width: 760px; }
.container--wide { max-width: 1320px; }

/* ── Top nav (público) ─────────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 30;
  background: rgba(255,251,245,.85);
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--border);
}
@media (prefers-color-scheme: dark) { .nav { background: rgba(20,16,26,.85); } }
.nav__inner { display: flex; align-items: center; padding: 14px 0; gap: var(--s-5); }
.nav img { height: 56px; width: auto; }
.nav__links { display: none; gap: var(--s-5); margin-left: auto; }
.nav__links a { color: var(--ink); font-weight: 600; font-size: 14px; }
.nav__links a:hover { color: var(--primary); text-decoration: none; }
.nav__cta { display: flex; gap: 8px; margin-left: auto; }
.nav__cta .btn { padding: 9px 16px; }
@media (min-width: 880px) {
  .nav__links { display: flex; }
  .nav__cta { margin-left: 0; }
}

/* Burger mobile */
.nav__burger {
  appearance: none; border: 0; background: transparent; padding: 8px; margin-left: auto;
  width: 40px; height: 40px; display: grid; place-items: center;
  border-radius: var(--r-2);
}
.nav__burger:hover { background: var(--surface-2); }
.nav__burger svg { width: 22px; height: 22px; stroke: var(--ink); }
@media (min-width: 880px) { .nav__burger { display: none; } }

/* Drawer mobile */
.drawer {
  position: fixed; inset: 0; z-index: 90;
  background: rgba(45,17,71,.5); backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none; transition: opacity var(--t-base);
}
.drawer.on { opacity: 1; pointer-events: auto; }
.drawer__panel {
  position: absolute; top: 0; right: 0; bottom: 0; width: 84%; max-width: 320px;
  background: var(--surface); padding: var(--s-5);
  transform: translateX(100%); transition: transform var(--t-slow) var(--ease);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.drawer.on .drawer__panel { transform: translateX(0); }
.drawer__panel a { padding: 12px 14px; border-radius: var(--r-2); font-weight: 600; color: var(--ink); }
.drawer__panel a:hover { background: var(--surface-2); text-decoration: none; }

/* ── Footer ────────────────────────────────────────────────────── */
.footer {
  border-top: 1px solid var(--border);
  padding: var(--s-12) 0 calc(var(--s-8) + env(safe-area-inset-bottom));
  margin-top: var(--s-12);
  background: var(--surface);
}
.footer__grid {
  display: grid; gap: var(--s-6);
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
}
@media (max-width: 760px) { .footer__grid { grid-template-columns: 1fr 1fr; } .footer__brand { grid-column: 1 / -1; } }
.footer__brand img { height: 30px; margin-bottom: 12px; }
.footer__brand p { color: var(--ink-soft); font-size: 14px; max-width: 280px; }
.footer h5 { margin: 0 0 12px; font-size: 12px; text-transform: uppercase; letter-spacing: .12em; color: var(--ink-soft); font-weight: 700; }
.footer__list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.footer__list a { color: var(--ink); font-size: 14px; }
.footer__bottom {
  margin-top: var(--s-8); padding-top: var(--s-5);
  border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--s-3);
  color: var(--ink-soft); font-size: 13px;
}
.footer__bottom .heart { color: var(--p-coral-500); }

/* ── Forms ─────────────────────────────────────────────────────── */
.field { display: block; margin-bottom: var(--s-4); }
.field label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; color: var(--ink); }
.field .hint { font-size: 12px; color: var(--ink-soft); margin-top: 4px; }
.field .err { font-size: 12px; color: var(--danger); margin-top: 4px; display: none; }
.field.has-err .err { display: block; }
.field.has-err input, .field.has-err select, .field.has-err textarea { border-color: var(--danger); }

.input, .select, .textarea {
  width: 100%; padding: 13px 14px;
  background: var(--surface); color: var(--ink);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-2);
  font-size: 16px; line-height: 1.4;
  transition: border-color var(--t-base), box-shadow var(--t-base);
}
.select {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  padding-right: 38px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2375695a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 16px 16px;
}
@media (prefers-color-scheme: dark) {
  .select {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c9bfdc' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  }
}
.input:focus, .select:focus, .textarea:focus {
  outline: 0; border-color: var(--primary); box-shadow: var(--glow-axe);
}
.input::placeholder { color: var(--ink-faint); }
.input--lg { padding: 16px 18px; font-size: 17px; border-radius: var(--r-3); }

.input-group { position: relative; }
.input-group .input { padding-left: 44px; }
.input-group__icon {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  color: var(--ink-faint); width: 18px; height: 18px; pointer-events: none;
}

.checkbox, .radio { display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px;
  border: 1px solid var(--border); border-radius: var(--r-2); cursor: pointer; transition: all var(--t-fast);
  background: var(--surface);
}
.checkbox:hover, .radio:hover { border-color: var(--border-strong); background: var(--surface-2); }
.checkbox input, .radio input { margin: 3px 0 0; accent-color: var(--primary); }
.checkbox.is-checked, .radio.is-checked, input:checked + .radio__visual {
  border-color: var(--primary); background: var(--primary-soft); color: var(--ink);
}
.radio__group { display: grid; gap: 8px; }
@media (min-width: 540px) { .radio__group--2 { grid-template-columns: repeat(2, 1fr); } }

/* Radio cards (PF / PJ) */
.option-card {
  border: 2px solid var(--border); border-radius: var(--r-3);
  padding: var(--s-5); cursor: pointer; transition: all var(--t-base) var(--ease);
  background: var(--surface);
}
.option-card:hover { border-color: var(--border-strong); transform: translateY(-1px); box-shadow: var(--shadow-1); }
.option-card.active { border-color: var(--primary); background: var(--primary-soft); box-shadow: var(--shadow-pop); }
.option-card__icon { width: 44px; height: 44px; border-radius: 12px; background: var(--primary-soft); color: var(--primary); display: grid; place-items: center; margin-bottom: 12px; }
.option-card.active .option-card__icon { background: var(--primary); color: #fff; }
.option-card h4 { margin: 0 0 4px; font-size: 16px; }
.option-card p { margin: 0; font-size: 13px; color: var(--ink-soft); }

/* ── Wizard / Stepper ──────────────────────────────────────────── */
.stepper {
  display: flex; align-items: center; gap: 8px; margin-bottom: var(--s-6);
  padding: 0 var(--s-2);
}
.stepper__step {
  flex: 1; display: flex; align-items: center; gap: 8px;
}
.stepper__circle {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--surface-2); color: var(--ink-soft);
  border: 2px solid var(--border); display: grid; place-items: center;
  font-size: 12px; font-weight: 700; flex-shrink: 0;
  transition: all var(--t-base);
}
.stepper__step.done .stepper__circle { background: var(--success); color: #fff; border-color: var(--success); }
.stepper__step.active .stepper__circle { background: var(--primary); color: #fff; border-color: var(--primary); box-shadow: var(--glow-axe); }
.stepper__line {
  flex: 1; height: 2px; background: var(--border);
}
.stepper__step.done + .stepper__step .stepper__line,
.stepper__line.done { background: var(--success); }
.stepper__label {
  font-size: 12px; font-weight: 600; color: var(--ink-soft); white-space: nowrap;
}
.stepper__step.active .stepper__label { color: var(--ink); }
@media (max-width: 540px) { .stepper__label { display: none; } }

/* ── Search bar ────────────────────────────────────────────────── */
.searchbar {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-3); padding: 6px;
  display: grid; gap: 6px; box-shadow: var(--shadow-1);
}
@media (min-width: 760px) {
  .searchbar { grid-template-columns: 1.2fr 1fr 1fr auto; align-items: center; }
}
.searchbar__field { padding: 10px 14px; }
.searchbar__field label { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-soft); margin-bottom: 2px; }
.searchbar__field select, .searchbar__field input {
  width: 100%; border: 0; background: transparent; padding: 0; font-size: 15px; font-weight: 600; color: var(--ink);
}
.searchbar__field select {
  /* Seta custom (some no dark) + ganho de contraste */
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  padding-right: 22px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2375695a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
  background-size: 14px 14px;
}
@media (prefers-color-scheme: dark) {
  .searchbar__field select {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c9bfdc' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  }
}
.searchbar__field select:focus, .searchbar__field input:focus { outline: 0; }
.searchbar .btn { margin: 0; align-self: stretch; padding: 14px 20px; }

/* ── Pro card (marketplace) ────────────────────────────────────── */
.pro-grid { display: grid; gap: var(--s-4); }
@media (min-width: 600px) { .pro-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 920px) { .pro-grid { grid-template-columns: repeat(3, 1fr); } }

.pro-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-3); overflow: hidden;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base);
  cursor: pointer; display: flex; flex-direction: column;
}
.pro-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); }
.pro-card__cover {
  height: 140px; position: relative; overflow: hidden;
  background:
    linear-gradient(135deg, var(--p-axe-300), var(--p-bonfim-400));
}
.pro-card__cover--2 { background: linear-gradient(135deg, var(--p-amber-500), var(--p-coral-500)); }
.pro-card__cover--3 { background: linear-gradient(135deg, var(--p-verde-500), var(--p-bonfim-500)); }
.pro-card__cover--4 { background: linear-gradient(135deg, var(--p-coral-500), var(--p-axe-500)); }
.pro-card__cover--5 { background: linear-gradient(135deg, var(--p-axe-500), var(--p-coral-400)); }
.pro-card__cover--6 { background: linear-gradient(135deg, var(--p-amber-500), var(--p-axe-500)); }

.pro-card__cover::after {
  content:''; position: absolute; inset: 0;
  background: radial-gradient(circle at 70% 30%, rgba(255,255,255,.25), transparent 50%);
  pointer-events: none;
}
/* Quando tem foto de perfil como capa: sombra inferior pra contraste do avatar
   e remove o brilho radial que lava a foto */
.pro-card__cover[data-has-photo="1"]::after {
  background: linear-gradient(to bottom, rgba(0,0,0,0) 55%, rgba(0,0,0,.45) 100%);
}
.pro-card__cover[data-has-photo="1"] > img { z-index: 0; }
.pro-card__cover .pro-card__verified,
.pro-card__cover .pro-card__avatar { z-index: 2; }
.pro-card__avatar {
  position: absolute; bottom: -28px; left: 18px;
  width: 56px; height: 56px; border-radius: 50%;
  border: 4px solid var(--surface);
  background: var(--surface);
  display: grid; place-items: center;
  font-weight: 800; color: var(--primary); font-size: 22px;
}
.pro-card__verified {
  position: absolute; top: 12px; right: 12px;
  background: rgba(255,255,255,.9); color: var(--success);
  padding: 4px 8px; border-radius: var(--r-pill);
  font-size: 11px; font-weight: 700; display: flex; align-items: center; gap: 4px;
}
.pro-card__body { padding: 38px var(--s-4) var(--s-4); flex: 1; display: flex; flex-direction: column; }
.pro-card__body h3 { margin: 0 0 4px; font-size: 17px; font-weight: 700; }
.pro-card__hood { font-size: 13px; color: var(--ink-soft); margin-bottom: 10px; display: flex; align-items: center; gap: 4px; }
.pro-card__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.pro-card__tag {
  font-size: 11px; padding: 3px 8px; border-radius: var(--r-pill);
  background: var(--surface-2); color: var(--ink-soft); font-weight: 600;
}
.pro-card__rating { display: flex; align-items: center; gap: 4px; font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 12px; }
.pro-card__rating .star { color: var(--p-amber-500); }
.pro-card__rating small { color: var(--ink-soft); font-weight: 500; }
.pro-card__price { margin-top: auto; display: flex; align-items: center; justify-content: space-between; padding-top: 12px; border-top: 1px solid var(--border); }
.pro-card__price b { color: var(--primary); font-weight: 700; }
.pro-card__price small { color: var(--ink-soft); font-size: 12px; }

/* ── Page hero (subpages) ──────────────────────────────────────── */
.page-hero {
  padding: var(--s-10) 0 var(--s-6);
  background:
    radial-gradient(800px 200px at 30% 0%, rgba(142,71,216,.14), transparent 60%),
    var(--bg);
  text-align: center;
}
.page-hero h1 { font-size: clamp(32px, 4vw, 44px); margin: 0 0 8px; font-weight: 800; letter-spacing: -.02em; }
.page-hero h1 .scribble { font-family: var(--font-display); color: var(--primary); font-weight: 700; }
.page-hero p { color: var(--ink-soft); font-size: 17px; max-width: 600px; margin: 0 auto; }

/* ── Auth card (login/cadastro) ────────────────────────────────── */
.auth-wrap {
  min-height: calc(100dvh - 80px);
  display: grid; place-items: center; padding: var(--s-6) var(--s-4);
  background:
    radial-gradient(900px 220px at 50% 0%, rgba(142,71,216,.16), transparent 60%),
    var(--bg);
}
.auth-card {
  width: 100%; max-width: 480px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-4); box-shadow: var(--shadow-3);
  overflow: hidden; position: relative;
  animation: fade-up var(--t-slow) var(--ease) both;
}
.auth-card::before {
  content:''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--fitinha);
}
.auth-card__body { padding: var(--s-8) var(--s-6); }
.auth-card__head { text-align: center; margin-bottom: var(--s-6); }
.auth-card__head h1 { font-size: 26px; margin: 0 0 6px; font-weight: 800; }
.auth-card__head p { color: var(--ink-soft); margin: 0; font-size: 15px; }
.auth-card .divider {
  display: flex; align-items: center; gap: 12px; color: var(--ink-faint);
  font-size: 12px; margin: var(--s-5) 0; text-transform: uppercase; letter-spacing: .08em;
}
.auth-card .divider::before, .auth-card .divider::after { content:''; flex: 1; height: 1px; background: var(--border); }
.auth-card .alt {
  text-align: center; font-size: 14px; color: var(--ink-soft); margin-top: var(--s-5);
}
.auth-card .alt a { font-weight: 600; }

/* ── Section helpers ──────────────────────────────────────────── */
.section { padding: var(--s-12) 0; }
.section__head { text-align: center; max-width: 720px; margin: 0 auto var(--s-8); }
.section__head h2 {
  font-size: clamp(28px, 4vw, 40px); font-weight: 800; letter-spacing: -.02em;
  margin: 0 0 var(--s-2);
}
.section__head h2 .scribble { font-family: var(--font-display); color: var(--primary); font-weight: 700; }
.section__head p { color: var(--ink-soft); font-size: 17px; margin: 0; }

/* ── Tabs ─────────────────────────────────────────────────────── */
.tabs {
  display: flex; gap: 6px; padding: 4px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-pill);
  overflow-x: auto; scrollbar-width: none;
}
.tabs::-webkit-scrollbar { display: none; }
.tabs button {
  border: 0; background: transparent; padding: 9px 16px;
  border-radius: var(--r-pill); font-size: 14px; font-weight: 600;
  color: var(--ink-soft); white-space: nowrap;
  transition: background var(--t-fast);
}
.tabs button.active { background: var(--primary); color: var(--primary-ink); }
.tabs button:not(.active):hover { background: var(--surface-2); color: var(--ink); }

/* ── Notice ───────────────────────────────────────────────────── */
.notice {
  display: flex; gap: 12px; padding: 14px 16px; border-radius: var(--r-2);
  background: var(--primary-soft); border: 1px solid var(--primary-soft);
  color: var(--primary-soft-fg); font-size: 14px;
}
.notice b, .notice strong { color: inherit; }
.notice a { color: inherit; text-decoration: underline; font-weight: 700; }
.notice--warn   { background: var(--status-pending-bg);   color: var(--status-pending-fg); border-color: var(--status-pending-bg); }
.notice--danger { background: var(--status-cancelled-bg); color: var(--status-cancelled-fg); border-color: var(--status-cancelled-bg); }
.notice--success{ background: var(--status-confirmed-bg); color: var(--status-confirmed-fg); border-color: var(--status-confirmed-bg); }

/* ── Lightbox (anti dark-mode bug) ────────────────────────────────
   Use SEMPRE que precisar de fundo claro fixo (cartão branco, botão
   Google, recibo, chave PIX, etc). Trava cor de texto pra escuro
   independente do tema do sistema. */
.lightbox, .light-surface {
  background: #ffffff;
  color: #2d271f;
  border: 1px solid rgba(45,17,71,.12);
}
.lightbox--cream { background: #fffbf5; }
.lightbox * { color: inherit; }

/* ── Toast (compartilhado) ────────────────────────────────────── */
.toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--n-700); color: var(--n-50);
  padding: 12px 18px; border-radius: var(--r-pill);
  font-size: 14px; font-weight: 500;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-base), transform var(--t-base) var(--ease);
  box-shadow: var(--shadow-3); z-index: 100;
}
.toast.on { opacity: 1; transform: translateX(-50%) translateY(0); }
