/* =========================================================================
   Studio Artemis — main.css
   Tokens estruturais e variáveis extraídas do Figma (frame 1440).
   ========================================================================= */

@import url("sections/hero-refine.css");
@import url("sections/about.css");
@import url("sections/differences.css");
@import url("sections/services.css");
@import url("sections/products.css");
@import url("sections/cta-band.css");
@import url("sections/reviews.css");
@import url("sections/cases.css");
@import url("sections/blog.css");
@import url("sections/cta-final.css");
@import url("sections/footer.css");
@import url("sections/mobile.css");


:root {
	/* Tokens estruturais (Fase 0.5) */
	--frame-w: 1440px;
	--content-w: 1376px;  /* 1440 - 64 (px de borda interna) */
	--section-px: 32px;
	--content-gap: 32px;

	/* Cores — get_variable_defs do root */
	--bg-pure: #09090B;
	--bg-light: #111111;
	--bg-surface: #15151A;
	--primary-lightest: #1E8BFF;
	--primary-dark: #0D419B;

	/* Texto */
	--text: #FFFFFF;
	--text-soft: rgba(255, 255, 255, 0.5);
	--text-mute: rgba(255, 255, 255, 0.7);

	/* Bordas */
	--border-soft: rgba(255, 255, 255, 0.15);
	--border-stronger: rgba(255, 255, 255, 0.25);

	/* Tipografia */
	--font-body: 'Cabin', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--font-display: 'Cabin', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

	/* Radius */
	--radius-pill: 999px;
	--radius-md: 12px;
	--radius-lg: 16px;
}

/* -------------------------------------------------------------------------
   Reset mínimo
   ------------------------------------------------------------------------- */

*, *::before, *::after { box-sizing: border-box; }

html {
	-webkit-text-size-adjust: 100%;
	line-height: 1.5;
	background: var(--bg-pure);
	overflow-x: clip;
}

body {
	margin: 0;
	font-family: var(--font-body);
	background: var(--bg-pure);
	color: var(--text);
	font-size: 16px;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: clip;
	max-width: 100vw;
}

img, svg, video { display: block; max-width: 100%; height: auto; }

a { color: inherit; text-decoration: none; }

button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }

p { margin: 0; text-wrap: pretty; }
h1, h2, h3, h4, h5, h6 { margin: 0; font-weight: 600; text-wrap: balance; }

/* -------------------------------------------------------------------------
   Anti-Elementor global leak
   Quando Elementor está ativo no site (mesmo em página não-Elementor), ele
   injeta <style> inline com regras tipo .elementor-kit-N h1 { color:#000 }
   que vazam pro nosso tema. Especificidade Elementor: (0,1,1).
   Usamos body.wp-theme-artemis + elemento = (0,1,2) — bate Elementor sem
   precisar de !important e preserva as overrides específicas de seção
   (.hero__title, .about__title, etc) que continuam tendo cascata normal.
   ------------------------------------------------------------------------- */
/* Color override — só cor, não font-family (deixa cascata normal pegar a font certa) */
body.wp-theme-artemis h1,
body.wp-theme-artemis h2,
body.wp-theme-artemis h3,
body.wp-theme-artemis h4,
body.wp-theme-artemis h5,
body.wp-theme-artemis h6 {
	color: var(--text);
	font-weight: 600;
}
/* NÃO setar p/a/span/li genericamente — quebra qualquer classe que
   precise de cor diferente (text-soft, eyebrow muted, etc).
   Elementos herdam do body via cascata normal. */
body.wp-theme-artemis {
	color: var(--text);
}

/* Override Elementor pras classes "soft/mute/muted" mantém cinza.
   Hero e CTA Final removidos — no Figma esses são brancos. */
body.wp-theme-artemis .about__title-mute,
body.wp-theme-artemis .differences__title-mute,
body.wp-theme-artemis .services__section-title-soft,
body.wp-theme-artemis .services__title-soft,
body.wp-theme-artemis .products__title-soft,
body.wp-theme-artemis .reviews__pitch-soft,
body.wp-theme-artemis .cases__heading-soft,
body.wp-theme-artemis .blog__title-muted,
body.wp-theme-artemis .cta-band__title-soft,
body.wp-theme-artemis .site-footer__newsletter-text-muted,
body.wp-theme-artemis .reviews__rating-caption {
	color: var(--text-soft);
}

/* Force fonts dos títulos principais — Exo bate .elementor-kit-N h1 (0,1,1)
   via body.wp-theme-artemis prefix (0,1,2). Section files originais ficam
   intactos, esse aqui só GARANTE override no contexto Elementor. */
body.wp-theme-artemis .hero__title,
body.wp-theme-artemis .about__title,
body.wp-theme-artemis .services__section-title,
body.wp-theme-artemis .services__heading,
body.wp-theme-artemis .products__heading,
body.wp-theme-artemis .reviews__pitch,
body.wp-theme-artemis .reviews__rating-score,
body.wp-theme-artemis .cases__heading,
body.wp-theme-artemis .cases-slider__title,
body.wp-theme-artemis .cases__stat-number,
body.wp-theme-artemis .blog__title,
body.wp-theme-artemis .cta-band__title,
body.wp-theme-artemis .cta-final__title {
	font-family: 'Exo', 'Cabin', system-ui, sans-serif;
}
body.wp-theme-artemis .reviews__eyebrow,
body.wp-theme-artemis .reviews__eyebrow p,
body.wp-theme-artemis .differences__headings,
body.wp-theme-artemis .differences__headings p,
body.wp-theme-artemis .differences__heading--left,
body.wp-theme-artemis .differences__heading--right,
body.wp-theme-artemis .site-nav,
body.wp-theme-artemis .site-nav a,
body.wp-theme-artemis .site-header__cta,
body.wp-theme-artemis .cases__eyebrow,
body.wp-theme-artemis .cases__eyebrow span,
body.wp-theme-artemis .cases__eyebrow em,
body.wp-theme-artemis .blog__eyebrow,
body.wp-theme-artemis .blog__eyebrow p,
body.wp-theme-artemis .reviews__card-role {
	font-family: 'Instrument Serif', Georgia, serif !important;
	font-style: italic !important;
	font-weight: 400 !important;
	font-size: 20px !important;
}
/* Tags/eyebrows cor cinza soft — sobrescreve Elementor */
body.wp-theme-artemis .reviews__eyebrow,
body.wp-theme-artemis .reviews__eyebrow p,
body.wp-theme-artemis .differences__headings,
body.wp-theme-artemis .differences__headings p,
body.wp-theme-artemis .cases__eyebrow,
body.wp-theme-artemis .cases__eyebrow span,
body.wp-theme-artemis .blog__eyebrow,
body.wp-theme-artemis .blog__eyebrow p {
	color: var(--text-soft) !important;
}

/* Elementor força .elementor-kit-N button { background:#005EFF; color:#F2F4F7;
   padding:16px 32px; border-radius:4px; font-size:18px }. Reseta TUDO.
   IMPORTANTE: .site-header__cta NÃO entra aqui — é texto Instrument Serif,
   não botão pill, e tem regras próprias acima. */
body.wp-theme-artemis .btn,
body.wp-theme-artemis .cta-band__cta,
body.wp-theme-artemis .cta-final__btn,
body.wp-theme-artemis .blog__cta,
body.wp-theme-artemis .cases-slider__btn,
body.wp-theme-artemis .reviews-slider__prev,
body.wp-theme-artemis .reviews-slider__next,
body.wp-theme-artemis .site-footer__top-btn,
body.wp-theme-artemis .site-footer__social-icon,
body.wp-theme-artemis .site-footer__newsletter-submit,
body.wp-theme-artemis .mobile-menu__cta {
	background-color: transparent;
	color: var(--text);
	font-family: var(--font-body);
	font-size: 16px;
	font-weight: 600;
	padding: 18px 24px;
	border-radius: var(--radius-pill);
}
/* Botões circulares (sliders, footer top) — width/height fixos + padding 0 */
body.wp-theme-artemis .cases-slider__btn,
body.wp-theme-artemis .reviews-slider__prev,
body.wp-theme-artemis .reviews-slider__next,
body.wp-theme-artemis .site-footer__top-btn,
body.wp-theme-artemis .site-footer__social-icon {
	width: 40px;
	height: 40px;
	padding: 0;
	border-radius: 50%;
	border: 1px solid var(--border-soft);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
/* Newsletter submit é um botão menor, com seu próprio sizing */
body.wp-theme-artemis .site-footer__newsletter-submit {
	padding: 14px 20px;
	font-size: 14px;
}
/* Botões "primary" mantém fundo branco com texto escuro.
   !important pra garantir que o JS premiumButtons leia a cor certa
   no DOMContentLoaded (senão lê branco do Elementor e fica invisível). */
body.wp-theme-artemis .btn--primary,
body.wp-theme-artemis .cta-band__cta,
body.wp-theme-artemis .cta-final__btn,
body.wp-theme-artemis .mobile-menu__cta {
	background-color: #fff !important;
	color: #09090B !important;
}
/* Header CTA — texto puro Instrument Serif, sem padding/border/bg */
body.wp-theme-artemis .site-header__cta {
	background-color: transparent !important;
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	border-radius: 0 !important;
}

/* Fixed header — position:sticky não tava funcionando (algum overflow
   no Elementor/Hello quebra o sticky context). Fixed é à prova de bala. */
body.wp-theme-artemis .site-header {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	width: 100% !important;
	z-index: 100 !important;
}
/* Compensa o fixed header com padding-top no main pra não esconder hero */
body.wp-theme-artemis .site-main {
	padding-top: 73px;
}
/* No admin do WP a admin-bar fica em cima do header — empurra ele 32px */
body.wp-theme-artemis.admin-bar .site-header {
	top: 32px !important;
}
@media (max-width: 782px) {
	body.wp-theme-artemis.admin-bar .site-header {
		top: 46px !important;
	}
}

/* ============================================================
   Section title sizes — Elementor força font-size global, precisa
   restaurar os tamanhos certos do design.
   ============================================================ */
body.wp-theme-artemis .hero__title {
	font-size: 62px !important;
	line-height: 1 !important;
	letter-spacing: -1.86px !important;
	color: var(--text) !important;
}
/* Hero NÃO tem parte cinza no Figma — força todo o título branco */
body.wp-theme-artemis .hero__title,
body.wp-theme-artemis .hero__title-soft {
	color: var(--text) !important;
}
body.wp-theme-artemis .hero__subtitle {
	font-size: 18px !important;
	line-height: 1.5 !important;
}
body.wp-theme-artemis .about__title {
	font-size: 40px !important;
	line-height: 1.3 !important;
}
body.wp-theme-artemis .differences__title {
	font-size: 24px !important;
	line-height: 1.3 !important;
}
body.wp-theme-artemis .services__section-title {
	font-size: 40px !important;
	line-height: 1.2 !important;
}
body.wp-theme-artemis .services__heading,
body.wp-theme-artemis .products__heading {
	font-size: 32px !important;
	line-height: 1.2 !important;
}
body.wp-theme-artemis .reviews__pitch {
	font-size: 40px !important;
	line-height: 1.2 !important;
	max-width: 972px !important;
	/* NÃO usar flex-basis 972px aqui — em flex-column (mobile) vira altura
	   forçada 972px no elemento. max-width já constrói a largura. */
}
body.wp-theme-artemis .reviews__rating-score {
	font-size: 62px !important;
	line-height: 1.2 !important;
}
body.wp-theme-artemis .cases__heading {
	font-size: 40px !important;
	line-height: 1.2 !important;
}
/* Cases landscape bg — Elementor lazy-load força background-image:none.
   !important garante que a imagem do landscape sempre apareça. */
body.wp-theme-artemis .cases-slider__image {
	background-image: url('../images/cases/landscape.jpg') !important;
	background-size: cover !important;
	background-position: center !important;
	background-repeat: no-repeat !important;
}
body.wp-theme-artemis .cases-slider__title {
	font-size: 32px !important;
	line-height: 1.3 !important;
}
body.wp-theme-artemis .cases__stat-number {
	font-size: 56px !important;
	line-height: 1.1 !important;
}
body.wp-theme-artemis .blog__title {
	font-size: 40px !important;
	line-height: 1.2 !important;
}
body.wp-theme-artemis .blog__card-title {
	font-size: 22px !important;
	line-height: 1.3 !important;
}
body.wp-theme-artemis .cta-band__title {
	font-size: 32px !important;
	line-height: 1.3 !important;
}
body.wp-theme-artemis .cta-final__title {
	font-size: 40px !important;
	line-height: 1.2 !important;
}
/* CTA Final: título branco MAS o span .cta-final__title-soft fica cinza
   (a frase "o que sua operação está perdendo?" no Figma tem cinza). */
body.wp-theme-artemis .cta-final__title {
	color: var(--text) !important;
}
body.wp-theme-artemis .cta-final__title-soft {
	color: var(--text-soft) !important;
}

/* ============================================================
   Mobile overrides — meu !important desktop tava vencendo os
   tamanhos do mobile.css. Aqui restauro os tamanhos certos pra
   tablet (≤1024) e mobile (≤768).
   ============================================================ */
@media (max-width: 1024px) {
	body.wp-theme-artemis .hero__title {
		font-size: 50px !important;
		letter-spacing: -1.4px !important;
	}
	body.wp-theme-artemis .about__title { font-size: 32px !important; }
	body.wp-theme-artemis .services__section-title { font-size: 32px !important; }
	body.wp-theme-artemis .services__heading,
	body.wp-theme-artemis .products__heading { font-size: 28px !important; }
	body.wp-theme-artemis .reviews__pitch {
		font-size: 28px !important;
		max-width: 100% !important;
	}
	body.wp-theme-artemis .reviews__rating-score { font-size: 48px !important; }
	body.wp-theme-artemis .cases__heading { font-size: 32px !important; }
	body.wp-theme-artemis .cases-slider__title { font-size: 24px !important; }
	body.wp-theme-artemis .cases__stat-number { font-size: 40px !important; }
	body.wp-theme-artemis .blog__title { font-size: 32px !important; }
	body.wp-theme-artemis .cta-band__title { font-size: 26px !important; }
	body.wp-theme-artemis .cta-final__title { font-size: 32px !important; }
}
@media (max-width: 768px) {
	body.wp-theme-artemis .hero__title {
		font-size: 36px !important;
		letter-spacing: -1px !important;
	}
	body.wp-theme-artemis .about__title { font-size: 24px !important; }
	body.wp-theme-artemis .services__section-title { font-size: 24px !important; }
	body.wp-theme-artemis .services__heading,
	body.wp-theme-artemis .products__heading { font-size: 22px !important; }
	body.wp-theme-artemis .reviews__pitch {
		font-size: 22px !important;
		max-width: 100% !important;
	}
	body.wp-theme-artemis .reviews__rating-score { font-size: 40px !important; }
	body.wp-theme-artemis .cases__heading { font-size: 24px !important; }
	body.wp-theme-artemis .cases-slider__title { font-size: 20px !important; }
	body.wp-theme-artemis .cases__stat-number { font-size: 32px !important; }
	body.wp-theme-artemis .blog__title { font-size: 24px !important; }
	body.wp-theme-artemis .cta-band__title { font-size: 20px !important; }
	body.wp-theme-artemis .cta-final__title { font-size: 26px !important; }

	/* Reviews mobile — apertar todos os gaps + Swiper height auto */
	body.wp-theme-artemis .reviews {
		padding: 60px var(--section-px) !important;
		gap: 32px !important;
	}
	body.wp-theme-artemis .reviews__inner { gap: 24px !important; }
	body.wp-theme-artemis .reviews__header { gap: 24px !important; }
	body.wp-theme-artemis .reviews__summary { gap: 24px !important; }
	body.wp-theme-artemis .reviews__cards,
	body.wp-theme-artemis .reviews__cards .swiper-wrapper,
	body.wp-theme-artemis .reviews__cards .swiper-slide,
	body.wp-theme-artemis .reviews__card {
		height: auto !important;
		min-height: 0 !important;
	}
	body.wp-theme-artemis .reviews__card-body {
		padding: 24px !important;
		min-height: 0 !important;
	}
}
@media (max-width: 480px) {
	body.wp-theme-artemis .hero__title {
		font-size: 30px !important;
		letter-spacing: -0.8px !important;
	}
}

/* ============================================================
   Hamburger button — não é botão pill, Elementor tava bagunçando
   ============================================================ */
body.wp-theme-artemis .site-header__hamburger {
	background: none !important;
	background-color: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	border-radius: 0 !important;
	width: 40px !important;
	height: 40px !important;
	color: var(--text) !important;
}
body.wp-theme-artemis .site-header__hamburger span {
	background: var(--text) !important;
}

/* ============================================================
   Anchor colors — Elementor força .elementor-kit-N a { color: blue }
   tanto no estado normal quanto no hover. Override total.
   ============================================================ */
body.wp-theme-artemis a {
	color: inherit !important;
	text-decoration: none;
	transition: opacity 0.15s ease;
}
body.wp-theme-artemis a:hover,
body.wp-theme-artemis a:focus {
	color: inherit !important;
	opacity: 0.7;
}
/* Botões com cor sólida — hover não muda opacity, só visual via JS */
body.wp-theme-artemis .btn:hover,
body.wp-theme-artemis .cta-band__cta:hover,
body.wp-theme-artemis .cta-final__btn:hover,
body.wp-theme-artemis .blog__card-link:hover {
	opacity: 1;
}

/* ============================================================
   Body text font-family — força Cabin como base, sobrescreve Elementor.
   Títulos específicos com Exo / Instrument Serif têm suas próprias regras
   prefixadas com body.wp-theme-artemis acima, então ganham.
   ============================================================ */
body.wp-theme-artemis,
body.wp-theme-artemis .about__intro,
body.wp-theme-artemis .about__founder-label,
body.wp-theme-artemis .about__location,
body.wp-theme-artemis .differences__text,
body.wp-theme-artemis .services__description,
body.wp-theme-artemis .products__description,
body.wp-theme-artemis .reviews__card-quote,
body.wp-theme-artemis .reviews__card-author,
body.wp-theme-artemis .reviews__card-score,
body.wp-theme-artemis .cases-slider__quote,
body.wp-theme-artemis .cases-slider__category,
body.wp-theme-artemis .cases-slider__country,
body.wp-theme-artemis .cases-slider__reviewer-name,
body.wp-theme-artemis .cases__stat-label,
body.wp-theme-artemis .blog__card-meta,
body.wp-theme-artemis .blog__card-title,
body.wp-theme-artemis .cta-final__subtitle,
body.wp-theme-artemis .site-footer__col-title,
body.wp-theme-artemis .site-footer__col a,
body.wp-theme-artemis .site-footer__contact-label,
body.wp-theme-artemis .site-footer__contact-value,
body.wp-theme-artemis .site-footer__newsletter-text,
body.wp-theme-artemis .site-footer__newsletter-input,
body.wp-theme-artemis .site-footer__copyright,
body.wp-theme-artemis .site-footer__copyright a,
body.wp-theme-artemis .site-footer__social-label {
	font-family: 'Cabin', system-ui, -apple-system, sans-serif !important;
}
/* Específicos: .about__founder-label peso 600 (label "Fundadores"). */
body.wp-theme-artemis .about__founder-label {
	font-weight: 600 !important;
}

/* -------------------------------------------------------------------------
   Container global
   ------------------------------------------------------------------------- */

.container {
	width: 100%;
	max-width: var(--frame-w);
	margin-inline: auto;
	padding-inline: var(--section-px);
}

/* -------------------------------------------------------------------------
   Templates page.php / single.php — Elementor-friendly
   Páginas individuais usam o header/footer do tema mas conteúdo full-bleed
   pro Elementor renderizar livre. Se usar template "Elementor Canvas" no
   editor, essas regras nem entram (canvas pula get_header/get_footer).
   ------------------------------------------------------------------------- */
.site-main--page,
.site-main--single {
	width: 100%;
	min-height: 50vh;
}
.page-article,
.single-article {
	width: 100%;
}
.single-article__header {
	max-width: 800px;
	margin: 80px auto 40px;
	padding-inline: var(--section-px);
}
.single-article__title {
	font-family: 'Exo', sans-serif;
	font-size: clamp(28px, 4vw, 48px);
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin-bottom: 32px;
}
.single-article__cover {
	margin-top: 32px;
	border-radius: var(--radius-md);
	overflow: hidden;
}
.single-article__cover img { width: 100%; height: auto; display: block; }
.single-article__content {
	max-width: 720px;
	margin: 0 auto 120px;
	padding-inline: var(--section-px);
	font-size: 18px;
	line-height: 1.7;
}
.single-article__content p { margin-bottom: 1.2em; }
.single-article__content h2,
.single-article__content h3 { margin-top: 1.8em; margin-bottom: 0.6em; }
.single-article__content a { color: var(--primary-lightest); text-decoration: underline; }

/* Páginas Elementor: deixa o Elementor controlar largura/padding sem
   conflito do tema. Elementor wrapper já tem .elementor classes próprias. */
.page-article .elementor,
.single-article .elementor {
	width: 100%;
}

/* -------------------------------------------------------------------------
   Botões
   ------------------------------------------------------------------------- */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 18px 24px;
	border-radius: var(--radius-pill);
	border: 1px solid var(--border-soft);
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 16px;
	line-height: 1.5;
	white-space: nowrap;
	transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

/* .btn:hover translateY removido — user pediu botões fixos sem subir */

.btn--primary {
	background: #fff;
	color: var(--bg-pure);
	border-color: var(--border-soft);
}
.btn--primary:hover { background: #f3f3f5; }

.btn--secondary {
	background: transparent;
	color: var(--text);
}
.btn--secondary:hover { background: rgba(255, 255, 255, 0.05); }

/* -------------------------------------------------------------------------
   Header — pixel-perfect (Figma 7093:699)
   bg #09090b, border-b 1px rgba(255,255,255,0.15), px 32, py 24
   Logo SVG 124.286x24. Nav: Instrument Serif Italic 20px.
   Separator: square 4x4 rgba(255,255,255,0.5). "Agendar conversa": text.
   ------------------------------------------------------------------------- */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--bg-pure);
	border-bottom: 1px solid var(--border-soft);
	padding: 24px var(--section-px);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

.site-brand {
	display: inline-flex;
	align-items: center;
	background: none;
	border: 0;
	padding: 0;
	cursor: pointer;
}
.site-brand__logo {
	display: block;
	width: 124.286px;
	height: 24px;
}
.site-brand__name { display: none; }

/* Wordmark "artemis" — Exo 24px, "is" italic 600. Figma node 7294:2287.
   Specs exatas: arte+m (500 normal, -1.2px), m (-1.68px), is (italic 600, -1.2px). */
.site-brand__wordmark {
	display: inline-block;
	font-family: 'Exo', system-ui, sans-serif;
	font-style: normal;
	font-weight: 500;
	font-size: 24px;
	line-height: 1;
	letter-spacing: -1.2px;
	color: var(--text);
	text-transform: lowercase;
}
.site-brand__wm-m {
	letter-spacing: -1.68px;
	font-weight: 500;
	font-style: normal;
}
.site-brand__wm-is {
	font-style: italic;
	font-weight: 600;
	letter-spacing: -1.2px;
}

.site-header__right {
	display: inline-flex;
	align-items: center;
	gap: 24px;
}

.site-nav {
	display: inline-flex;
	align-items: center;
	gap: 24px;
	font-family: 'Instrument Serif', Georgia, serif;
	font-style: italic;
	font-size: 20px;
	line-height: 1.5;
	color: var(--text);
}
.site-nav a {
	color: var(--text);
	transition: opacity 0.15s ease;
}
.site-nav a:hover { opacity: 0.7; }

.site-header__sep {
	width: 4px;
	height: 4px;
	background: rgba(255, 255, 255, 0.5);
	flex-shrink: 0;
}

.site-header__cta {
	font-family: 'Instrument Serif', Georgia, serif;
	font-style: italic;
	font-size: 20px;
	line-height: 1.5;
	color: var(--text);
	white-space: nowrap;
	transition: opacity 0.15s ease;
}
.site-header__cta:hover { opacity: 0.7; }

/* Hero — regras movidas pra sections/hero-refine.css (Figma 7294:2298) */

/* -------------------------------------------------------------------------
   Customer Logos (faixa Hero)
   ------------------------------------------------------------------------- */

.customer-logos {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 24px;
	align-items: flex-start;
}

.customer-logos__title {
	font-size: 18px;
	font-weight: 400;
	color: var(--text);
}

.customer-logos__grid {
	width: 100%;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	border: 1px solid var(--border-soft);
}

.customer-logos__cell {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 32px;
	border-right: 1px solid var(--border-soft);
	border-bottom: 1px solid var(--border-soft);
	min-height: 96px;
}
.customer-logos__cell:nth-child(5n) { border-right: 0; }

.customer-logos__cell img,
.customer-logos__cell svg {
	max-height: 32px;
	width: auto;
	max-width: 166px;
	opacity: 0.9;
	filter: brightness(0) invert(1);
}

/* customer-logos__pattern: rule canônica em sections/hero-refine.css (overrride com SVG real) */
.customer-logos__pattern {
	grid-column: 1 / -1;
	height: 64px;
}

/* -------------------------------------------------------------------------
   Responsive básico (desktop > tablet > mobile-fluid)
   Mobile pixel-perfect fica para skill mobile separada.
   ------------------------------------------------------------------------- */

@media (max-width: 980px) {
	.customer-logos__grid { grid-template-columns: repeat(3, 1fr); }
	.customer-logos__cell:nth-child(5n) { border-right: 1px solid var(--border-soft); }
	.customer-logos__cell:nth-child(3n) { border-right: 0; }
	.site-nav { display: none; }
}

@media (max-width: 640px) {
	.customer-logos__grid { grid-template-columns: repeat(2, 1fr); }
	.customer-logos__cell:nth-child(3n) { border-right: 1px solid var(--border-soft); }
	.customer-logos__cell:nth-child(2n) { border-right: 0; }
}
