/* ============================================================
   ASESORÍA RATÓN — COMPONENTES REUSABLES
   ============================================================ */

/* — HEADER — */
.raton-header {
	position: sticky;
	top: 0;
	z-index: var(--z-sticky);
	background: rgba(240, 235, 224, 0.78);
	backdrop-filter: blur(14px) saturate(150%);
	-webkit-backdrop-filter: blur(14px) saturate(150%);
	border-bottom: 1px solid var(--color-line);
	transition: background var(--t-mid), border-color var(--t-mid);
}
.raton-header.is-scrolled {
	background: rgba(248, 244, 236, 0.92);
}
.raton-header__inner {
	max-width: var(--container-wide);
	margin: 0 auto;
	padding: var(--s-4) var(--gutter);
	display: flex;
	align-items: center;
	gap: var(--s-6);
}

.raton-brand {
	display: inline-flex;
	align-items: center;
	gap: var(--s-3);
	color: var(--color-fg);
}
.raton-brand:hover { color: var(--color-primary); }
.raton-brand__mark {
	width: 44px;
	height: 44px;
	display: block;
	flex-shrink: 0;
}
.raton-brand__mark svg { width: 100%; height: 100%; }
.raton-brand__type {
	display: flex;
	flex-direction: column;
	line-height: 1;
}
.raton-brand__name {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.05rem;
	letter-spacing: var(--tracking-tight);
}
.raton-brand__sub {
	font-size: 0.68rem;
	color: var(--color-fg-mute);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	margin-top: 4px;
}

.raton-nav {
	flex: 1;
	display: flex;
	justify-content: center;
}
.raton-nav__list {
	display: flex;
	gap: var(--s-6);
	align-items: center;
}
.raton-nav__link, .raton-nav__list a {
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--color-fg);
	letter-spacing: 0.01em;
	position: relative;
	padding: 0.3em 0;
}
.raton-nav__link::after,
.raton-nav__list a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -2px;
	height: 1px;
	background: var(--color-primary);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--t-mid);
}
.raton-nav__link:hover::after,
.raton-nav__list a:hover::after,
.raton-nav .current-menu-item > a::after { transform: scaleX(1); }

.raton-header__aside {
	display: flex;
	align-items: center;
	gap: var(--s-4);
}

.raton-lang {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	font-size: 0.78rem;
	letter-spacing: var(--tracking-wide);
}
.raton-lang__btn {
	color: var(--color-fg-mute);
	padding: 0.2em 0.3em;
	font-weight: 600;
}
.raton-lang__btn.is-active { color: var(--color-primary); }
.raton-lang__sep { color: var(--color-line-strong); }

.raton-burger {
	display: none;
	background: none;
	border: none;
	width: 32px;
	height: 32px;
	padding: 0;
	cursor: pointer;
	position: relative;
}
.raton-burger span {
	display: block;
	height: 1.5px;
	background: var(--color-fg);
	margin: 7px 0;
	transition: transform var(--t-mid), opacity var(--t-fast);
}
.raton-burger.is-open span:nth-child(1) { transform: translateY(8.5px) rotate(45deg); }
.raton-burger.is-open span:nth-child(2) { opacity: 0; }
.raton-burger.is-open span:nth-child(3) { transform: translateY(-8.5px) rotate(-45deg); }

.raton-drawer {
	position: fixed;
	inset: 64px 0 0 0;
	background: var(--color-bg-paper);
	z-index: var(--z-drawer);
	padding: var(--s-7) var(--gutter);
	transform: translateY(-100%);
	transition: transform var(--t-mid);
}
.raton-drawer:not([hidden]) { transform: translateY(0); }
.raton-drawer__nav { display: flex; flex-direction: column; gap: var(--s-5); }
.raton-drawer__nav .raton-nav__list { flex-direction: column; align-items: flex-start; gap: var(--s-4); }
.raton-drawer__nav .raton-nav__list a {
	font-family: var(--font-display);
	font-size: var(--fs-40);
	color: var(--color-fg);
	letter-spacing: var(--tracking-tight);
}

@media (max-width: 880px) {
	.raton-nav { display: none; }
	.raton-header__aside .raton-btn { display: none; }
	.raton-burger { display: block; }
	.raton-brand__sub { display: none; }
}

/* — BOTONES — */
.raton-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6em;
	padding: 0.85em 1.4em;
	font-family: var(--font-body);
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
	background: var(--color-fg);
	color: var(--color-bg-paper);
	border: 1px solid transparent;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: transform var(--t-fast), background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
	position: relative;
	overflow: hidden;
	line-height: 1;
}
.raton-btn:hover { transform: translateY(-1px); }
.raton-btn:active { transform: translateY(0); }

.raton-btn--primary {
	background: var(--color-primary);
	color: var(--color-bg-paper);
}
.raton-btn--primary:hover {
	background: var(--color-primary-deep);
	color: var(--color-bg-paper);
	box-shadow: var(--shadow-md);
}
.raton-btn--ghost {
	background: transparent;
	color: var(--color-fg);
	border-color: var(--color-line-strong);
}
.raton-btn--ghost:hover {
	background: var(--color-fg);
	color: var(--color-bg-paper);
	border-color: var(--color-fg);
}
.raton-btn--lg { padding: 1.05em 1.6em; font-size: 1rem; }
.raton-btn--sm { padding: 0.65em 1.1em; font-size: 0.86rem; }

.raton-btn__arrow {
	display: inline-block;
	transition: transform var(--t-fast);
}
.raton-btn:hover .raton-btn__arrow { transform: translateX(4px); }

/* — FAB WhatsApp — */
.raton-fab {
	position: fixed;
	bottom: clamp(1rem, 3vw, 2rem);
	right: clamp(1rem, 3vw, 2rem);
	z-index: var(--z-fab);
	width: 60px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-primary);
	color: var(--color-bg-paper);
	border-radius: 50%;
	box-shadow: var(--shadow-lg);
	transition: transform var(--t-mid), background var(--t-fast);
}
.raton-fab:hover {
	transform: scale(1.05);
	background: var(--color-primary-deep);
	color: var(--color-bg-paper);
}
.raton-fab__icon { width: 28px; height: 28px; position: relative; z-index: 2; }
.raton-fab__ring {
	position: absolute;
	inset: -2px;
	border: 1px solid var(--color-primary);
	border-radius: 50%;
	animation: raton-pulse 2.6s var(--ease-out) infinite;
	pointer-events: none;
}
@keyframes raton-pulse {
	0%   { transform: scale(1);   opacity: 0.7; }
	80%  { transform: scale(1.8); opacity: 0; }
	100% { transform: scale(1.8); opacity: 0; }
}

/* — FOOTER — */
.raton-footer {
	background: var(--color-secondary-deep);
	color: var(--color-fg-inverse);
	padding: var(--s-9) 0 var(--s-5);
	position: relative;
}
.raton-footer::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
}
.raton-footer__inner {
	max-width: var(--container-wide);
	margin: 0 auto;
	padding: 0 var(--gutter);
	display: grid;
	gap: var(--s-7);
	grid-template-columns: 1.2fr 2fr;
}
.raton-footer__brand {
	display: flex;
	flex-direction: column;
	gap: var(--s-4);
}
.raton-footer__monogram {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 80px;
	height: 80px;
	background: var(--color-primary);
	color: var(--color-bg-paper);
	font-family: var(--font-display);
	font-size: 2.6rem;
	font-weight: 700;
	letter-spacing: -2px;
}
.raton-footer__about {
	font-size: 0.95rem;
	color: rgba(240, 235, 224, 0.7);
	max-width: 38ch;
	line-height: var(--lh-normal);
}

.raton-footer__cols {
	display: grid;
	gap: var(--s-7);
	grid-template-columns: repeat(3, 1fr);
}
.raton-footer__col-title {
	font-family: var(--font-body);
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: var(--tracking-mega);
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0 0 var(--s-3);
}
.raton-footer__col-list { display: flex; flex-direction: column; gap: var(--s-2); }
.raton-footer__col-list a,
.raton-footer__address a {
	color: rgba(240, 235, 224, 0.85);
	font-size: 0.95rem;
}
.raton-footer__col-list a:hover,
.raton-footer__address a:hover { color: var(--color-accent); }
.raton-footer__address {
	font-style: normal;
	line-height: var(--lh-normal);
	color: rgba(240, 235, 224, 0.85);
	font-size: 0.95rem;
}

.raton-footer__bottom {
	grid-column: 1 / -1;
	margin-top: var(--s-7);
	padding-top: var(--s-5);
	border-top: 1px solid var(--color-line-inverse);
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-4);
	justify-content: space-between;
	align-items: center;
	font-size: 0.82rem;
	color: rgba(240, 235, 224, 0.55);
}
.raton-legal__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-4);
}
.raton-legal__list a {
	color: rgba(240, 235, 224, 0.55);
	font-size: 0.82rem;
}
.raton-legal__list a:hover { color: var(--color-accent); }

@media (max-width: 880px) {
	.raton-footer__inner { grid-template-columns: 1fr; }
	.raton-footer__cols  { grid-template-columns: 1fr; gap: var(--s-5); }
}

/* — GUILLOCHÉ — */
.raton-guilloche {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
	opacity: 0.85;
}
.raton-guilloche svg { width: 100%; height: 100%; }

/* — STRIP / FAJA AUTORIDAD — */
.raton-strip {
	background: var(--color-primary);
	color: var(--color-bg-paper);
	padding: var(--s-7) 0;
	position: relative;
	overflow: hidden;
}
.raton-strip::after {
	content: "";
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(
		135deg,
		transparent 0,
		transparent 80px,
		rgba(248, 244, 236, 0.04) 80px,
		rgba(248, 244, 236, 0.04) 81px
	);
	pointer-events: none;
}
.raton-strip__list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--s-5);
	position: relative;
	z-index: 2;
}
.raton-strip__item {
	display: flex;
	flex-direction: column;
	gap: var(--s-2);
	padding-right: var(--s-5);
	border-right: 1px solid rgba(248, 244, 236, 0.18);
}
.raton-strip__item:last-child { border-right: none; }
.raton-strip__num {
	font-family: var(--font-display);
	font-size: var(--fs-64);
	font-weight: 600;
	line-height: 1;
	letter-spacing: var(--tracking-tight);
}
.raton-strip__num--word {
	font-style: italic;
	font-weight: 500;
}
.raton-strip__label {
	font-size: 0.78rem;
	letter-spacing: var(--tracking-mega);
	text-transform: uppercase;
	color: rgba(248, 244, 236, 0.7);
}
@media (max-width: 720px) {
	.raton-strip__list { grid-template-columns: repeat(2, 1fr); gap: var(--s-5); }
	.raton-strip__item { border-right: none; padding-right: 0; }
}

/* — SERVICE CARD — */
.raton-service-card {
	display: flex;
	flex-direction: column;
	gap: var(--s-4);
	padding: var(--s-6);
	background: var(--color-bg-paper);
	border: 1px solid var(--color-line);
	color: var(--color-fg);
	position: relative;
	overflow: hidden;
	transition: transform var(--t-mid), border-color var(--t-mid), background var(--t-mid);
	min-height: 320px;
}
.raton-service-card:hover {
	transform: translateY(-4px);
	border-color: var(--color-primary);
	color: var(--color-fg);
}
.raton-service-card::before {
	content: "";
	position: absolute;
	left: 0; top: 0;
	width: 0;
	height: 2px;
	background: var(--color-primary);
	transition: width var(--t-mid);
}
.raton-service-card:hover::before { width: 100%; }
.raton-service-card__num {
	font-family: var(--font-display);
	font-size: var(--fs-40);
	color: var(--color-secondary);
	line-height: 1;
	transition: transform var(--t-mid), color var(--t-mid);
}
.raton-service-card:hover .raton-service-card__num {
	color: var(--color-primary);
	transform: translateX(-3px);
}
.raton-service-card__icon {
	position: absolute;
	top: var(--s-5);
	right: var(--s-5);
	width: 60px;
	height: 60px;
	color: var(--color-secondary-soft);
	opacity: 0.5;
	transition: opacity var(--t-mid), color var(--t-mid);
}
.raton-service-card:hover .raton-service-card__icon {
	opacity: 0.9;
	color: var(--color-primary);
}
.raton-service-card__icon svg { width: 100%; height: 100%; }
.raton-service-card__title {
	font-size: var(--fs-28);
	color: var(--color-fg);
	margin: 0;
}
.raton-service-card__lead {
	font-size: 0.96rem;
	color: var(--color-fg-soft);
	line-height: var(--lh-normal);
	margin: 0;
	flex: 1;
}
.raton-service-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	font-size: 0.84rem;
	font-weight: 600;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--color-primary);
	margin-top: auto;
}
.raton-service-card__cta span { transition: transform var(--t-fast); }
.raton-service-card:hover .raton-service-card__cta span { transform: translateX(4px); }

.raton-service-card--mini { min-height: 220px; padding: var(--s-5); }
.raton-service-card--mini .raton-service-card__title { font-size: var(--fs-22); }

/* — FORM — */
.raton-form { display: flex; flex-direction: column; gap: var(--s-4); }
.raton-form__row { display: grid; gap: var(--s-4); grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) { .raton-form__row { grid-template-columns: 1fr; } }
.raton-form__field { display: flex; flex-direction: column; gap: var(--s-2); }
.raton-form__label {
	font-size: 0.78rem;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--color-fg-soft);
	font-weight: 600;
}
.raton-form__input {
	background: var(--color-bg-paper);
	border: 1px solid var(--color-line-strong);
	padding: 0.85em 1em;
	font-size: 1rem;
	color: var(--color-fg);
	border-radius: var(--radius-sm);
	transition: border-color var(--t-fast), box-shadow var(--t-fast);
	font-family: inherit;
}
.raton-form__input:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(122, 31, 43, 0.15);
}
textarea.raton-form__input { resize: vertical; min-height: 120px; }
select.raton-form__input {
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--color-fg-soft) 50%),
	                  linear-gradient(135deg, var(--color-fg-soft) 50%, transparent 50%);
	background-position: calc(100% - 18px) center, calc(100% - 12px) center;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 2.5em;
}
.raton-form__consent {
	display: flex;
	gap: 0.6em;
	align-items: flex-start;
	font-size: 0.86rem;
	color: var(--color-fg-soft);
	line-height: var(--lh-normal);
}
.raton-form__consent input { margin-top: 0.3em; flex-shrink: 0; }
.raton-form__hp { position: absolute !important; left: -9999px !important; }
.raton-form__actions { margin-top: var(--s-2); }
.raton-form__feedback {
	margin-top: var(--s-3);
	font-size: 0.95rem;
	min-height: 1.5em;
	transition: color var(--t-fast);
}
.raton-form__feedback.is-success { color: var(--color-secondary); font-weight: 600; }
.raton-form__feedback.is-error   { color: var(--color-primary);  font-weight: 600; }
.raton-form__feedback.is-sending { color: var(--color-fg-mute); }

/* — CTA FOOTER BLOCK — */
.raton-cta-footer {
	background: var(--color-bg-deep);
	padding: var(--s-9) 0;
	border-top: 1px solid var(--color-line);
	position: relative;
	overflow: hidden;
}
.raton-cta-footer::after {
	content: "AR";
	position: absolute;
	right: -3vw;
	bottom: -8vw;
	font-family: var(--font-display);
	font-size: var(--fs-200);
	font-weight: 700;
	color: var(--color-secondary);
	opacity: 0.06;
	pointer-events: none;
	letter-spacing: -0.06em;
	line-height: 0.8;
}
.raton-cta-footer__inner {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--gutter);
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--s-7);
	align-items: end;
	position: relative;
	z-index: 2;
}
.raton-cta-footer__title { font-size: var(--fs-64); margin: 0 0 var(--s-3); }
.raton-cta-footer__lead { color: var(--color-fg-soft); max-width: 48ch; font-size: var(--fs-18); }
.raton-cta-footer__actions { display: flex; flex-direction: column; gap: var(--s-3); align-items: flex-start; }
@media (max-width: 880px) {
	.raton-cta-footer__inner { grid-template-columns: 1fr; gap: var(--s-5); }
}

/* — FAQ — */
.raton-faq { display: flex; flex-direction: column; gap: var(--s-1); }
.raton-faq__item {
	border-bottom: 1px solid var(--color-line);
	padding: var(--s-4) 0;
}
.raton-faq__q {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--s-4);
	cursor: pointer;
	list-style: none;
	font-family: var(--font-display);
	font-size: var(--fs-22);
	font-weight: 500;
	color: var(--color-fg);
	letter-spacing: var(--tracking-tight);
}
.raton-faq__q::-webkit-details-marker { display: none; }
.raton-faq__icon {
	display: inline-block;
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	position: relative;
}
.raton-faq__icon::before,
.raton-faq__icon::after {
	content: "";
	position: absolute;
	background: var(--color-secondary);
	left: 50%;
	top: 50%;
	transition: transform var(--t-mid);
}
.raton-faq__icon::before { width: 14px; height: 1.5px; transform: translate(-50%, -50%); }
.raton-faq__icon::after  { width: 1.5px; height: 14px; transform: translate(-50%, -50%); }
.raton-faq__item[open] .raton-faq__icon::after { transform: translate(-50%, -50%) scaleY(0); }
.raton-faq__a {
	padding-top: var(--s-3);
	color: var(--color-fg-soft);
	font-size: var(--fs-18);
	line-height: var(--lh-normal);
	max-width: 64ch;
}

/* — TICK MARK — */
.raton-tick {
	display: inline-block;
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	border: 1px solid var(--color-primary);
	position: relative;
	margin-top: 4px;
}
.raton-tick::after {
	content: "";
	position: absolute;
	left: 4px;
	top: 1px;
	width: 6px;
	height: 12px;
	border-right: 1.5px solid var(--color-primary);
	border-bottom: 1.5px solid var(--color-primary);
	transform: rotate(45deg);
}

/* — CRUMBS — */
.raton-crumbs {
	display: flex;
	gap: 0.6em;
	font-size: 0.78rem;
	letter-spacing: var(--tracking-wide);
	color: var(--color-fg-mute);
	margin-bottom: var(--s-4);
	flex-wrap: wrap;
}
.raton-crumbs a { color: var(--color-fg-mute); }
.raton-crumbs a:hover { color: var(--color-primary); }
.raton-crumbs > span:last-child { color: var(--color-fg); }
