/*!
 * Mousas — Base: tokens, reset, tipografia, grid, utilitários
 *
 * @author   Dante Testa <https://dantetesta.com.br>
 * @version  1.1.0
 * @since    2026-04-17 15:46:00 UTC-03
 */

/* =============================================================================
 * 0. Type stack — Architectural Confidence
 *    Switzer (body, ITF/OFL, self-hosted variable woff2)
 *    Poppins (display, OFL, carregada via Google Fonts em wp_head)
 * ========================================================================== */

@font-face {
	font-family: "Switzer";
	src: url("../fonts/Switzer-Variable.woff2") format("woff2-variations"),
	     url("../fonts/Switzer-Variable.woff2") format("woff2");
	font-weight: 100 900;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Switzer";
	src: url("../fonts/Switzer-VariableItalic.woff2") format("woff2-variations"),
	     url("../fonts/Switzer-VariableItalic.woff2") format("woff2");
	font-weight: 100 900;
	font-style: italic;
	font-display: swap;
}

/* =============================================================================
 * 1. Tokens (Custom Properties)
 * ========================================================================== */

:root {
	/* Cores — primárias */
	--mousas-primary:        #0A1E3F;
	--mousas-primary-600:    #102A5C;
	--mousas-primary-500:    #1B3C82;
	--mousas-primary-100:    #E7ECF6;

	/* Cores — secundárias */
	--mousas-secondary:      #1F2937;
	--mousas-secondary-600:  #374151;
	--mousas-secondary-400:  #6B7280;

	/* Cores — acento/ação */
	--mousas-accent:         #C9A961;
	--mousas-accent-700:     #A68945;
	--mousas-success:        #0F766E;
	--mousas-danger:         #DC2626;
	--mousas-warning:        #D97706;

	/* Cores — superfícies */
	--mousas-white:          #FFFFFF;
	--mousas-neutral-50:     #F8FAFC;
	--mousas-neutral-100:    #F4F6FA;
	--mousas-neutral-200:    #E5E7EB;
	--mousas-neutral-300:    #D1D5DB;
	--mousas-neutral-700:    #374151;
	--mousas-neutral-900:    #0B1426;

	/* Texto */
	--mousas-text:           var(--mousas-secondary);
	--mousas-text-strong:    var(--mousas-primary);
	--mousas-text-muted:     var(--mousas-secondary-400);
	--mousas-text-inverse:   var(--mousas-white);

	/* Tipografia — Architectural Confidence
	 * sans (body):    Switzer  → grotesque neutro, x-height alta, pt-BR friendly
	 * display:        Poppins  → geométrica, peso premium, leitura confortável em pt-BR
	 * mono:           JetBrains Mono
	 */
	--mousas-font-sans:      "Switzer", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
	--mousas-font-display:   "Poppins", "Switzer", ui-sans-serif, system-ui, sans-serif;
	--mousas-font-mono:      "JetBrains Mono", ui-monospace, "SF Mono", Consolas, Monaco, monospace;

	--mousas-fs-xs:    0.75rem;
	--mousas-fs-sm:    0.875rem;
	--mousas-fs-base:  1rem;
	--mousas-fs-lg:    1.125rem;
	--mousas-fs-xl:    1.25rem;
	--mousas-fs-2xl:   1.5rem;
	--mousas-fs-3xl:   1.875rem;
	--mousas-fs-4xl:   2.25rem;
	--mousas-fs-5xl:   3rem;
	--mousas-fs-6xl:   3.75rem;
	--mousas-fs-7xl:   4.5rem;

	--mousas-lh-tight:  1.15;
	--mousas-lh-snug:   1.3;
	--mousas-lh-normal: 1.55;
	--mousas-lh-relaxed: 1.7;

	/* Espaçamento (escala 8pt) */
	--mousas-space-2xs: 0.25rem;
	--mousas-space-xs:  0.5rem;
	--mousas-space-sm:  0.75rem;
	--mousas-space-md:  1rem;
	--mousas-space-lg:  1.5rem;
	--mousas-space-xl:  2rem;
	--mousas-space-2xl: 3rem;
	--mousas-space-3xl: 4.5rem;
	--mousas-space-4xl: 6rem;
	--mousas-space-5xl: 8rem;

	/* Raios */
	--mousas-radius-xs: 4px;
	--mousas-radius-sm: 8px;
	--mousas-radius-md: 12px;
	--mousas-radius-lg: 16px;
	--mousas-radius-xl: 24px;
	--mousas-radius-pill: 999px;

	/* Sombras (premium, baixa opacidade) */
	--mousas-shadow-sm:   0 1px 2px rgba(10, 30, 63, 0.06);
	--mousas-shadow-base: 0 4px 14px rgba(10, 30, 63, 0.08);
	--mousas-shadow-md:   0 8px 20px rgba(10, 30, 63, 0.10);
	--mousas-shadow-lg:   0 12px 32px rgba(10, 30, 63, 0.12);
	--mousas-shadow-xl:   0 24px 60px rgba(10, 30, 63, 0.16);

	/* Transições */
	--mousas-ease:        cubic-bezier(0.22, 1, 0.36, 1);
	--mousas-transition:  200ms var(--mousas-ease);
	--mousas-transition-slow: 320ms var(--mousas-ease);

	/* Layout */
	--mousas-container:   1280px;
	--mousas-container-narrow: 880px;
	--mousas-gutter:      clamp(1rem, 4vw, 2rem);
	--mousas-header-h:    72px;

	/* Z-index */
	--mousas-z-header:    50;
	--mousas-z-overlay:   60;
	--mousas-z-menu:      70;
	--mousas-z-float:     90;
	--mousas-z-toast:     100;
}

/* =============================================================================
 * 2. Reset moderno
 * ========================================================================== */

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

* { margin: 0; }

html {
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
	scroll-behavior: smooth;
	-webkit-tap-highlight-color: transparent;
	tab-size: 4;
	hanging-punctuation: first last;
}

body {
	min-height: 100svh;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	font-family: var(--mousas-font-sans);
	font-size: var(--mousas-fs-base);
	font-weight: 400;
	line-height: var(--mousas-lh-normal);
	color: var(--mousas-text);
	background: var(--mousas-white);
	font-synthesis: none;
	font-optical-sizing: auto;
	font-feature-settings: "ss01", "cv11";
}

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

input, button, textarea, select {
	font: inherit;
	color: inherit;
}

button { cursor: pointer; background: none; border: 0; padding: 0; }

a {
	color: var(--mousas-primary);
	text-decoration-color: color-mix(in oklab, var(--mousas-primary) 30%, transparent);
	text-underline-offset: 3px;
	transition: color var(--mousas-transition);
}

a:hover { color: var(--mousas-accent-700); }

p, li { text-wrap: pretty; }
h1, h2, h3, h4, h5, h6 { text-wrap: balance; }

#root, #__next { isolation: isolate; }

ul, ol { padding: 0; list-style-position: inside; }

/* =============================================================================
 * 3. Tipografia
 * ========================================================================== */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--mousas-font-display);
	font-weight: 600;
	line-height: var(--mousas-lh-tight);
	color: var(--mousas-text-strong);
	letter-spacing: -0.02em;
	font-optical-sizing: auto;
}

.mousas-display-1 {
	font-family: var(--mousas-font-display);
	font-size: clamp(2.5rem, 5.6vw, 4.75rem);
	font-weight: 600;
	line-height: 1.02;
	letter-spacing: -0.035em;
	color: var(--mousas-text-strong);
	text-wrap: balance;
}

.mousas-display-2 {
	font-family: var(--mousas-font-display);
	font-size: clamp(1.875rem, 4.2vw, 3.25rem);
	font-weight: 600;
	line-height: 1.08;
	letter-spacing: -0.028em;
	color: var(--mousas-text-strong);
	text-wrap: balance;
}

.mousas-display-3 {
	font-family: var(--mousas-font-display);
	font-size: clamp(1.5rem, 3.2vw, 2.375rem);
	font-weight: 600;
	line-height: 1.15;
	letter-spacing: -0.022em;
	color: var(--mousas-text-strong);
	text-wrap: balance;
}

.mousas-lead {
	font-family: var(--mousas-font-sans);
	font-size: clamp(var(--mousas-fs-lg), 1.2vw, var(--mousas-fs-xl));
	font-weight: 400;
	line-height: var(--mousas-lh-relaxed);
	color: var(--mousas-secondary-600);
	max-width: 62ch;
	letter-spacing: -0.005em;
}

.mousas-eyebrow {
	font-family: var(--mousas-font-sans);
	font-size: var(--mousas-fs-xs);
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mousas-accent-700);
}

/* Numerais tabulares para preços, contadores, KPIs e tabelas. */
.mousas-num,
.mousas-price,
.mousas-kpi,
table tbody td:has(> .mousas-num) {
	font-variant-numeric: tabular-nums;
	font-feature-settings: "tnum", "ss02";
}

small { font-size: var(--mousas-fs-sm); color: var(--mousas-text-muted); }

.mousas-content { max-width: 68ch; line-height: var(--mousas-lh-relaxed); }
.mousas-content h2 { margin-top: var(--mousas-space-xl); margin-bottom: var(--mousas-space-md); }
.mousas-content h3 { margin-top: var(--mousas-space-lg); margin-bottom: var(--mousas-space-sm); }
.mousas-content p + p { margin-top: var(--mousas-space-md); }
.mousas-content ul, .mousas-content ol { margin: var(--mousas-space-md) 0; padding-left: 1.25rem; list-style-position: outside; }

/* =============================================================================
 * 4. Layout utilitário
 * ========================================================================== */

.mousas-container {
	width: 100%;
	max-width: var(--mousas-container);
	margin-inline: auto;
	padding-inline: var(--mousas-gutter);
}

.mousas-container--narrow { max-width: var(--mousas-container-narrow); }

.mousas-section {
	padding-block: clamp(3rem, 8vw, var(--mousas-space-4xl));
}

.mousas-section--tight { padding-block: clamp(2rem, 5vw, 3rem); }
.mousas-section--center { text-align: center; }
.mousas-section--surface { background: var(--mousas-neutral-100); }
.mousas-section--dark {
	background: var(--mousas-primary);
	color: var(--mousas-text-inverse);
}
.mousas-section--dark h1,
.mousas-section--dark h2,
.mousas-section--dark h3 { color: var(--mousas-white); }

.mousas-stack { display: flex; flex-direction: column; gap: var(--mousas-space-md); }
.mousas-stack > .mousas-eyebrow + * { margin-top: calc(-1 * var(--mousas-space-xs)); }
.mousas-stack--center { align-items: center; text-align: center; }
.mousas-stack--gap-lg { gap: var(--mousas-space-xl); }
.mousas-stack--gap-2xl { gap: var(--mousas-space-2xl); }

.mousas-grid { display: grid; gap: var(--mousas-space-lg); }
.mousas-gap-sm { gap: var(--mousas-space-sm); }
.mousas-gap-md { gap: var(--mousas-space-md); }
.mousas-gap-lg { gap: var(--mousas-space-lg); }
.mousas-gap-xl { gap: var(--mousas-space-xl); }

.mousas-grid--cols-2 { grid-template-columns: 1fr; }
.mousas-grid--cols-3 { grid-template-columns: 1fr; }
.mousas-grid--cols-4 { grid-template-columns: 1fr; }

@media (min-width: 640px) {
	.mousas-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
	.mousas-grid--cols-3 { grid-template-columns: repeat(2, 1fr); }
	.mousas-grid--cols-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
	.mousas-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
	.mousas-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }
}

/* =============================================================================
 * 5. Utilitários
 * ========================================================================== */

.mousas-py-xs  { padding-block: var(--mousas-space-xs); }
.mousas-py-sm  { padding-block: var(--mousas-space-sm); }
.mousas-py-md  { padding-block: var(--mousas-space-md); }
.mousas-py-lg  { padding-block: var(--mousas-space-lg); }
.mousas-py-xl  { padding-block: var(--mousas-space-xl); }
.mousas-py-2xl { padding-block: var(--mousas-space-2xl); }
.mousas-py-3xl { padding-block: var(--mousas-space-3xl); }

.mousas-mb-xs  { margin-bottom: var(--mousas-space-xs); }
.mousas-mb-sm  { margin-bottom: var(--mousas-space-sm); }
.mousas-mb-md  { margin-bottom: var(--mousas-space-md); }
.mousas-mb-lg  { margin-bottom: var(--mousas-space-lg); }
.mousas-mb-xl  { margin-bottom: var(--mousas-space-xl); }

.mousas-text-center { text-align: center; }
.mousas-text-muted  { color: var(--mousas-text-muted); }
.mousas-text-strong { color: var(--mousas-text-strong); }
.mousas-text-accent { color: var(--mousas-accent-700); }

.mousas-hidden { display: none !important; }
.mousas-visually-hidden,
.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	margin: -1px; padding: 0;
	overflow: hidden; clip: rect(0 0 0 0);
	white-space: nowrap; border: 0;
}

.mousas-divider {
	height: 1px;
	background: var(--mousas-neutral-200);
	border: 0;
}

/* =============================================================================
 * 6. Reduced motion
 * ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* =============================================================================
 * 7. Page hero padrão
 * ========================================================================== */

.mousas-page-hero {
	padding-block: clamp(4rem, 10vw, 7rem) clamp(2rem, 5vw, 4rem);
	background: linear-gradient(180deg, var(--mousas-neutral-100) 0%, var(--mousas-white) 100%);
	border-bottom: 1px solid var(--mousas-neutral-200);
}

/*
 * Limita a largura de leitura apenas dos FILHOS do stack (texto/eyebrow/lead),
 * preservando o container full-width. Sem isso, quando o elemento tem ambas
 * as classes (mousas-container + mousas-stack), o max-width:60ch vencia a
 * especificidade do container e centralizava o hero inteiro.
 */
.mousas-page-hero .mousas-stack > * { max-width: 60ch; }
.mousas-page-hero .mousas-stack > .mousas-cta-row,
.mousas-page-hero .mousas-stack > .mousas-breadcrumb { max-width: none; }

.mousas-empty { display: grid; place-items: center; text-align: center; padding-block: var(--mousas-space-3xl); gap: var(--mousas-space-md); }
