/* We Can — CSS do site (estático, HostGator).
   Construído sobre os tokens do design system (assets/css/tokens.css = cópia de design-system/we-can/tokens/).
   Fonte da verdade dos tokens e dos componentes: design-system/we-can/. Este arquivo é o "build" estático.
   Taste: flat e honesto (sem gradiente decorativo / sombra falsa), Inter com tracking apertado em display,
   pesos só 400/500, acento laranja ~10%. */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500&display=swap");
@import "tokens.css";

/* ============ reset mínimo ============ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
html, body { overflow-x: hidden; max-width: 100%; }
img, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
ul[role="list"] { list-style: none; padding: 0; }
a { color: inherit; text-decoration: none; }

/* ============ base ============ */
html {
  font-family: var(--font-body);
  color: var(--color-text-primary);
  background: var(--color-bg);
}
body {
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  font-weight: var(--font-weight-regular);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
}
p { overflow-wrap: break-word; }
strong, b { font-weight: var(--font-weight-medium); }
:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 2px; border-radius: var(--radius-sm); }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

/* ============ layout ============ */
.container { width: 100%; max-width: var(--container-max); margin-inline: auto; padding-inline: var(--space-6); }
@media (min-width: 768px) { .container { padding-inline: var(--space-8); } }

.section { padding-block: var(--space-16); }
@media (min-width: 768px) { .section { padding-block: var(--space-24); } }
.section--soft   { background: var(--wecan-orange-soft); }
.section--dark   { background: var(--color-bg-dark); color: var(--color-text-on-dark); }
.section--dark h2, .section--dark h3 { color: var(--color-text-on-dark); }
.section--accent { background: var(--color-bg-accent); color: var(--color-text-on-orange); }
.section--accent h2 { color: var(--color-text-on-orange); }

.section__head { max-width: 46rem; margin-bottom: var(--space-12); }
.section__kicker {
  display: inline-block; font-size: var(--text-sm); font-weight: var(--font-weight-medium);
  letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-accent);
  margin-bottom: var(--space-3);
}
.section__title { font-size: var(--text-4xl); }
.section__lead { margin-top: var(--space-4); font-size: var(--text-lg); color: var(--color-text-secondary); }
.section--dark .section__lead { color: color-mix(in oklab, var(--color-text-on-dark) 75%, transparent); }

/* ============ botões ============ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-6); border-radius: var(--radius-md);
  font-weight: var(--font-weight-medium); font-size: var(--text-base);
  border: 1px solid transparent; transition: background var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default), border-color var(--duration-fast) var(--easing-default);
}
.btn--primary { background: var(--color-accent); color: var(--color-text-on-orange); }
.btn--primary:hover { background: var(--color-accent-hover); color: var(--color-text-on-orange); }
.btn--secondary { border-color: var(--color-text-primary); color: var(--color-text-primary); }
.btn--secondary:hover { background: var(--color-text-primary); color: var(--color-text-on-dark); }
.btn--ghost { color: var(--color-accent); padding-inline: var(--space-2); }
.btn--ghost:hover { color: var(--color-accent-hover); }
.btn--on-dark { background: var(--color-accent); color: var(--color-text-on-orange); }
.btn--on-dark:hover { background: var(--color-accent-hover); }
.btn--lg { padding: var(--space-4) var(--space-8); font-size: var(--text-lg); }
.btn--block { width: 100%; }

/* ============ header / nav ============ */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklab, var(--color-bg) 92%, transparent);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-border);
}
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); min-height: 64px; }
.site-header__logo img { width: 116px; }
.nav-toggle { display: none; }
.nav-burger {
  display: inline-flex; flex-direction: column; gap: 5px; padding: var(--space-2);
  border-radius: var(--radius-sm); cursor: pointer;
}
.nav-burger span { width: 22px; height: 2px; background: var(--color-text-primary); display: block; }
.site-nav { display: none; }
.site-nav__list { display: flex; align-items: center; gap: var(--space-6); list-style: none; }
.site-nav__link { color: var(--color-text-secondary); font-size: var(--text-base); }
.site-nav__link:hover { color: var(--color-text-primary); }

/* mobile: nav abre via checkbox */
.nav-toggle:checked ~ .site-nav {
  display: block; position: absolute; left: 0; right: 0; top: 100%;
  background: var(--color-bg); border-bottom: 1px solid var(--color-border);
  padding: var(--space-4) var(--space-6) var(--space-8);
}
.nav-toggle:checked ~ .site-nav .site-nav__list { flex-direction: column; align-items: flex-start; gap: var(--space-4); }

@media (min-width: 880px) {
  .nav-burger { display: none; }
  .site-nav { display: block; }
  .site-nav__list { gap: var(--space-8); }
}

/* ============ hero ============ */
.hero { position: relative; overflow: hidden; }
.hero__grid { display: grid; gap: var(--space-8); align-items: center; }
.hero__logo img { width: 132px; margin-bottom: var(--space-8); }
.hero__title { font-size: var(--text-5xl); max-width: 14ch; }
.hero__lead { margin-top: var(--space-4); font-size: var(--text-xl); color: var(--color-text-secondary); max-width: 46ch; }
.hero__actions { margin-top: var(--space-8); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hero__slogan { margin-top: var(--space-8); font-size: var(--text-sm); color: var(--color-text-secondary); letter-spacing: var(--tracking-wide); }
.hero__accent { display: none; }
@media (min-width: 880px) {
  .hero__grid { grid-template-columns: 1.3fr .7fr; }
  .hero__accent { display: block; align-self: stretch; background: var(--color-bg-accent); border-radius: var(--radius-xl); min-height: 360px; }
}

/* ============ hero cinematográfico (home) ============ */
/* Cinematic = escala + palco escuro + split laranja sólido + entrada encenada.
   Honesto: cores chapadas, logo real, movimento só em transform/opacity (sem gradiente/profundidade falsa). */
.hero-cine { position: relative; min-height: 90svh; display: flex; flex-direction: column; justify-content: center; background: var(--color-bg-dark); color: var(--color-text-on-dark); overflow: hidden; }
.hero-cine__panel { position: absolute; inset: 0 0 0 auto; width: 36%; background: var(--color-bg-accent); display: none; place-items: center; transform: translateX(101%); animation: heroWipe 900ms var(--easing-default) 150ms both; }
.hero-cine__mark { width: min(48%, 260px); }
.hero-cine__bar { position: absolute; left: 0; right: 0; bottom: 0; height: 6px; background: var(--color-bg-accent); transform: scaleX(0); transform-origin: left; animation: heroBar 900ms var(--easing-default) 250ms both; }
.hero-cine__inner { position: relative; z-index: 1; width: 100%; min-width: 0; }
.hero-cine__content { padding-block: var(--space-24); }
.hero-cine__eyebrow { font-size: var(--text-sm); letter-spacing: var(--tracking-wide); color: var(--color-accent); margin-bottom: var(--space-6); opacity: 0; animation: heroFadeUp 700ms var(--easing-default) 250ms both; }
.hero-cine__title { font-size: clamp(2.5rem, 6.2vw, 5rem); line-height: 1.03; letter-spacing: -0.03em; font-weight: var(--font-weight-medium); color: var(--color-text-on-dark); }
.hero-cine__title .line { display: block; opacity: 0; animation: heroFadeUp 800ms var(--easing-default) both; }
.hero-cine__title .line:nth-child(1) { animation-delay: 340ms; }
.hero-cine__title .line:nth-child(2) { animation-delay: 460ms; }
.hero-cine__title .line:nth-child(3) { animation-delay: 580ms; }
.hero-cine__title em { font-style: normal; color: var(--color-accent); }
.hero-cine__lead { margin-top: var(--space-6); font-size: var(--text-xl); color: color-mix(in oklab, var(--color-text-on-dark) 80%, transparent); max-width: 42ch; opacity: 0; animation: heroFadeUp 800ms var(--easing-default) 720ms both; }
.hero-cine__actions { margin-top: var(--space-8); display: flex; flex-wrap: wrap; gap: var(--space-3); opacity: 0; animation: heroFadeUp 800ms var(--easing-default) 860ms both; }
.hero-cine__slogan { margin-top: var(--space-8); font-size: var(--text-sm); letter-spacing: var(--tracking-wide); color: color-mix(in oklab, var(--color-text-on-dark) 52%, transparent); opacity: 0; animation: heroFadeUp 800ms var(--easing-default) 1000ms both; }
.btn--outline-dark { border-color: color-mix(in oklab, var(--color-text-on-dark) 55%, transparent); color: var(--color-text-on-dark); }
.btn--outline-dark:hover { background: var(--color-text-on-dark); color: var(--color-text-primary); }
@keyframes heroWipe { to { transform: translateX(0); } }
@keyframes heroBar  { to { transform: scaleX(1); } }
@keyframes heroFadeUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
@media (min-width: 900px) {
  .hero-cine { min-height: 100svh; }
  .hero-cine__panel { display: grid; }
  .hero-cine__bar { display: none; }
  .hero-cine__content { padding-block: var(--space-32); padding-right: 42%; }
}

/* ============ prose / manifesto ============ */
.prose { max-width: 46rem; }
.prose p { font-size: var(--text-lg); line-height: var(--leading-relaxed); }
.prose p + p { margin-top: var(--space-4); }
.prose--secondary p { color: var(--color-text-secondary); }

/* ============ grid utilitário ============ */
.grid { display: grid; gap: var(--space-6); }
@media (min-width: 720px) { .grid--2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .grid--3 { grid-template-columns: repeat(3, 1fr); } .grid--4 { grid-template-columns: repeat(4, 1fr); } }

/* ============ card ============ */
.card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-8); }
.card__title { font-size: var(--text-xl); margin-bottom: var(--space-3); }
.card__text { color: var(--color-text-secondary); line-height: var(--leading-relaxed); }

/* ============ price cards ============ */
.price { display: flex; flex-direction: column; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-8); }
.price--popular { border-color: var(--color-accent); border-width: 2px; }
.price__badge { align-self: flex-start; background: var(--color-accent-secondary); color: var(--color-text-on-orange); font-size: var(--text-xs); font-weight: var(--font-weight-medium); text-transform: uppercase; letter-spacing: var(--tracking-wide); padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); margin-bottom: var(--space-4); }
.price__name { font-size: var(--text-2xl); }
.price__value { font-size: var(--text-4xl); margin-top: var(--space-2); }
.price__installment { color: var(--color-text-secondary); margin-top: var(--space-1); }
.price__list { list-style: none; padding: 0; margin: var(--space-6) 0; display: grid; gap: var(--space-3); }
.price__list li { position: relative; padding-left: var(--space-8); line-height: var(--leading-normal); }
.price__list li::before { content: "✓"; position: absolute; left: 0; color: var(--color-accent); font-weight: var(--font-weight-medium); }
.price__cta { margin-top: auto; }

/* ============ passos (como funciona) ============ */
.steps { display: grid; gap: var(--space-8); counter-reset: step; }
@media (min-width: 960px) { .steps--5 { grid-template-columns: repeat(5, 1fr); gap: var(--space-6); } }
.step__num { font-size: var(--text-2xl); font-weight: var(--font-weight-medium); color: var(--color-accent); letter-spacing: var(--tracking-tight); }
.step__title { font-size: var(--text-lg); margin-top: var(--space-3); }
.step__text { color: var(--color-text-secondary); margin-top: var(--space-2); line-height: var(--leading-relaxed); }

/* ============ FAQ ============ */
.faq { max-width: 52rem; }
.faq__item { border-bottom: 1px solid var(--color-border); }
.faq__item summary { display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); padding: var(--space-6) 0; font-weight: var(--font-weight-medium); font-size: var(--text-lg); cursor: pointer; list-style: none; }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after { content: "+"; color: var(--color-accent); font-size: var(--text-2xl); line-height: 1; transition: transform var(--duration-base) var(--easing-default); }
.faq__item[open] summary::after { transform: rotate(45deg); }
.faq__answer { padding-bottom: var(--space-6); color: var(--color-text-secondary); line-height: var(--leading-relaxed); max-width: 60ch; }

/* ============ seletor de plano (no formulário — visual como os price cards da home) ============ */
.plan-pick { display: grid; gap: var(--space-4); }
@media (min-width: 720px) { .plan-pick { grid-template-columns: 1fr 1fr; } }
.plan-pick__option { display: block; position: relative; }
.plan-pick__option input { position: absolute; opacity: 0; width: 0; height: 0; }
.plan-pick__card { display: flex; flex-direction: column; height: 100%; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-6); cursor: pointer; transition: border-color var(--duration-fast) var(--easing-default), background var(--duration-fast) var(--easing-default); }
.plan-pick__card:hover { border-color: var(--color-border-strong); }
.plan-pick__option input:checked + .plan-pick__card { border-color: var(--color-accent); border-width: 2px; background: var(--wecan-orange-soft); }
.plan-pick__option input:focus-visible + .plan-pick__card { outline: 2px solid var(--color-focus-ring); outline-offset: 2px; }
.plan-pick__badge { align-self: flex-start; background: var(--color-accent-secondary); color: var(--color-text-on-orange); font-size: var(--text-xs); font-weight: var(--font-weight-medium); text-transform: uppercase; letter-spacing: var(--tracking-wide); padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); margin-bottom: var(--space-3); }
.plan-pick__head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.plan-pick__name { font-size: var(--text-xl); font-weight: var(--font-weight-medium); }
.plan-pick__check { width: 22px; height: 22px; border-radius: var(--radius-full); border: 1px solid var(--color-border-strong); flex: none; display: grid; place-items: center; font-size: var(--text-sm); color: transparent; }
.plan-pick__option input:checked + .plan-pick__card .plan-pick__check { background: var(--color-accent); border-color: var(--color-accent); color: var(--color-text-on-orange); }
.plan-pick__price { font-size: var(--text-2xl); margin-top: var(--space-2); }
.plan-pick__inst { color: var(--color-text-secondary); font-size: var(--text-sm); }
.plan-pick__list { list-style: none; padding: 0; margin: var(--space-4) 0 0; display: grid; gap: var(--space-2); font-size: var(--text-sm); }
.plan-pick__list li { position: relative; padding-left: var(--space-6); }
.plan-pick__list li::before { content: "✓"; position: absolute; left: 0; color: var(--color-accent); }

/* ============ formulário ============ */
.field { margin-bottom: var(--space-6); }
.field__label { display: block; font-weight: var(--font-weight-medium); margin-bottom: var(--space-2); }
.field__req { color: var(--color-accent); }
.field__control { width: 100%; padding: var(--space-3) var(--space-4); border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-bg); transition: border-color var(--duration-fast) var(--easing-default); }
.field__control:hover { border-color: var(--color-border-strong); }
.field__control:focus-visible { border-color: var(--color-accent); outline-color: var(--color-accent); }
textarea.field__control { min-height: 7rem; resize: vertical; }
.field__help { font-size: var(--text-sm); color: var(--color-text-secondary); margin-top: var(--space-2); }
.field__options { display: grid; gap: var(--space-2); margin-top: var(--space-2); }
@media (min-width: 600px) { .field__options { grid-template-columns: repeat(3, 1fr); } }
.chip { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3); border: 1px solid var(--color-border); border-radius: var(--radius-md); cursor: pointer; }
.chip:hover { border-color: var(--color-border-strong); }
.note { background: var(--color-bg-elevated); border: 1px solid var(--color-border); border-left: 3px solid var(--color-accent); border-radius: var(--radius-md); padding: var(--space-4) var(--space-6); color: var(--color-text-secondary); font-size: var(--text-sm); }

/* ============ portfolio ============ */
.empty-state { border: 1px dashed var(--color-border-strong); border-radius: var(--radius-lg); padding: var(--space-16) var(--space-8); text-align: center; background: var(--color-bg-elevated); }
.empty-state__title { font-size: var(--text-2xl); }
.empty-state__text { color: var(--color-text-secondary); margin-top: var(--space-3); max-width: 44ch; margin-inline: auto; }

/* ============ legal / texto longo ============ */
.legal { max-width: 46rem; }
.legal h2 { font-size: var(--text-2xl); margin-top: var(--space-12); margin-bottom: var(--space-4); }
.legal h2:first-of-type { margin-top: var(--space-8); }
.legal p, .legal li { color: var(--color-text-secondary); line-height: var(--leading-relaxed); }
.legal p + p { margin-top: var(--space-4); }
.legal ul { margin: var(--space-4) 0; padding-left: var(--space-6); display: grid; gap: var(--space-2); }
.legal__updated { font-size: var(--text-sm); color: var(--color-text-secondary); margin-bottom: var(--space-8); }

/* ============ CTA band ============ */
.cta-band { text-align: center; }
.cta-band__title { font-size: var(--text-4xl); max-width: 20ch; margin-inline: auto; }
.cta-band__actions { margin-top: var(--space-8); display: flex; justify-content: center; flex-wrap: wrap; gap: var(--space-3); }

/* ============ footer ============ */
.site-footer { background: var(--color-bg-dark); color: var(--color-text-on-dark); padding-block: var(--space-16); }
.site-footer a { color: color-mix(in oklab, var(--color-text-on-dark) 80%, transparent); }
.site-footer a:hover { color: var(--color-text-on-dark); }
.site-footer__grid { display: grid; gap: var(--space-12); }
@media (min-width: 720px) { .site-footer__grid { grid-template-columns: 1.4fr 1fr 1fr; } }
.site-footer__logo img { width: 188px; margin-bottom: var(--space-4); }
.site-footer__sig { font-weight: var(--font-weight-medium); }
.site-footer__desc { color: color-mix(in oklab, var(--color-text-on-dark) 70%, transparent); margin-top: var(--space-1); }
.site-footer__coltitle { font-size: var(--text-sm); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: color-mix(in oklab, var(--color-text-on-dark) 60%, transparent); margin-bottom: var(--space-4); }
.site-footer__list { list-style: none; padding: 0; display: grid; gap: var(--space-3); }
.site-footer__bottom { border-top: 1px solid color-mix(in oklab, var(--color-text-on-dark) 18%, transparent); margin-top: var(--space-12); padding-top: var(--space-8); font-size: var(--text-sm); color: color-mix(in oklab, var(--color-text-on-dark) 60%, transparent); }
.site-footer .contact-accent { color: var(--color-accent); }

/* fallback de logo (rede de segurança; os SVGs reais existem em assets/img/) */
.logo-missing { display: inline-flex; align-items: center; padding: var(--space-2) var(--space-3); font-size: var(--text-xs); font-weight: var(--font-weight-medium); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-text-secondary); border: 1px dashed var(--color-border-strong); border-radius: var(--radius-sm); }

/* ============ utilitários ============ */
.u-visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.u-center { text-align: center; }
