/* =========================================================================
 *  TANATOINFO · v2.0.0
 *  Directorio funerario independiente — País Vasco + Navarra
 *  Dirección estética: editorial sobrio. Verde pino dominante, papel cálido,
 *  latón discreto, acento arcilla. Tipografía Fraunces (display) + Mulish (texto).
 *  Texturas: grano sutil + curvas de nivel (colinas verdes de Euskadi/Navarra).
 * ====================================================================== */

:root {
	/* ---- Paleta ---- */
	--ti-pine:        #163a30;   /* verde pino — color marca dominante */
	--ti-pine-deep:   #0e271f;   /* verde profundo para degradados/fondos oscuros */
	--ti-pine-700:    #1d473b;
	--ti-sage:        #5e8273;   /* verde salvia, acentos suaves */
	--ti-sage-pale:   #e4ece7;   /* verde papel muy claro */
	--ti-brass:       #c2a878;   /* latón cálido — acento de lujo discreto */
	--ti-brass-deep:  #9a7f54;
	--ti-gold:        #c2a878;   /* alias retro-compat (home original) */
	--ti-gold-dark:   #9a7f54;   /* alias retro-compat */
	--ti-clay:        #b06a4f;   /* arcilla / terracota — calidez emocional */
	--ti-clay-soft:   #c98b72;

	--ti-paper:       #f5efe3;   /* fondo papel cálido */
	--ti-paper-2:     #efe7d6;   /* papel ligeramente más intenso (bandas) */
	--ti-card:        #fcf9f2;   /* superficie de tarjeta */
	--ti-white:       #ffffff;

	--ti-ink:         #1b2420;   /* texto principal */
	--ti-ink-soft:    #4b574f;   /* texto secundario */
	--ti-ink-mute:    #7d877f;   /* texto terciario */
	--ti-line:        #ddd3c1;   /* líneas sobre papel */
	--ti-line-soft:   #ece4d4;
	--ti-on-dark:     #e9efe9;
	--ti-on-dark-mute:#a9bcb1;

	/* ---- Tipografía ---- */
	--ti-display: "Fraunces", "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--ti-body:    "Mulish", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	/* ---- Espaciado ---- */
	--s1: .25rem;  --s2: .5rem;  --s3: .75rem;  --s4: 1rem;  --s5: 1.5rem;
	--s6: 2rem;    --s7: 3rem;   --s8: 4rem;    --s9: 6rem;  --s10: 8rem;

	/* ---- Radios ---- */
	--r-sm: 6px; --r: 12px; --r-lg: 20px; --r-xl: 28px; --r-pill: 999px;

	/* ---- Sombras ---- */
	--sh-sm: 0 1px 2px rgba(14,39,31,.05), 0 2px 6px rgba(14,39,31,.05);
	--sh:    0 6px 18px rgba(14,39,31,.08), 0 18px 40px rgba(14,39,31,.06);
	--sh-lg: 0 20px 60px rgba(14,39,31,.14);

	/* ---- Layout ---- */
	--container: 1200px;
	--container-wide: 1320px;

	/* ---- Curvas de nivel (motivo de fondo) ---- */
	--contours: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='600' viewBox='0 0 1200 600'%3E%3Cg fill='none' stroke='%23163a30' stroke-opacity='0.05' stroke-width='1.5'%3E%3Cpath d='M-50 480 C 200 420 400 520 650 460 S 1050 380 1260 440'/%3E%3Cpath d='M-50 520 C 220 470 420 560 660 500 S 1060 430 1260 485'/%3E%3Cpath d='M-50 440 C 180 370 390 470 640 410 S 1040 330 1260 395'/%3E%3Cpath d='M-50 560 C 240 520 440 600 680 545 S 1070 480 1260 530'/%3E%3Cpath d='M-50 400 C 160 330 380 420 630 360 S 1030 285 1260 350'/%3E%3C/g%3E%3C/svg%3E");

	/* ---- Grano (textura) ---- */
	--grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
}

/* ============================ Reset / base ============================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--ti-body);
	font-size: 17px;
	line-height: 1.7;
	color: var(--ti-ink);
	background: var(--ti-paper);
	background-image: var(--contours);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-attachment: fixed;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-variant-ligatures: common-ligatures;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--ti-pine); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--ti-brass-deep); }

h1, h2, h3, h4 {
	font-family: var(--ti-display);
	font-weight: 460;
	line-height: 1.12;
	color: var(--ti-pine);
	margin: 0 0 var(--s4);
	letter-spacing: -.015em;
	font-optical-sizing: auto;
}
h1 { font-size: clamp(2.4rem, 5.2vw, 4.1rem); font-weight: 420; }
h2 { font-size: clamp(1.9rem, 3.4vw, 2.8rem); }
h3 { font-size: clamp(1.3rem, 2.2vw, 1.65rem); font-weight: 520; }
h4 { font-size: 1.12rem; font-weight: 560; }
p  { margin: 0 0 var(--s4); }
ul, ol { padding-left: 1.3rem; }
hr { border: 0; border-top: 1px solid var(--ti-line); margin: var(--s6) 0; }
strong { font-weight: 700; color: var(--ti-ink); }
:focus-visible { outline: 3px solid var(--ti-brass); outline-offset: 3px; border-radius: 3px; }
::selection { background: var(--ti-pine); color: var(--ti-paper); }

/* ============================ Layout helpers =========================== */
.ti-container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.ti-container--wide { max-width: var(--container-wide); }
.ti-main { display: block; }
.ti-section { padding: var(--s9) 0; position: relative; }
.ti-section--tight { padding: var(--s7) 0; }
.ti-section--paper2 { background: var(--ti-paper-2); }
.ti-section--sage { background: var(--ti-sage-pale); }
.ti-section--cream { background: var(--ti-sage-pale); }  /* alias retro-compat (home original) */
.ti-section--bone  { background: var(--ti-paper-2); }    /* alias retro-compat */
.ti-section--dark {
	background:
		radial-gradient(120% 140% at 80% -10%, rgba(194,168,120,.16), transparent 55%),
		linear-gradient(160deg, var(--ti-pine) 0%, var(--ti-pine-deep) 100%);
	color: var(--ti-on-dark);
}
.ti-section--dark h1, .ti-section--dark h2, .ti-section--dark h3 { color: var(--ti-white); }
.ti-text-center { text-align: center; }
.ti-sr-only {
	position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ============================ Eyebrow / kicker ========================= */
.ti-kicker, .ti-hero__kicker {
	display: inline-flex; align-items: center; gap: .55rem;
	font-family: var(--ti-body);
	font-size: .76rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
	color: var(--ti-brass-deep);
}
.ti-kicker::before, .ti-hero__kicker::before {
	content: ""; width: 26px; height: 1px; background: currentColor; opacity: .7;
}
.ti-section__head { max-width: 64ch; margin: 0 auto var(--s7); text-align: center; }
.ti-section__head .ti-kicker { margin-bottom: var(--s3); }
.ti-section__head h2 { margin: 0 0 var(--s3); }
.ti-section__head p { color: var(--ti-ink-soft); font-size: 1.08rem; margin: 0; }
.ti-section__head--left { text-align: left; margin-left: 0; }
.ti-kicker--gold { color: var(--ti-brass); }
.ti-bento__kicker { display: inline-flex; align-items: center; gap: .5rem; font-size: .78rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--ti-brass); margin-bottom: var(--s3); }
.ti-bento__kicker svg { stroke: var(--ti-brass); }

/* ============================ Botones ================================== */
.ti-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
	font-family: var(--ti-body); font-weight: 700; font-size: .98rem;
	padding: .95rem 1.7rem; border-radius: var(--r-pill);
	border: 1.5px solid transparent; cursor: pointer; transition: all .22s ease;
	letter-spacing: .01em; text-align: center;
}
.ti-btn--primary { background: var(--ti-pine); color: var(--ti-white); }
.ti-btn--primary:hover { background: var(--ti-pine-deep); color: #fff; transform: translateY(-2px); box-shadow: var(--sh); }
.ti-btn--gold { background: var(--ti-brass); color: var(--ti-pine-deep); }
.ti-btn--gold:hover { background: #d2bb91; color: var(--ti-pine-deep); transform: translateY(-2px); box-shadow: var(--sh); }
.ti-btn--ghost { background: transparent; color: var(--ti-pine); border-color: var(--ti-line); }
.ti-btn--ghost:hover { border-color: var(--ti-pine); color: var(--ti-pine); background: rgba(22,58,48,.04); }
.ti-btn--on-dark { color: #fff; border-color: rgba(255,255,255,.55); }
.ti-btn--on-dark:hover { color: #fff; border-color: #fff; background: rgba(255,255,255,.1); }
.ti-btn--clay { background: var(--ti-clay); color: #fff; }
.ti-btn--clay:hover { background: #9c5a41; color:#fff; transform: translateY(-2px); box-shadow: var(--sh); }
.ti-btn--block { width: 100%; }
.ti-btn--sm { padding: .6rem 1.1rem; font-size: .9rem; }

/* ============================ HEADER =================================== */
.ti-header {
	position: sticky; top: 0; z-index: 200;
	background: rgba(245,239,227,.86);
	backdrop-filter: saturate(140%) blur(12px);
	-webkit-backdrop-filter: saturate(140%) blur(12px);
	border-bottom: 1px solid var(--ti-line-soft);
}
.ti-header__inner { display: flex; align-items: center; justify-content: space-between; height: 78px; }
.ti-logo { display: inline-flex; align-items: center; gap: .65rem; font-family: var(--ti-display); font-weight: 560; font-size: 1.42rem; color: var(--ti-pine); letter-spacing: -.02em; }
.ti-logo:hover { color: var(--ti-pine); }
.ti-logo__mark {
	width: 38px; height: 38px; flex-shrink: 0;
	display: grid; place-items: center;
	background: var(--ti-pine); color: var(--ti-brass);
	border-radius: 10px; font-family: var(--ti-display); font-weight: 600; font-size: 1.25rem;
	box-shadow: inset 0 0 0 1px rgba(194,168,120,.35);
}
.ti-logo__mark svg { width: 22px; height: 22px; }

/* Navegación desktop */
.ti-nav__list { list-style: none; display: flex; align-items: center; gap: .35rem; margin: 0; padding: 0; }
.ti-nav__list > li { position: relative; }
.ti-nav__list > li > a {
	display: inline-flex; align-items: center; gap: .3rem;
	padding: .55rem .85rem; border-radius: var(--r-pill);
	font-weight: 600; font-size: .96rem; color: var(--ti-ink);
}
.ti-nav__list > li > a:hover { color: var(--ti-pine); background: rgba(22,58,48,.06); }
.ti-nav__sub {
	position: absolute; top: calc(100% + 10px); left: 0; min-width: 230px;
	list-style: none; margin: 0; padding: .5rem;
	background: var(--ti-card); border: 1px solid var(--ti-line-soft);
	border-radius: var(--r-lg); box-shadow: var(--sh-lg);
	opacity: 0; visibility: hidden; transform: translateY(8px); transition: all .2s ease; z-index: 50;
}
.ti-nav__list > li:hover .ti-nav__sub,
.ti-nav__list > li:focus-within .ti-nav__sub { opacity: 1; visibility: visible; transform: translateY(0); }
.ti-nav__sub li a { display: block; padding: .6rem .8rem; border-radius: var(--r-sm); font-size: .92rem; font-weight: 500; color: var(--ti-ink-soft); }
.ti-nav__sub li a:hover { background: var(--ti-sage-pale); color: var(--ti-pine); }
.ti-nav__cta { margin-left: .5rem; }

/* Hamburguesa */
.ti-burger { display: none; width: 46px; height: 46px; border: 1px solid var(--ti-line); border-radius: 10px; background: transparent; cursor: pointer; padding: 0; flex-direction: column; gap: 5px; align-items: center; justify-content: center; }
.ti-burger span { width: 22px; height: 2px; background: var(--ti-pine); border-radius: 2px; transition: all .25s ease; }
.is-open .ti-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.is-open .ti-burger span:nth-child(2) { opacity: 0; }
.is-open .ti-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================ Breadcrumbs ============================== */
.ti-breadcrumbs { background: transparent; border-bottom: 1px solid var(--ti-line-soft); }
.ti-breadcrumbs ol {
	max-width: var(--container); margin: 0 auto; padding: .85rem 24px;
	list-style: none; display: flex; flex-wrap: wrap; gap: .4rem; font-size: .85rem; color: var(--ti-ink-mute);
}
.ti-breadcrumbs li { display: flex; align-items: center; gap: .4rem; }
.ti-breadcrumbs li:not(:last-child)::after { content: "›"; color: var(--ti-line); margin-left: .2rem; }
.ti-breadcrumbs a { color: var(--ti-ink-soft); font-weight: 600; }
.ti-breadcrumbs a:hover { color: var(--ti-brass-deep); }
.ti-breadcrumbs [aria-current="page"] { color: var(--ti-pine); font-weight: 600; }

/* ============================ HERO ===================================== */
.ti-hero { position: relative; overflow: hidden; color: var(--ti-on-dark); isolation: isolate; }
.ti-hero__media { position: absolute; inset: 0; z-index: -2; }
.ti-hero__media img, .ti-hero__media video { width: 100%; height: 100%; object-fit: cover; filter: saturate(.78) brightness(.62); }
/* Capa de gradiente/atmósfera (visible siempre, también sin vídeo) */
.ti-hero::before {
	content: ""; position: absolute; inset: 0; z-index: -1;
	background:
		radial-gradient(90% 80% at 78% 8%, rgba(194,168,120,.20), transparent 50%),
		radial-gradient(120% 120% at 12% 100%, rgba(94,130,115,.40), transparent 55%),
		linear-gradient(165deg, rgba(14,39,31,.92) 0%, rgba(22,58,48,.82) 45%, rgba(14,39,31,.94) 100%);
}
/* Brillo lento animado para dar vida sin vídeo */
.ti-hero__glow {
	position: absolute; inset: -20%; z-index: -1; pointer-events: none;
	background: radial-gradient(40% 40% at 50% 50%, rgba(194,168,120,.22), transparent 70%);
	animation: ti-drift 18s ease-in-out infinite alternate;
}
@keyframes ti-drift {
	0%   { transform: translate(-12%, -6%) scale(1); opacity: .8; }
	100% { transform: translate(14%, 8%) scale(1.25); opacity: 1; }
}
.ti-hero__inner { padding: clamp(5rem, 12vh, 9rem) 0 clamp(3.5rem, 8vh, 6rem); max-width: 56rem; }
.ti-hero__kicker { color: var(--ti-brass); margin-bottom: var(--s5); }
.ti-hero__title { color: #fff; font-size: clamp(2.6rem, 6.2vw, 5rem); font-weight: 380; margin: 0 0 var(--s5); line-height: 1.05; }
.ti-hero__title em { font-style: italic; color: var(--ti-brass); font-weight: 420; }
.ti-hero__sub { color: rgba(233,239,233,.92); font-size: clamp(1.05rem, 1.8vw, 1.3rem); max-width: 46ch; margin: 0 0 var(--s6); line-height: 1.6; }
.ti-hero__cta { display: flex; flex-wrap: wrap; gap: var(--s3); margin-bottom: var(--s7); }

/* Buscador hero */
.ti-search {
	display: flex; gap: .5rem; background: var(--ti-card); padding: .5rem;
	border-radius: var(--r-pill); box-shadow: var(--sh-lg); max-width: 540px;
	border: 1px solid rgba(255,255,255,.5);
}
.ti-search input {
	flex: 1; border: 0; background: transparent; padding: .65rem 1rem; font-family: var(--ti-body);
	font-size: 1rem; color: var(--ti-ink); min-width: 0;
}
.ti-search input::placeholder { color: var(--ti-ink-mute); }
.ti-search input:focus { outline: none; }
.ti-search button { border: 0; background: var(--ti-pine); color: #fff; padding: .7rem 1.5rem; border-radius: var(--r-pill); font-family: var(--ti-body); font-weight: 700; cursor: pointer; transition: background .2s; }
.ti-search button:hover { background: var(--ti-pine-deep); }

/* Stats hero */
.ti-hero__stats { display: flex; flex-wrap: wrap; gap: var(--s7); margin-top: var(--s7); padding-top: var(--s6); border-top: 1px solid rgba(233,239,233,.18); }
.ti-hero__stat strong { display: block; font-family: var(--ti-display); font-size: 2.4rem; font-weight: 460; color: var(--ti-brass); line-height: 1; }
.ti-hero__stat span { font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ti-on-dark-mute); }

/* ============================ Provincias =============================== */
.ti-provincias { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s5); }
.ti-prov-card {
	position: relative; display: block; border-radius: var(--r-lg); overflow: hidden;
	aspect-ratio: 3/4; box-shadow: var(--sh); isolation: isolate; transition: transform .3s ease, box-shadow .3s ease;
}
.ti-prov-card:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); }
.ti-prov-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; filter: saturate(.85); }
.ti-prov-card:hover img { transform: scale(1.06); }
.ti-prov-card::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(14,39,31,0) 30%, rgba(14,39,31,.45) 60%, rgba(14,39,31,.9) 100%); }
.ti-prov-card__body { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: var(--s5); color: #fff; }
.ti-prov-card__name { font-family: var(--ti-display); font-size: 1.7rem; font-weight: 500; line-height: 1; margin-bottom: .35rem; }
.ti-prov-card__meta { font-size: .85rem; color: rgba(255,255,255,.85); }
.ti-prov-card__count { display: inline-block; margin-top: .6rem; font-size: .78rem; font-weight: 700; letter-spacing: .04em; color: var(--ti-pine-deep); background: var(--ti-brass); padding: .25rem .7rem; border-radius: var(--r-pill); }
.ti-prov-card__arrow { position: absolute; top: var(--s5); right: var(--s5); z-index: 2; width: 40px; height: 40px; display: grid; place-items: center; border-radius: 50%; background: rgba(252,249,242,.18); backdrop-filter: blur(4px); color: #fff; font-size: 1.1rem; border: 1px solid rgba(255,255,255,.3); transition: all .25s; }
.ti-prov-card:hover .ti-prov-card__arrow { background: var(--ti-brass); color: var(--ti-pine-deep); transform: rotate(-45deg); }

/* ============================ Servicios (4 cards) ====================== */
.ti-services { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s5); }
.ti-svc {
	background: var(--ti-card); border: 1px solid var(--ti-line-soft); border-radius: var(--r-lg);
	padding: var(--s6) var(--s5); transition: transform .25s ease, box-shadow .25s ease, border-color .25s; display: flex; flex-direction: column;
}
.ti-svc:hover { transform: translateY(-5px); box-shadow: var(--sh); border-color: var(--ti-brass); }
.ti-svc__icon { width: 56px; height: 56px; display: grid; place-items: center; border-radius: 14px; background: var(--ti-sage-pale); margin-bottom: var(--s4); }
.ti-svc__icon svg { width: 28px; height: 28px; stroke: var(--ti-pine); }
.ti-svc h3 { margin: 0 0 var(--s2); }
.ti-svc p { color: var(--ti-ink-soft); font-size: .96rem; margin: 0 0 var(--s4); flex: 1; }
.ti-svc__link { font-weight: 700; color: var(--ti-pine); font-size: .92rem; }
.ti-svc__link:hover { color: var(--ti-brass-deep); }

/* ============================ Bento (información) ====================== */
.ti-bento { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s5); }
.ti-bento__cell {
	background: var(--ti-card); border: 1px solid var(--ti-line-soft); border-radius: var(--r-lg);
	padding: var(--s6); display: flex; flex-direction: column; transition: transform .25s ease, box-shadow .25s ease; position: relative; overflow: hidden;
}
.ti-bento__cell:hover { transform: translateY(-4px); box-shadow: var(--sh); }
.ti-bento__cell--feature { grid-column: span 2; grid-row: span 2; color: #fff; min-height: 320px; justify-content: flex-end; border: 0;
	background: radial-gradient(120% 110% at 85% 0%, rgba(194,168,120,.2), transparent 50%), linear-gradient(155deg, var(--ti-pine) 0%, var(--ti-pine-deep) 100%); }
.ti-bento__cell--feature h3 { color: #fff; font-size: clamp(1.6rem,2.6vw,2.2rem); }
.ti-bento__cell--feature p { color: rgba(233,239,233,.85); max-width: 48ch; }
.ti-bento__icon { font-size: 1.7rem; margin-bottom: var(--s3); }
.ti-bento__cell h3 { margin: 0 0 var(--s2); }
.ti-bento__cell p { color: var(--ti-ink-soft); font-size: .95rem; margin: 0 0 var(--s4); flex: 1; }
.ti-bento__link { font-weight: 700; color: var(--ti-pine); font-size: .9rem; margin-top: auto; }
.ti-bento__cell--feature .ti-bento__link { color: var(--ti-brass); }
.ti-bento__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .14; z-index: 0; pointer-events: none; mix-blend-mode: luminosity; }

/* ============================ CTA band ================================= */
.ti-cta-band {
	border-radius: var(--r-xl); padding: clamp(2.5rem,5vw,4rem); text-align: center; color: #fff; position: relative; overflow: hidden;
	background: radial-gradient(100% 120% at 0% 0%, rgba(94,130,115,.5), transparent 55%), radial-gradient(90% 120% at 100% 100%, rgba(194,168,120,.25), transparent 55%), linear-gradient(150deg, var(--ti-pine) 0%, var(--ti-pine-deep) 100%);
}
.ti-cta-band h2 { color: #fff; margin: var(--s3) 0; }
.ti-cta-band p { color: rgba(233,239,233,.88); max-width: 60ch; margin: 0 auto var(--s6); }

/* ============================ Posts cards ============================== */
.ti-posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s5); }
.ti-post-card { background: var(--ti-card); border: 1px solid var(--ti-line-soft); border-radius: var(--r-lg); overflow: hidden; transition: transform .25s ease, box-shadow .25s ease; display: flex; flex-direction: column; }
.ti-post-card:hover { transform: translateY(-4px); box-shadow: var(--sh); }
.ti-post-card__img { display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--ti-sage-pale); }
.ti-post-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.ti-post-card:hover .ti-post-card__img img { transform: scale(1.05); }
.ti-post-card__body { padding: var(--s5); display: flex; flex-direction: column; flex: 1; }
.ti-post-card__cat { display: inline-block; align-self: flex-start; font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ti-clay); margin-bottom: var(--s2); }
.ti-post-card__title { font-size: 1.25rem; margin: 0 0 var(--s2); line-height: 1.2; }
.ti-post-card__title a { color: var(--ti-pine); }
.ti-post-card__title a:hover { color: var(--ti-brass-deep); }
.ti-post-card__excerpt { color: var(--ti-ink-soft); font-size: .94rem; margin: 0 0 var(--s4); flex: 1; }
.ti-post-card__meta { font-size: .82rem; color: var(--ti-ink-mute); }

/* ============================ Trust =================================== */
.ti-trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s6); }
.ti-trust__item { text-align: center; padding: var(--s4); }
.ti-trust__icon { width: 64px; height: 64px; margin: 0 auto var(--s4); display: grid; place-items: center; border-radius: 50%; background: var(--ti-sage-pale); border: 1px solid var(--ti-line-soft); }
.ti-trust__icon svg { width: 30px; height: 30px; stroke: var(--ti-pine); }
.ti-trust__item h3 { margin: 0 0 var(--s2); }
.ti-trust__item p { color: var(--ti-ink-soft); font-size: .96rem; margin: 0; }

/* ============================ FOOTER =================================== */
.ti-footer { background: var(--ti-pine-deep); color: var(--ti-on-dark-mute); padding: var(--s9) 0 var(--s6); margin-top: var(--s8); }
.ti-footer .ti-logo { color: #fff; }
.ti-footer .ti-logo__mark { background: var(--ti-brass); color: var(--ti-pine-deep); }
.ti-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--s7); padding-bottom: var(--s7); border-bottom: 1px solid rgba(233,239,233,.12); }
.ti-footer__brand p { color: var(--ti-on-dark-mute); font-size: .95rem; max-width: 38ch; margin-top: var(--s4); }
.ti-footer h4 { color: #fff; font-family: var(--ti-body); font-weight: 700; font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 var(--s4); }
.ti-footer ul { list-style: none; margin: 0; padding: 0; }
.ti-footer ul li { margin-bottom: .6rem; }
.ti-footer ul li a { color: var(--ti-on-dark-mute); font-size: .95rem; }
.ti-footer ul li a:hover { color: var(--ti-brass); }
.ti-footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--s4); padding-top: var(--s6); font-size: .85rem; }
.ti-footer__bottom a { color: var(--ti-on-dark-mute); text-decoration: underline; }
.ti-footer__bottom a:hover { color: var(--ti-brass); }
.ti-footer__legales { display: flex; flex-wrap: wrap; gap: var(--s4); }
.ti-footer__legales a { color: var(--ti-on-dark-mute); }
.ti-footer__legales a:hover { color: var(--ti-brass); }
.ti-footer__creditos { margin-top: var(--s5); font-size: .76rem; color: rgba(169,188,177,.6); line-height: 1.6; }

/* ============================ Archive hero ============================= */
.ti-archive-hero {
	position: relative; color: #fff; padding: clamp(3rem,7vh,5rem) 0 clamp(2.5rem,5vh,4rem);
	background: radial-gradient(90% 120% at 90% 0%, rgba(194,168,120,.16), transparent 50%), linear-gradient(160deg, var(--ti-pine) 0%, var(--ti-pine-deep) 100%);
	overflow: hidden; isolation: isolate;
}
.ti-archive-hero::after { content: ""; position: absolute; inset: 0; z-index: -1; background-image: var(--contours); background-position: center bottom; opacity: .6; mix-blend-mode: screen; }
.ti-archive-hero__kicker { color: var(--ti-brass); margin-bottom: var(--s3); }
.ti-archive-hero__title { color: #fff; margin: 0 0 var(--s3); max-width: 22ch; }
.ti-archive-hero__sub { color: rgba(233,239,233,.85); font-size: 1.08rem; max-width: 64ch; margin: 0; }

/* ============================ Grid + entity cards ====================== */
.ti-grid { display: grid; gap: var(--s5); }
.ti-grid--auto { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.ti-grid--3 { grid-template-columns: repeat(3, 1fr); }

.ti-card {
	background: var(--ti-card); border: 1px solid var(--ti-line-soft); border-radius: var(--r-lg);
	overflow: hidden; display: flex; flex-direction: column; transition: transform .25s ease, box-shadow .25s ease, border-color .25s;
}
.ti-card:hover { transform: translateY(-4px); box-shadow: var(--sh); border-color: var(--ti-brass); }
.ti-card__img { position: relative; display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--ti-sage-pale); }
.ti-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.ti-card:hover .ti-card__img img { transform: scale(1.05); }
.ti-card__body { padding: var(--s5); display: flex; flex-direction: column; flex: 1; }
.ti-card__title { font-size: 1.3rem; margin: 0 0 var(--s2); line-height: 1.18; }
.ti-card__title a { color: var(--ti-pine); }
.ti-card__title a:hover { color: var(--ti-brass-deep); }
.ti-card__loc { color: var(--ti-ink-mute); font-size: .9rem; margin: 0 0 var(--s3); }
.ti-card__tel { display: inline-flex; align-items: center; gap: .4rem; font-weight: 700; color: var(--ti-pine); font-size: .95rem; margin-bottom: var(--s4); }
.ti-card__cta { margin-top: auto; font-weight: 700; color: var(--ti-clay); font-size: .92rem; }
.ti-card__cta:hover { color: var(--ti-pine); }

/* Badges */
.ti-badge { position: absolute; top: var(--s3); left: var(--s3); z-index: 2; font-size: .72rem; font-weight: 700; letter-spacing: .06em; padding: .3rem .7rem; border-radius: var(--r-pill); }
.ti-badge--24h { background: var(--ti-clay); color: #fff; }
.ti-badge--pine { background: var(--ti-pine); color: #fff; }

/* Selector de provincias (en archives) */
.ti-prov-pills { display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: var(--s7); }
.ti-prov-pills a { padding: .55rem 1.2rem; border-radius: var(--r-pill); border: 1px solid var(--ti-line); background: var(--ti-card); font-weight: 600; font-size: .92rem; color: var(--ti-ink-soft); }
.ti-prov-pills a:hover, .ti-prov-pills a.is-active { background: var(--ti-pine); border-color: var(--ti-pine); color: #fff; }

/* Clasificador A-Z por población (en archives) */
.ti-azbar { display: flex; flex-wrap: wrap; align-items: center; gap: .4rem; margin-bottom: var(--s6); }
.ti-azbar__label { font-family: var(--ti-body); font-weight: 700; font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ti-ink-soft); margin-right: .5rem; }
.ti-az { min-width: 2.1rem; padding: .35rem .55rem; border-radius: 10px; border: 1px solid var(--ti-line); background: var(--ti-card); font-family: var(--ti-body); font-weight: 700; font-size: .9rem; line-height: 1; color: var(--ti-ink-soft); cursor: pointer; transition: background .18s ease, color .18s ease, border-color .18s ease; }
.ti-az:hover { border-color: var(--ti-brass); color: var(--ti-pine); }
.ti-az.is-active { background: var(--ti-pine); border-color: var(--ti-pine); color: #fff; }
.ti-az-hidden { display: none !important; }

/* Contenido editorial bajo el listado de los archives */
.ti-editorial { margin-top: var(--s8); padding-top: var(--s7); border-top: 1px solid var(--ti-line); max-width: 72ch; }
.ti-editorial h2 { font-family: var(--ti-display); font-weight: 460; font-size: clamp(1.3rem, 2.4vw, 1.75rem); color: var(--ti-pine-deep); margin: var(--s6) 0 var(--s3); }
.ti-editorial h2:first-child { margin-top: 0; }
.ti-editorial p { color: var(--ti-ink-soft); line-height: 1.7; margin: 0 0 var(--s4); }
.ti-editorial strong { color: var(--ti-ink); }

/* Estado vacío */
.ti-empty { text-align: center; padding: var(--s8) var(--s5); background: var(--ti-card); border: 1px dashed var(--ti-line); border-radius: var(--r-lg); color: var(--ti-ink-soft); }
.ti-lead { color: var(--ti-ink-soft); font-size: 1.08rem; line-height: 1.7; max-width: 72ch; margin: 0 0 var(--s5); }
.ti-lead strong { color: var(--ti-pine); }
.ti-pagination { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; }
.ti-pagination .page-numbers { display: inline-grid; place-items: center; min-width: 42px; height: 42px; padding: 0 .8rem; border-radius: var(--r-pill); border: 1px solid var(--ti-line); background: var(--ti-card); font-weight: 600; font-size: .95rem; color: var(--ti-ink-soft); }
.ti-pagination .page-numbers:hover { border-color: var(--ti-pine); color: var(--ti-pine); }
.ti-pagination .page-numbers.current { background: var(--ti-pine); border-color: var(--ti-pine); color: #fff; }
.ti-pagination .page-numbers.dots { border: 0; background: transparent; }
.ti-tax-block { margin-top: var(--s8); scroll-margin-top: 90px; }.ti-tax-block__title { display: flex; align-items: center; gap: .6rem; margin: 0; }
.ti-tax-block__icon { display: grid; place-items: center; width: 40px; height: 40px; border-radius: 11px; background: var(--ti-sage-pale); flex-shrink: 0; }
.ti-tax-block__icon svg { stroke: var(--ti-pine); }

/* ============================ Zona blocks (florist/marmol) ============= */
.ti-zona { margin-bottom: var(--s8); }
.ti-zona__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--s4); padding-bottom: var(--s3); margin-bottom: var(--s5); border-bottom: 2px solid var(--ti-line); flex-wrap: wrap; }
.ti-zona__title { display: flex; align-items: center; gap: .65rem; margin: 0; font-size: 1.7rem; }
.ti-zona__title .ti-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--ti-brass); flex-shrink: 0; }
.ti-zona__link { font-weight: 700; font-size: .9rem; color: var(--ti-pine); white-space: nowrap; }
.ti-zona__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s5); }

/* Card destacada de floristería/marmolista (formato horizontal premium) */
.ti-feat {
	display: grid; grid-template-columns: 200px 1fr; background: var(--ti-card);
	border: 1px solid var(--ti-line-soft); border-radius: var(--r-lg); overflow: hidden;
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s;
}
.ti-feat:hover { transform: translateY(-4px); box-shadow: var(--sh); border-color: var(--ti-brass); }
.ti-feat__img { position: relative; overflow: hidden; background: var(--ti-sage-pale); }
.ti-feat__img img { width: 100%; height: 100%; object-fit: cover; }
.ti-feat__body { padding: var(--s5); display: flex; flex-direction: column; }
.ti-feat__title { font-size: 1.35rem; margin: 0 0 var(--s2); }
.ti-feat__title a { color: var(--ti-pine); }
.ti-feat__loc { color: var(--ti-ink-mute); font-size: .88rem; margin: 0 0 var(--s3); }
.ti-feat__tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: 0 0 var(--s4); }
.ti-feat__tags span { font-size: .78rem; font-weight: 600; color: var(--ti-pine); background: var(--ti-sage-pale); padding: .25rem .65rem; border-radius: var(--r-pill); }
.ti-feat__actions { margin-top: auto; display: flex; gap: .6rem; flex-wrap: wrap; }

/* Hueco de plaza libre + captación */
.ti-slot {
	display: flex; flex-direction: column; align-items: flex-start; justify-content: center; gap: var(--s3);
	border: 1.5px dashed var(--ti-line); border-radius: var(--r-lg); padding: var(--s6) var(--s5);
	background: repeating-linear-gradient(135deg, transparent, transparent 12px, rgba(194,168,120,.04) 12px, rgba(194,168,120,.04) 24px);
}
.ti-slot__tag { font-size: .74rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ti-brass-deep); }
.ti-slot h4 { margin: 0; font-family: var(--ti-display); font-size: 1.3rem; color: var(--ti-pine); }
.ti-slot p { color: var(--ti-ink-soft); font-size: .92rem; margin: 0; }

/* Banda de captación grande (florist/marmol) */
.ti-captacion-band {
	display: grid; grid-template-columns: 1.5fr 1fr; align-items: center; gap: var(--s6);
	background: radial-gradient(100% 130% at 0% 0%, rgba(94,130,115,.45), transparent 55%), linear-gradient(150deg, var(--ti-pine) 0%, var(--ti-pine-deep) 100%);
	color: #fff; border-radius: var(--r-xl); padding: clamp(2rem,4vw,3.2rem);
}
.ti-captacion-band h2 { color: #fff; margin: 0 0 var(--s3); }
.ti-captacion-band p { color: rgba(233,239,233,.88); margin: 0; }
.ti-captacion-band__cta { text-align: right; }

/* ============================ FICHA (single) ========================== */
.ti-ficha { padding: var(--s8) 0; }
.ti-ficha__hero-img { border-radius: var(--r-lg); overflow: hidden; margin-bottom: var(--s7); aspect-ratio: 21/9; box-shadow: var(--sh); }
.ti-ficha__hero-img img { width: 100%; height: 100%; object-fit: cover; }
.ti-ficha__grid { display: grid; grid-template-columns: 1fr 360px; gap: var(--s8); align-items: start; }
.ti-ficha__cat { display: inline-block; font-size: .74rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ti-clay); margin-bottom: var(--s3); }
.ti-ficha__title { margin: 0 0 var(--s4); }
.ti-ficha__loc { display: flex; flex-wrap: wrap; align-items: center; gap: .7rem; margin-bottom: var(--s6); color: var(--ti-ink-soft); font-size: 1rem; padding-bottom: var(--s5); border-bottom: 1px solid var(--ti-line-soft); }
.ti-ficha__body { font-size: 1.06rem; color: var(--ti-ink); line-height: 1.75; }
.ti-ficha__body h2 { margin: var(--s7) 0 var(--s4); font-size: 1.7rem; }
.ti-ficha__body h3 { margin: var(--s6) 0 var(--s3); }
.ti-ficha__body p { margin: 0 0 var(--s4); }
.ti-ficha__body a { color: var(--ti-clay); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.ti-ficha__fuente { font-size: .82rem; color: var(--ti-ink-mute); font-style: italic; margin-top: var(--s6); padding-top: var(--s4); border-top: 1px dashed var(--ti-line); }

.ti-services-list { list-style: none; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; margin: var(--s4) 0 var(--s6); }
.ti-services-list li { position: relative; padding-left: 1.7rem; font-size: .96rem; color: var(--ti-ink-soft); }
.ti-services-list li::before { content: "✓"; position: absolute; left: 0; top: 0; width: 1.2rem; height: 1.2rem; color: var(--ti-sage); font-weight: 800; }

/* Sidebar info cards */
.ti-ficha__sidebar { position: sticky; top: 96px; display: flex; flex-direction: column; gap: var(--s5); }
.ti-info-card { background: var(--ti-card); border: 1px solid var(--ti-line-soft); border-radius: var(--r-lg); padding: var(--s6); }
.ti-info-card h3 { font-size: 1.2rem; margin: 0 0 var(--s4); padding-bottom: var(--s3); border-bottom: 1px solid var(--ti-line-soft); }
.ti-info-card dl { margin: 0 0 var(--s5); }
.ti-info-card dt { font-size: .76rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--ti-ink-mute); margin-top: var(--s4); }
.ti-info-card dt:first-child { margin-top: 0; }
.ti-info-card dd { margin: .2rem 0 0; font-size: .98rem; color: var(--ti-ink); }
.ti-info-card dd a { color: var(--ti-pine); font-weight: 600; }
.ti-info-card .ti-btn { margin-top: var(--s3); width: 100%; }

.ti-map { border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 16/9; border: 1px solid var(--ti-line-soft); margin: var(--s4) 0; }
.ti-map iframe { width: 100%; height: 100%; border: 0; display: block; }
.ti-info-card--map h3 { margin-bottom: var(--s3); }
.ti-map--mini { aspect-ratio: 4/3; margin: 0 0 var(--s3); }
.ti-map__open { display: inline-block; font-weight: 700; font-size: .88rem; color: var(--ti-pine); }
.ti-map__open:hover { color: var(--ti-brass-deep); }

/* Captación al pie de ficha */
.ti-ficha__captacion {
	display: grid; grid-template-columns: 1.5fr auto; align-items: center; gap: var(--s6);
	margin-top: var(--s8); padding: clamp(1.8rem,3.5vw,2.6rem); border-radius: var(--r-xl);
	background: var(--ti-sage-pale); border: 1px solid var(--ti-line-soft);
}
.ti-ficha__captacion h2 { font-size: 1.5rem; margin: 0 0 var(--s2); }
.ti-ficha__captacion p { margin: 0; color: var(--ti-ink-soft); font-size: .98rem; }

/* ============================ Páginas legales ========================= */
.ti-legal { padding: var(--s8) 0 var(--s9); }
.ti-legal__container { max-width: 820px; margin: 0 auto; padding: 0 24px; }
.ti-legal h1 { margin-bottom: var(--s2); }
.ti-legal__updated { color: var(--ti-ink-mute); font-size: .9rem; margin-bottom: var(--s7); }
.ti-legal h2 { font-size: 1.5rem; margin: var(--s7) 0 var(--s3); }
.ti-legal p, .ti-legal li { color: var(--ti-ink-soft); }
.ti-legal a { color: var(--ti-clay); text-decoration: underline; text-underline-offset: 2px; }

/* Aviso RGPD (contacto) */
.ti-rgpd-notice { display: flex; gap: 1rem; align-items: flex-start; background: var(--ti-sage-pale); border: 1px solid var(--ti-line-soft); border-left: 4px solid var(--ti-pine); border-radius: var(--r-lg); padding: 1.1rem 1.35rem; margin-bottom: var(--s5); }
.ti-rgpd-notice__icon { font-size: 1.4rem; flex-shrink: 0; }
.ti-rgpd-notice__text p { margin: 0; font-size: .94rem; line-height: 1.6; color: var(--ti-ink-soft); }
.ti-rgpd-notice__text strong { color: var(--ti-pine); }
.ti-rgpd-notice__text a { color: var(--ti-clay); font-weight: 700; }
.ti-contacto-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--s7); align-items: start; }
@media (max-width: 880px) { .ti-contacto-grid { grid-template-columns: 1fr; } }

/* ============================ Single post / page ====================== */
.ti-article { padding: var(--s8) 0; }
.ti-article__wrap { max-width: 760px; margin: 0 auto; }
.ti-article__cat { color: var(--ti-clay); font-size: .76rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.ti-article__title { margin: var(--s3) 0; }
.ti-article__meta { color: var(--ti-ink-mute); font-size: .9rem; margin-bottom: var(--s6); }
.ti-article__feat { border-radius: var(--r-lg); overflow: hidden; margin-bottom: var(--s7); box-shadow: var(--sh); }
.ti-article__body { font-size: 1.1rem; line-height: 1.8; color: var(--ti-ink); }
.ti-article__body h2 { margin: var(--s7) 0 var(--s3); }
.ti-article__body h3 { margin: var(--s6) 0 var(--s3); }
.ti-article__body img { border-radius: var(--r-lg); margin: var(--s5) 0; }
.ti-article__body a { color: var(--ti-clay); text-decoration: underline; text-underline-offset: 2px; }
.ti-article__body blockquote { margin: var(--s6) 0; padding: var(--s4) var(--s6); border-left: 3px solid var(--ti-brass); background: var(--ti-card); font-family: var(--ti-display); font-style: italic; font-size: 1.3rem; color: var(--ti-pine); border-radius: 0 var(--r-lg) var(--r-lg) 0; }
.ti-article__related { margin-top: var(--s8); padding-top: var(--s7); border-top: 1px solid var(--ti-line-soft); }
.ti-article__related h2 { margin: 0 0 var(--s6); }

/* ============================ 404 ===================================== */
.ti-404 { text-align: center; padding: var(--s9) 0; max-width: 640px; margin: 0 auto; }
.ti-404__code { font-family: var(--ti-display); font-size: clamp(6rem,16vw,11rem); color: var(--ti-brass); line-height: 1; font-weight: 420; margin: 0; }
.ti-404 h1 { margin: var(--s3) 0; }
.ti-404__text { color: var(--ti-ink-soft); margin: 0 0 var(--s6); }
.ti-404__actions { display: flex; gap: var(--s3); justify-content: center; flex-wrap: wrap; }

/* ============================ Reveal animation ======================== */
@media (prefers-reduced-motion: no-preference) {
	.ti-reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
	.ti-reveal.is-in { opacity: 1; transform: none; }
	.ti-hero__inner > * { animation: ti-rise .8s cubic-bezier(.2,.7,.3,1) backwards; }
	.ti-hero__kicker { animation-delay: .05s; }
	.ti-hero__title { animation-delay: .15s; }
	.ti-hero__sub { animation-delay: .28s; }
	.ti-hero__cta { animation-delay: .4s; }
	.ti-search { animation-delay: .5s; }
	.ti-hero__stats { animation-delay: .6s; }
}
@keyframes ti-rise { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: none; } }

/* ============================ Grano global ============================ */
body::after {
	content: ""; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
	background-image: var(--grain); opacity: .035; mix-blend-mode: multiply;
}

/* ============================ Responsive ============================== */
@media (max-width: 1024px) {
	.ti-provincias { grid-template-columns: repeat(2, 1fr); }
	.ti-services { grid-template-columns: repeat(2, 1fr); }
	.ti-ficha__grid { grid-template-columns: 1fr; }
	.ti-ficha__sidebar { position: static; }
	.ti-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 880px) {
	.ti-burger { display: flex; }
	.ti-nav { position: fixed; inset: 78px 0 0 auto; width: min(86vw, 360px); background: var(--ti-card); border-left: 1px solid var(--ti-line); box-shadow: var(--sh-lg); transform: translateX(105%); transition: transform .3s ease; overflow-y: auto; padding: var(--s5); }
	.is-open .ti-nav { transform: translateX(0); }
	.ti-nav__list { flex-direction: column; align-items: stretch; gap: .15rem; }
	.ti-nav__list > li > a { padding: .85rem 1rem; border-radius: var(--r-sm); justify-content: space-between; }
	.ti-nav__sub { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: 0; background: transparent; padding: 0 0 .5rem 1rem; }
	.ti-nav__cta { margin: var(--s4) 0 0; }
	.ti-nav__cta .ti-btn { width: 100%; }
	.ti-bento { grid-template-columns: 1fr 1fr; }
	.ti-bento__cell--feature { grid-column: span 2; grid-row: auto; min-height: 240px; }
	.ti-posts, .ti-trust, .ti-grid--3 { grid-template-columns: 1fr; }
	.ti-zona__grid { grid-template-columns: 1fr; }
	.ti-captacion-band, .ti-ficha__captacion { grid-template-columns: 1fr; text-align: left; }
	.ti-captacion-band__cta { text-align: left; }
	.ti-hero__stats { gap: var(--s5); }
}
@media (max-width: 560px) {
	body { font-size: 16px; }
	.ti-provincias { grid-template-columns: 1fr; }
	.ti-services { grid-template-columns: 1fr; }
	.ti-bento { grid-template-columns: 1fr; }
	.ti-bento__cell--feature { grid-column: auto; }
	.ti-hero__cta { flex-direction: column; }
	.ti-hero__cta .ti-btn { width: 100%; }
	.ti-services-list { grid-template-columns: 1fr; }
	.ti-feat { grid-template-columns: 1fr; }
	.ti-feat__img { aspect-ratio: 16/9; }
	.ti-hero__stat strong { font-size: 2rem; }
	.ti-section { padding: var(--s8) 0; }
}
