/* =========================================================================
   INVIA — Tipulim Archive (/treatments/)
   ========================================================================= */

.invia-tipulim-archive {
	direction: rtl;
	color: #151515;
	font-family: 'Ploni', -apple-system, BlinkMacSystemFont, sans-serif;
	background: #fff;
	overflow-x: clip;
}
.invia-tipulim-archive[dir="ltr"] {
	direction: ltr;
}

.invia-tipulim-archive *,
.invia-tipulim-archive *::before,
.invia-tipulim-archive *::after {
	box-sizing: border-box;
}

/* =========================================================================
   HERO — white background, centered copy, images floating around
   ========================================================================= */

.invia-tip-hero {
	position: relative;
	background: #fff;
	padding: 48px 24px 40px;
	overflow: hidden;
}

.invia-tip-hero__stage {
	position: relative;
	max-width: 1240px;
	margin: 0 auto;
	min-height: 540px;
	display: grid;
	place-items: center;
}

.invia-tip-hero__copy {
	position: relative;
	z-index: 2;
	grid-column: 1;
	grid-row: 1;
	max-width: 600px;
	text-align: center;
	padding: 0 16px;
	margin: 0 auto;
}

.invia-tip-hero__eyebrow {
	display: inline-block;
	font-size: 12px;
	letter-spacing: .18em;
	color: #151515;
	background: #fff;
	border: 1px solid #ececec;
	padding: 7px 14px;
	border-radius: 999px;
	margin-bottom: 22px;
	font-weight: 600;
	text-transform: uppercase;
}

.invia-tip-hero__title {
	font-size: clamp(2.2rem, 5vw, 3.6rem);
	line-height: 1.1;
	letter-spacing: -0.025em;
	font-weight: 700;
	font-style: normal;
	margin: 0 0 20px;
	color: #151515;
}

.invia-tip-hero__subtitle {
	font-size: clamp(15px, 1.5vw, 17px);
	line-height: 1.65;
	color: #151515;
	margin: 0 auto 32px;
	max-width: 520px;
}

.invia-tip-hero__cta {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	justify-content: center;
}

.invia-tip-hero__btn {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	padding: 14px 28px !important;
	border-radius: 999px !important;
	font-size: 15px !important;
	font-weight: 600;
	text-decoration: none;
	line-height: 1;
	cursor: pointer;
}
.invia-tip-hero__btn--primary,
.invia-tip-hero__btn--primary:link,
.invia-tip-hero__btn--primary:visited {
	background: #151515 !important;
	color: #fff !important;
	border-color: #151515 !important;
	text-decoration: none;
	transition: background 0.22s ease, color 0.22s ease, transform .18s ease;
}
.invia-tip-hero__btn--primary:hover,
.invia-tip-hero__btn--primary:focus {
	background: #fff !important;
	color: #151515 !important;
	transform: scale(1.02);
}
.invia-tip-hero__btn--ghost,
.invia-tip-hero__btn--ghost:link,
.invia-tip-hero__btn--ghost:visited {
	background: #fff !important;
	color: #151515 !important;
	border-color: #e3e3e3 !important;
	text-decoration: none;
	transition: background 0.22s ease, color 0.22s ease, border-color 0.22s ease, transform .18s ease;
}
.invia-tip-hero__btn--ghost:hover,
.invia-tip-hero__btn--ghost:focus {
	background: #151515 !important;
	color: #fff !important;
	border-color: #151515 !important;
	transform: scale(1.02);
}

/* ── Floating images around the centered copy ─────────────────────────── */
.invia-tip-hero__pic {
	position: absolute;
	z-index: 1;
	overflow: hidden;
	background: #f5ece4;
	box-shadow: 0 18px 40px -22px rgba(0, 0, 0, .25);
}
.invia-tip-hero__pic img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}

/* Symmetric corner sizes so visual weight stays balanced and copy reads centered. */

/* All hero pics share the same rectangular shape & radius. */
.invia-tip-hero__pic {
	width: 160px;
	height: 200px;
	border-radius: 8px;
}

.invia-tip-hero__pic--1 {
	top: 2%;  right: 4%;
	transform: rotate(-4deg);
	animation: tip-float 9s ease-in-out infinite;
}
.invia-tip-hero__pic--2 {
	top: 6%;  left: 4%;
	transform: rotate(3deg);
	animation: tip-float 11s ease-in-out infinite .8s;
}
.invia-tip-hero__pic--3 {
	bottom: 2%; right: 14%;
	transform: rotate(5deg);
	animation: tip-float 10s ease-in-out infinite 1.4s;
}
.invia-tip-hero__pic--4 {
	bottom: 4%; left: 4%;
	transform: rotate(-6deg);
	animation: tip-float 12s ease-in-out infinite .4s;
}
.invia-tip-hero__pic--5 {
	display: none;
}

@keyframes tip-float {
	0%, 100% { translate: 0 0; }
	50%      { translate: 0 -14px; }
}

@media (prefers-reduced-motion: reduce) {
	.invia-tip-hero__pic { animation: none !important; }
}

/* =========================================================================
   SECTION (search + grid)
   ========================================================================= */

.invia-tip-section {
	padding: 48px 24px 100px;
	background: #fff;
}

.invia-tip-section__inner {
	max-width: 1240px;
	margin: 0 auto;
}

.invia-tip-section__header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 24px;
}

.invia-tip-section__title {
	font-size: clamp(1.6rem, 3.5vw, 2.4rem);
	font-weight: 700;
	color: #151515;
	letter-spacing: -0.02em;
	margin: 0;
}
.invia-tip-section__count {
	margin: 0;
	color: #888;
	font-size: 14px;
	white-space: nowrap;
}

/* ── Category chips ── */
.invia-tipulim-archive .invia-tip-cats {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 28px;
	padding: 0;
	list-style: none;
}
.invia-tipulim-archive .invia-tip-cats__chip,
.invia-tipulim-archive button.invia-tip-cats__chip {
	appearance: none;
	-webkit-appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid #e0ddd8;
	background: #fff;
	color: #151515;
	font-family: inherit;
	font-size: 14px;
	font-weight: 500;
	line-height: 1;
	padding: 11px 20px;
	border-radius: 999px;
	cursor: pointer;
	white-space: nowrap;
	letter-spacing: .01em;
	box-shadow: none;
	text-transform: none;
	transition: background .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.invia-tipulim-archive .invia-tip-cats__chip:hover,
.invia-tipulim-archive button.invia-tip-cats__chip:hover,
.invia-tipulim-archive .invia-tip-cats__chip:focus-visible,
.invia-tipulim-archive button.invia-tip-cats__chip:focus-visible {
	background: #faf6f0;
	border-color: #c4a77d;
	color: #151515;
	outline: none;
}
.invia-tipulim-archive .invia-tip-cats__chip.is-active,
.invia-tipulim-archive button.invia-tip-cats__chip.is-active,
.invia-tipulim-archive .invia-tip-cats__chip.is-active:hover,
.invia-tipulim-archive button.invia-tip-cats__chip.is-active:hover {
	background: #151515;
	color: #fff;
	border-color: #151515;
	box-shadow: 0 4px 14px -6px rgba(21, 21, 21, .35);
}

@media (max-width: 640px) {
	.invia-tipulim-archive .invia-tip-cats {
		gap: 8px;
		margin-bottom: 22px;
	}
	.invia-tipulim-archive .invia-tip-cats__chip,
	.invia-tipulim-archive button.invia-tip-cats__chip {
		padding: 9px 16px;
		font-size: 13px;
	}
}

/* ── Search ── */
.invia-tip-search {
	position: relative;
	border: 1px solid #ececec;
	border-radius: 999px;
	background: #fafafa;
	margin-bottom: 40px;
	max-width: 580px;
	transition: border-color .15s, background .15s, box-shadow .15s;
}
.invia-tip-search:focus-within {
	border-color: #d0d0d0;
	background: #fff;
	box-shadow: 0 6px 22px -12px rgba(0,0,0,.08);
}
.invia-tip-search,
.invia-tip-search * {
	outline: none !important;
	box-shadow: none;
}
.invia-tip-search:focus-within {
	box-shadow: 0 6px 22px -12px rgba(0,0,0,.08);
}
.invia-tip-search__icon {
	position: absolute;
	top: 50%;
	left: 22px;
	right: auto;
	transform: translateY(-50%);
	color: #aaa;
	display: flex;
	pointer-events: none;
}
.invia-tip-search:focus-within .invia-tip-search__icon { color: #151515; }
.invia-tipulim-archive .invia-tip-search__input,
.invia-tipulim-archive input[type="search"].invia-tip-search__input {
	width: 100%;
	padding: 18px 24px 18px 56px;
	border: none !important;
	background: transparent !important;
	border-radius: 999px;
	font-size: 15px;
	font-family: inherit;
	color: #151515;
	outline: none !important;
	box-shadow: none !important;
	direction: rtl;
	-webkit-appearance: none;
	appearance: none;
}
.invia-tipulim-archive[dir="ltr"] .invia-tip-search__input,
.invia-tipulim-archive[dir="ltr"] input[type="search"].invia-tip-search__input {
	direction: ltr;
}
.invia-tip-search__input::placeholder { color: #aaa; }
.invia-tip-search__input::-webkit-search-cancel-button { display:none; }

/* =========================================================================
   GRID & CARDS
   ========================================================================= */

.invia-tip-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}

.invia-tip-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid #efe6dc;
	border-radius: 20px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	will-change: transform;
}
.invia-tip-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 18px 40px -22px rgba(80,50,30,.28);
	border-color: #e3d2bf;
}

.invia-tip-card__media {
	position: relative;
	aspect-ratio: 4 / 3;
	background: linear-gradient(135deg, #f5ece4, #ead9ca);
	overflow: hidden;
}
.invia-tip-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .6s ease;
}
.invia-tip-card:hover .invia-tip-card__media img {
	transform: scale(1.06);
}
.invia-tip-card__media-placeholder {
	position: absolute; inset: 0;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
}

.invia-tip-card__placeholder-logo {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52%;
	max-width: 120px;
	pointer-events: none;
	opacity: 0.18;
	filter: invert(1); /* белый SVG → чёрный на белом фоне */
	transition: opacity .4s ease, transform .45s ease;
}

.invia-tip-card__placeholder-logo svg {
	width: 100%;
	height: auto;
	display: block;
}

.invia-tip-card:hover .invia-tip-card__placeholder-logo {
	opacity: 0.3;
	transform: scale(1.04);
}

.invia-tip-card__duration {
	position: absolute;
	bottom: 12px;
	right: 12px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: rgba(255,255,255,.94);
	backdrop-filter: blur(6px);
	color: #151515;
	font-size: 12px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
	box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.invia-tip-card__body {
	padding: 22px 22px 24px;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.invia-tip-card__title {
	margin: 0 0 10px;
	font-size: 1.2rem;
	font-weight: 700;
	color: #151515;
	line-height: 1.3;
	letter-spacing: -0.01em;
}
.invia-tip-card__excerpt {
	margin: 0 0 18px;
	font-size: 14.5px;
	line-height: 1.6;
	color: #666;
	flex: 1;
}
.invia-tip-card__more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13.5px;
	font-weight: 600;
	color: #b07a52;
	transition: gap .2s ease, color .2s ease;
}
.invia-tip-card:hover .invia-tip-card__more {
	gap: 10px;
	color: #151515;
}

/* hidden by search */
.invia-tip-card.is-hidden { display: none; }

/* No results */
.invia-tip-noresults {
	display: none;
	text-align: center;
	color: #999;
	font-size: 15px;
	padding: 60px 0 20px;
	margin: 0;
}
.invia-tip-noresults.is-visible { display: block; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */

@media (max-width: 1024px) {
	.invia-tip-hero__stage { min-height: 420px; }
	.invia-tip-hero__pic { width: 120px; height: 150px; }
	.invia-tip-hero__pic--1 { top: 2%;  right: 2%; }
	.invia-tip-hero__pic--2 { top: 4%;  left: 2%; }
	.invia-tip-hero__pic--3 { bottom: 2%; right: 6%; }
	.invia-tip-hero__pic--4 { bottom: 4%; left: 2%; }
	.invia-tip-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
}

@media (max-width: 640px) {
	.invia-tip-hero { padding: 56px 16px 48px; }
	.invia-tip-hero__stage { min-height: auto; }
	.invia-tip-hero__pic { display: none; }

	.invia-tip-section { padding: 56px 20px 80px; }
	.invia-tip-section__header { flex-direction: column; align-items: flex-start; gap: 6px; }
	.invia-tip-grid { grid-template-columns: 1fr; gap: 18px; }
	.invia-tip-card__media { aspect-ratio: 16 / 11; }
	.invia-tip-hero__btn { padding: 13px 22px; font-size: 14px; }
}
