/*
 * text-page.css — AM-39
 * Стилі для текстових сторінок (content.full_page.*).
 * Підключається всередині шаблону, після tokens/base/components/layout.
 */

/* ============================================================
 *  LAYOUT
 * ============================================================ */
.am-text-page {
	padding-block: var(--space-2) var(--space-10);
}

.am-text-page__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	align-items: start;
}
@media (min-width: 1024px) {
	.am-text-page__layout {
		grid-template-columns: minmax(0, 1fr) 220px;
	}
}

/* ============================================================
 *  TITLE
 * ============================================================ */
.am-text-page__title {
	font-family: var(--font-display);
	font-size: var(--text-display-m);
	line-height: var(--lh-display-m);
	letter-spacing: var(--tracking-snug);
	font-weight: var(--fw-regular);
	margin-bottom: var(--space-6);
}
@media (min-width: 1024px) {
	.am-text-page__title {
		font-size: var(--text-display-l);
		line-height: var(--lh-display-l);
	}
}

/* ============================================================
 *  PROSE — user-generated HTML content
 * ============================================================ */
.am-prose {
	max-width: 68ch;
}
.am-prose p {
	margin-bottom: var(--space-4);
	line-height: var(--lh-body);
}
.am-prose p:last-child { margin-bottom: 0; }

.am-prose h2 {
	font-size: var(--text-h2);
	line-height: var(--lh-h2);
	font-weight: var(--fw-medium);
	letter-spacing: var(--tracking-snug);
	margin-block: var(--space-7) var(--space-3);
}
.am-prose h3 {
	font-size: var(--text-h3);
	line-height: var(--lh-h3);
	font-weight: var(--fw-medium);
	margin-block: var(--space-5) var(--space-2);
}
.am-prose h4,
.am-prose h5,
.am-prose h6 {
	font-size: var(--text-body);
	font-weight: var(--fw-medium);
	margin-block: var(--space-4) var(--space-2);
}

.am-prose ul,
.am-prose ol {
	list-style: revert;
	padding-left: var(--space-5);
	margin-bottom: var(--space-4);
}
.am-prose li { margin-bottom: var(--space-2); }

.am-prose strong { font-weight: var(--fw-medium); }

.am-prose a {
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-color: var(--c-line);
}
.am-prose a:hover {
	text-decoration-color: var(--c-ink);
	color: var(--c-ink);
}

.am-prose blockquote {
	border-left: 2px solid var(--c-line);
	padding-left: var(--space-5);
	color: var(--c-ink-soft);
	margin-block: var(--space-5);
}

.am-prose img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-2);
	margin-block: var(--space-5);
}

/* ============================================================
 *  BREADCRUMBS — нормалізація legacy .cl_breadcrumb
 * ============================================================ */
.am-text-page .am-breadcrumbs {
	padding: var(--space-4) 0 var(--space-3);
	font-size: var(--text-body-s);
	color: var(--c-ink-soft);
}

.am-text-page .am-breadcrumbs .cl_breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0;
	margin: 0;
	padding: 0 !important; /* reset inline style */
	list-style: none;
}

.am-text-page .am-breadcrumbs .breadcrumb-item {
	display: flex;
	align-items: center;
}
.am-text-page .am-breadcrumbs .breadcrumb-item + .breadcrumb-item::before {
	content: "/";
	margin-inline: var(--space-2);
	opacity: 0.4;
}
.am-text-page .am-breadcrumbs .breadcrumb-item a {
	color: var(--c-ink-soft);
}
.am-text-page .am-breadcrumbs .breadcrumb-item a:hover {
	color: var(--c-ink);
}
.am-text-page .am-breadcrumbs .breadcrumb-item:last-child a,
.am-text-page .am-breadcrumbs .breadcrumb-item:last-child span {
	color: var(--c-ink);
}

/* ============================================================
 *  ASIDE — related pages sidebar
 * ============================================================ */
.am-text-page__aside {
	padding-top: var(--space-3);
}
@media (min-width: 1024px) {
	.am-text-page__aside {
		border-left: 1px solid var(--c-line);
		padding-left: var(--space-6);
	}
}

.am-text-page__aside:empty { display: none; }

.am-text-page__aside .page-menu {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.am-text-page__aside .page-menu li { list-style: none; }
.am-text-page__aside .page-menu li a {
	display: block;
	padding: var(--space-2) var(--space-3);
	font-size: var(--text-body-s);
	color: var(--c-ink-soft);
	border-radius: var(--radius-2);
	transition: background var(--duration-fast) var(--ease-out),
	            color var(--duration-fast) var(--ease-out);
}
.am-text-page__aside .page-menu li a:hover {
	background: var(--c-paper-2);
	color: var(--c-ink);
}

/* ============================================================
 *  PAGE IMAGES (from {$image} / {$imgs})
 * ============================================================ */
.am-text-page .cl_page_img_full {
	width: 100%;
	max-height: 480px;
	object-fit: cover;
	border-radius: var(--radius-2);
	margin-bottom: var(--space-6);
}

/* ============================================================
 *  SUBCONTENT tabs (hidden by PHP inline style on most pages)
 * ============================================================ */
.cl_subc { margin-top: var(--space-5); }

/* ============================================================
 *  BLOG POST DATE (content.full_page.2)
 * ============================================================ */
.am-blog-post__date {
	display: block;
	font-size: var(--text-micro);
	letter-spacing: var(--tracking-caps);
	text-transform: uppercase;
	color: var(--c-ink-soft);
	margin-bottom: var(--space-6);
}

/* ============================================================
 *  BLOG LISTING GRID
 * ============================================================ */
.am-blog-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-7);
	margin-top: var(--space-6);
}
@media (min-width: 600px) {
	.am-blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
	.am-blog-grid { grid-template-columns: repeat(3, 1fr); }
}
.am-blog-grid:empty { display: none; }

/* ============================================================
 *  BLOG CARD
 * ============================================================ */
.am-blog-card {
	display: flex;
	flex-direction: column;
}

.am-blog-card__media {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--c-paper-2);
	border-radius: var(--radius-2);
}
.am-blog-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--duration-slow) var(--ease-out);
}
.am-blog-card:hover .am-blog-card__media img {
	transform: scale(1.04);
}

.am-blog-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	padding-top: var(--space-4);
	flex: 1;
}

.am-blog-card__date {
	font-size: var(--text-micro);
	letter-spacing: var(--tracking-caps);
	text-transform: uppercase;
	color: var(--c-ink-soft);
}

.am-blog-card__title {
	font-size: var(--text-h3);
	font-weight: var(--fw-medium);
	line-height: var(--lh-h3);
	letter-spacing: var(--tracking-snug);
	color: var(--c-ink);
}
.am-blog-card__title:hover { color: var(--c-accent-ink); }

.am-blog-card__excerpt {
	font-size: var(--text-body-s);
	color: var(--c-ink-soft);
	line-height: var(--lh-body);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex: 1;
}

.am-blog-card__more {
	font-size: var(--text-body-s);
	font-weight: var(--fw-medium);
	letter-spacing: var(--tracking-loose);
	color: var(--c-ink);
	margin-top: var(--space-2);
}
.am-blog-card__more:hover { color: var(--c-accent-ink); }

/* ============================================================
 *  PAGER
 * ============================================================ */
.am-text-page .cl_pager {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-top: var(--space-7);
	padding: 0;
	list-style: none;
}
.am-text-page .cl_pager li a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding-inline: var(--space-3);
	font-size: var(--text-body-s);
	font-weight: var(--fw-medium);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-2);
	color: var(--c-ink);
	transition: background var(--duration-fast) var(--ease-out),
	            border-color var(--duration-fast) var(--ease-out);
}
.am-text-page .cl_pager li a:hover {
	background: var(--c-paper-2);
	border-color: var(--c-ink-soft);
}
.am-text-page .cl_pager li a[aria-current="page"] {
	background: var(--c-ink);
	color: var(--c-paper);
	border-color: var(--c-ink);
}
.am-text-page .cl_pager .cl_pager__nav svg {
	width: 16px;
	height: 16px;
	display: block;
}
.am-text-page .cl_pager .cl_pager__nav--off {
	opacity: 0.3;
	pointer-events: none;
	cursor: default;
}

/* ============================================================
 *  COMMENTS SECTION
 * ============================================================ */
.am-text-page .cl_cat_comments {
	margin-top: var(--space-8);
	padding-top: var(--space-6);
	border-top: 1px solid var(--c-line);
}
.am-text-page .cl_cat_comments h2 {
	font-size: var(--text-h2);
	font-weight: var(--fw-medium);
	margin-bottom: var(--space-5);
}

/* ============================================================
 *  REVIEW FORM (am-review-form, am-field)
 *  Стилі дублюються з product-page.css — тут без display:none
 *  і без .is-review-form-open (форма завжди видима).
 * ============================================================ */
.am-text-page .am-review-form { margin-top: 0; }

.am-review-form__title {
	font-family: var(--font-display);
	font-size: var(--text-h3);
	margin-bottom: var(--space-5);
}

.am-review-form__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4);
	margin-bottom: var(--space-4);
}
@media (max-width: 640px) {
	.am-review-form__grid { grid-template-columns: 1fr; }
}

.am-field { display: grid; gap: var(--space-1); }
.am-field--full { grid-column: 1 / -1; }
.am-field--rating { align-content: start; }

.am-field__label {
	font-size: var(--text-body-s);
	color: var(--c-ink-soft);
}
.am-field__input {
	width: 100%;
	height: 44px;
	padding: 0 var(--space-3);
	background: var(--c-paper);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-1);
	font-family: var(--font-sans);
	font-size: var(--text-body);
	color: var(--c-ink);
	transition: border-color var(--duration-fast) var(--ease-out);
}
.am-field__textarea {
	height: auto;
	min-height: 88px;
	padding: var(--space-3);
	resize: vertical;
	line-height: 1.5;
}
.am-field__input:focus { outline: none; border-color: var(--c-ink); }
.am-field__input.cl_red { border-color: var(--c-sale); }

/* Зірки оцінки */
.am-review-form .detail-tab-reviews-add-stars {
	display: inline-flex;
	gap: var(--space-1);
	cursor: pointer;
}
.am-review-form .detail-tab-reviews-add-stars-i {
	width: 26px; height: 26px;
	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23E5DDD2"><path d="M12 .587l3.668 7.431 8.2 1.192-5.934 5.787 1.402 8.168L12 18.896l-7.336 3.869 1.402-8.168L.132 9.21l8.2-1.192z"/></svg>') no-repeat center;
	background-size: 24px 24px;
	transition: transform var(--duration-fast) var(--ease-out);
}
.am-review-form .detail-tab-reviews-add-stars-i:hover { transform: scale(1.1); }
.am-review-form .detail-tab-reviews-add-stars-i.active {
	background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23B8842E"><path d="M12 .587l3.668 7.431 8.2 1.192-5.934 5.787 1.402 8.168L12 18.896l-7.336 3.869 1.402-8.168L.132 9.21l8.2-1.192z"/></svg>');
}

/* Успіх-повідомлення (cms7.js показує після submit) */
.am-review-form__success {
	display: none;
	margin-top: var(--space-4);
	padding: var(--space-4) var(--space-5);
	background: var(--c-paper-2);
	border-radius: var(--radius-2);
	font-size: var(--text-body-s);
}
