/* professorantalfekete-main.css — generated; edit the source modules in assets/css/, not this file. */

/* ===== base.css ===== */
/* base.css — reset + base elements + tokens + shared layout/buttons.
   Brand: navy #143D55, gold #A47C13. Body Inter 18px, headings Trirong (light).
   Per-section styles live in assets/css/components/<name>.css. Mirrors theme.json. */

:root {
	--navy: #143D55;
	--navy-dark: #0e2c3e;
	--navy-border: #5B8AA6;
	--navy-soft: #8CB4C9;
	--gold: #A47C13;
	--gold-dark: #8a6410;
	--fg: #143D55;
	--body: #4b5563;        /* gray-600 — body copy */
	--muted: #6b7280;       /* gray-500 */
	--bg: #ffffff;
	--surface: #f9fafb;     /* gray-50 */
	--surface-2: #f3f4f6;   /* gray-100 */
	--surface-3: #e5e7eb;   /* gray-200 */
	--border: #e5e7eb;
	--container: 1280px;
	--radius: 0;            /* design uses square corners on cards/buttons */
	--shadow-card: 0 10px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.1);
	--shadow-lg: 0 25px 50px -12px rgba(0,0,0,.25);
}

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

html { font-size: 18px; -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	font-size: 1.125rem;
	line-height: 1.65;
	color: var(--body);
	background: var(--bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--gold); }

/* ---------- Headings (Trirong, light) ---------- */
h1, h2, h3, h4, h5, h6 {
	font-family: 'Trirong', Georgia, 'Times New Roman', serif;
	font-weight: 300;
	line-height: 1.2;
	color: var(--navy);
	margin: 0 0 .5em;
}
h1 { font-size: clamp(2.75rem, 5vw, 3.75rem); }
h2 { font-size: clamp(2.25rem, 4vw, 3rem); }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; line-height: 1.4; }

p { margin: 0 0 1rem; }
p:last-child { margin-bottom: 0; }

/* ---------- Layout ---------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: 1rem;
}
@media (min-width: 640px) { .container { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .container { padding-inline: 2rem; } }

/* Narrower reading container for long-form text (about biography, etc.) */
.container--narrow { max-width: 56rem; }
.container--prose { max-width: 64rem; }

/* Section vertical rhythm */
.section { padding-block: 5rem; }
.section--sm { padding-block: 4rem; }
@media (max-width: 768px) {
	.section { padding-block: 3.5rem; }
	.section--sm { padding-block: 2.5rem; }
}

.bg-surface { background: var(--surface); }
.bg-navy { background: var(--navy); color: #fff; }

/* ---------- Buttons ---------- */
.btn {
	display: inline-block;
	font-family: 'Inter', sans-serif;
	font-weight: 500;
	font-size: 1rem;
	line-height: 1.2;
	letter-spacing: .03em;
	text-align: center;
	border: 1px solid transparent;
	border-radius: var(--radius);
	padding: .85rem 2rem;
	cursor: pointer;
	transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}
.btn-primary { background: var(--gold); color: #fff; }
.btn-primary:hover { background: var(--gold-dark); color: #fff; }
.btn-outline-gold { background: #fff; color: var(--gold); border-color: var(--gold); }
.btn-outline-gold:hover { background: var(--gold); color: #fff; }
.btn-block { display: block; width: 100%; }
.btn-lg { padding: 1rem 2rem; font-size: 1.125rem; }

/* small uppercase eyebrow label (e.g. "PROFESSOR") */
.eyebrow {
	color: var(--gold);
	text-transform: uppercase;
	letter-spacing: .1em;
	font-size: .875rem;
	font-weight: 500;
	margin: 0 0 1rem;
}

/* ---------- Accessibility ---------- */
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 1rem; top: 1rem; background:#fff; padding:.5rem 1rem; z-index:1000; }
.screen-reader-text {
	position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }


/* ===== components/chrome.css ===== */
/* chrome.css — shared header + footer (ported from the design's Header.tsx / Footer.tsx). */

/* wp_nav_menu prints bare <li> items (items_wrap '%3$s'); kill the list bullets
   on every theme nav so no menu ever shows the default disc marker. */
.main-nav, .main-nav li,
.footer-nav, .footer-nav li { list-style: none; }

/* ===================== HEADER ===================== */
.site-header {
	background: #fff;
	border-bottom: 1px solid var(--border);
	position: relative;
	z-index: 50;
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 5rem;
}
.site-header__logo img,
.site-header__logo .custom-logo {
	height: 3rem;
	width: auto;
	display: block;
}

.main-nav {
	display: flex;
	align-items: center;
	gap: 2rem;
	list-style: none;
	margin: 0;
	padding: 0;
}
.main-nav li {
	list-style: none;
	margin: 0;
}
.main-nav a {
	font-weight: 600;
	font-size: 1rem;
	color: var(--navy);
	transition: color .2s ease;
}
.main-nav a:hover,
.main-nav .current-menu-item > a,
.main-nav .current_page_item > a {
	color: var(--gold);
}

/* Cart icon */
.header-cart {
	position: relative;
	display: inline-flex;
	color: var(--navy);
	transition: color .2s ease;
}
.header-cart:hover { color: var(--gold); }
.header-cart svg { width: 1.5rem; height: 1.5rem; display: block; }
.header-cart__count {
	position: absolute;
	top: -.5rem;
	right: -.5rem;
	background: var(--gold);
	color: #fff;
	font-size: .7rem;
	line-height: 1;
	font-weight: 600;
	min-width: 1.25rem;
	height: 1.25rem;
	border-radius: 999px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 .25rem;
	font-family: 'Inter', sans-serif;
}

/* Mobile nav toggle */
.nav-toggle {
	display: none;
	background: none;
	border: 0;
	color: var(--navy);
	cursor: pointer;
	padding: .5rem;
}
.nav-toggle svg { width: 1.75rem; height: 1.75rem; }

@media (max-width: 880px) {
	.nav-toggle { display: inline-flex; }
	.main-nav {
		position: absolute;
		top: 5rem;
		left: 0;
		right: 0;
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
		background: #fff;
		border-bottom: 1px solid var(--border);
		box-shadow: var(--shadow-card);
		padding: .5rem 0;
		display: none;
	}
	.main-nav.is-open { display: flex; }
	.main-nav li { width: 100%; }
	.main-nav a { display: block; width: 100%; padding: .85rem 1.5rem; }
	.main-nav .header-cart { padding: .85rem 1.5rem; }
	.main-nav .header-cart__count { position: static; margin-left: .5rem; }
}

/* ===================== FOOTER ===================== */
.site-footer {
	background: var(--navy);
	color: #fff;
}
.site-footer__inner { padding-block: 3rem; }
.site-footer__top {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
	margin-bottom: 2rem;
	text-align: center;
}
.site-footer__logo { width: 6rem; height: 6rem; }
.site-footer__logo img { width: 100%; height: 100%; object-fit: contain; }
.site-footer__title {
	font-size: 1.5rem;
	font-weight: 600;
	color: #fff;
	margin: 0;
	letter-spacing: .02em;
}
.footer-nav {
	display: flex;
	align-items: center;
	gap: 2rem;
	flex-wrap: wrap;
	justify-content: center;
	list-style: none;
	margin: 0;
	padding: 0;
}
.footer-nav li { list-style: none; margin: 0; }
.footer-nav a { color: #fff; transition: color .2s ease; }
.footer-nav a:hover { color: var(--gold); }

.footer-social { display: flex; align-items: center; gap: 1rem; }
.footer-social a {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 999px;
	background: rgba(255,255,255,.1);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	transition: background-color .2s ease;
}
.footer-social a:hover { background: rgba(255,255,255,.2); color: #fff; }
.footer-social svg { width: 1.25rem; height: 1.25rem; }

.site-footer__bottom {
	border-top: 1px solid rgba(255,255,255,.1);
	padding-top: 2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}
.site-footer__copy { font-size: .875rem; color: rgba(255,255,255,.7); margin: 0; }
.scroll-top {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 999px;
	background: rgba(255,255,255,.1);
	border: 0;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background-color .2s ease;
}
.scroll-top:hover { background: rgba(255,255,255,.2); }
.scroll-top svg { width: 1.25rem; height: 1.25rem; }


/* ===== components/sections.css ===== */
/* sections.css — block-engine marketing sections (Home, About, Contact).
   Ported from the design; loaded front end + editor canvas. */

/* Centered section heads used on Home featured + others */
.section-title-center { text-align: center; margin-bottom: 1rem; }
.section-lede-center {
	text-align: center;
	max-width: 48rem;
	margin: 0 auto 3rem;
	color: var(--body);
}

/* ============================================================
   HOME · HERO  (split background, text left, image right)
   ============================================================ */
.home-hero { position: relative; overflow: hidden; }
@media (min-width: 768px) { .home-hero { min-height: 600px; } }

.home-hero__bg { position: absolute; inset: 0; display: flex; }
.home-hero__bg-light { flex: 1; background: var(--surface); }
.home-hero__bg-navy { width: 42%; background: var(--navy); }
@media (max-width: 767px) {
	.home-hero__bg { flex-direction: column; }
	.home-hero__bg-light { flex: 1; }
	.home-hero__bg-navy { width: 100%; height: 16rem; }
}

.home-hero__inner { position: relative; z-index: 1; }
@media (min-width: 768px) {
	.home-hero__inner { display: flex; align-items: stretch; min-height: 600px; }
}
.home-hero__text {
	position: relative;
	z-index: 2;
	padding-block: 4rem;
}
@media (min-width: 768px) {
	.home-hero__text { width: 50%; padding-block: 5rem; padding-right: 3rem; align-self: center; }
}
.home-hero__title { color: var(--navy); margin-bottom: 1.5rem; }
.home-hero__lede {
	color: var(--body);
	margin-bottom: 2rem;
	max-width: 32rem;
	line-height: 1.7;
}
.home-hero__btn { letter-spacing: .05em; }

.home-hero__media { position: relative; }
@media (min-width: 768px) {
	.home-hero__media {
		position: absolute;
		bottom: 0;
		right: 0;
		width: 50%;
		height: 100%;
		display: flex;
		align-items: flex-end;
		justify-content: center;
	}
}
.home-hero__img { width: 100%; max-width: 22rem; height: auto; object-fit: contain; object-position: bottom; margin: 2rem auto 0; }
@media (min-width: 768px) {
	.home-hero__img { max-width: none; height: 100%; width: auto; margin: 0; }
}

/* ============================================================
   HOME · FEATURED E-BOOKS  (2-up book cards)
   ============================================================ */
.featured-grid {
	display: grid;
	gap: 2rem;
	max-width: 56rem;
	margin: 0 auto;
}
@media (min-width: 768px) { .featured-grid { grid-template-columns: repeat(2, 1fr); } }

.book-card { background: #fff; box-shadow: var(--shadow-card); overflow: hidden; }
.book-card__media {
	display: flex;
	justify-content: center;
	padding: 2rem;
	background: linear-gradient(to bottom right, var(--surface), #fff);
}
.book-card__media img { width: 16rem; height: auto; box-shadow: var(--shadow-lg); }
.book-card__body { padding: 1.5rem; }
.book-card__title { margin-bottom: .75rem; font-size: 1.5rem; }
.book-card__title a { color: var(--navy); }
.book-card__title a:hover { color: var(--gold); }
.book-card__desc { color: var(--body); font-size: .95rem; margin-bottom: 1rem; line-height: 1.6; }
.book-card__btn { font-size: .9rem; padding: .55rem 1.5rem; }

/* ============================================================
   HOME · ABOUT PREVIEW  (image+caption left, text right)
   ============================================================ */
.about-preview__grid {
	display: grid;
	gap: 3rem;
	align-items: center;
}
@media (min-width: 768px) { .about-preview__grid { grid-template-columns: repeat(2, 1fr); } }
.about-preview__img { width: 100%; height: auto; box-shadow: var(--shadow-lg); }
.about-preview__caption {
	text-align: center;
	font-size: .9rem;
	color: var(--body);
	font-style: italic;
	margin-top: 1rem;
}
.about-preview__text h2 { margin-bottom: 1.5rem; }
.about-preview__body { color: var(--body); margin-bottom: 1.5rem; line-height: 1.7; }
@media (max-width: 767px) {
	.about-preview__media { order: 2; }
	.about-preview__text { order: 1; }
}

/* ============================================================
   HOME · TESTIMONIALS  (two navy quote cards)
   ============================================================ */
.testimonials { background: linear-gradient(to bottom right, var(--surface-2), var(--surface-3)); }
.testimonials__grid { display: grid; gap: 2rem; }
@media (min-width: 768px) { .testimonials__grid { grid-template-columns: repeat(2, 1fr); } }
.testimonial-card {
	background: var(--navy);
	color: #fff;
	padding: 2.5rem;
	box-shadow: var(--shadow-lg);
	margin: 0;
}
.testimonial-card__quote {
	font-family: 'Trirong', serif;
	font-size: 1.25rem;
	line-height: 1.7;
	font-style: italic;
	margin: 0 0 1.5rem;
	color: #fff;
}
.testimonial-card:nth-child(2) .testimonial-card__quote { font-style: normal; }
.testimonial-card__author { font-weight: 600; color: #fff; }

/* ============================================================
   ABOUT · HERO  (navy-framed image left, text right)
   ============================================================ */
.about-hero__grid { display: grid; gap: 3rem; align-items: start; }
@media (min-width: 768px) { .about-hero__grid { grid-template-columns: repeat(2, 1fr); } }
.about-hero__media { background: var(--navy); padding: 2rem; }
.about-hero__img { width: 100%; height: auto; display: block; }
.about-hero__text h1 { margin-bottom: 2rem; }
.about-hero__body { color: var(--body); line-height: 1.8; margin-bottom: 1.5rem; }

/* ============================================================
   ABOUT · BIOGRAPHY
   ============================================================ */
.about-bio__title { margin-bottom: 3rem; }
.about-bio__body { display: flex; flex-direction: column; gap: 1.5rem; color: var(--body); line-height: 1.8; }
.about-bio__body p { margin: 0; }

/* ============================================================
   CONTACT  (form left, navy info box right)
   ============================================================ */
.contact-section { background: var(--surface); }
.contact-section__title { margin-bottom: 4rem; }
.contact-section__grid { display: grid; gap: 3rem; }
@media (min-width: 1024px) { .contact-section__grid { grid-template-columns: repeat(2, 1fr); } }

.contact-section__info { background: var(--navy); color: #fff; padding: 2.5rem; display: flex; flex-direction: column; justify-content: center; }
.contact-info__title { color: #fff; font-size: 1.875rem; margin-bottom: 1.5rem; }
.contact-info__text { margin-bottom: 2rem; line-height: 1.7; color: rgba(255,255,255,.92); }
.contact-info__rows { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-info__row { display: flex; align-items: flex-start; gap: 1rem; }
.contact-info__icon { color: var(--gold); flex-shrink: 0; margin-top: .15rem; }
.contact-info__icon svg { width: 1.5rem; height: 1.5rem; }
.contact-info__label { font-weight: 600; margin: 0 0 .25rem; color: #fff; }
.contact-info__value { margin: 0; }
.contact-info__value a, .contact-info__value { color: var(--gold); }

/* Contact Form 7 — styled to the design (inputs + gold submit) */
.paf-contact-form .paf-field { margin-bottom: 1.5rem; }
.paf-contact-form input[type="text"],
.paf-contact-form input[type="email"],
.paf-contact-form input[type="tel"],
.paf-contact-form textarea {
	width: 100%;
	border: 1px solid #d1d5db;
	border-radius: 0;
	padding: .85rem 1rem;
	font-family: 'Inter', sans-serif;
	font-size: 1rem;
	color: var(--navy);
	background: #fff;
}
.paf-contact-form input::placeholder,
.paf-contact-form textarea::placeholder { color: var(--muted); letter-spacing: .03em; }
.paf-contact-form input:focus,
.paf-contact-form textarea:focus { outline: none; border-color: var(--navy); }
.paf-contact-form textarea { min-height: 9rem; resize: vertical; }
.paf-contact-form .paf-field--submit { margin-bottom: 0; }
.paf-contact-form input[type="submit"] {
	background: var(--gold);
	color: #fff;
	border: 0;
	border-radius: 0;
	padding: .85rem 2rem;
	font-family: 'Inter', sans-serif;
	font-weight: 500;
	letter-spacing: .05em;
	cursor: pointer;
	transition: background-color .2s ease;
}
.paf-contact-form input[type="submit"]:hover { background: var(--gold-dark); }
.paf-contact-form .wpcf7-spinner { margin: 0 0 0 .5rem; }

/* ============================================================
   404
   ============================================================ */
.error-404 {
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--surface);
	padding: 4rem 1rem;
}
.error-404__inner { text-align: center; }
.error-404__code { font-size: clamp(4rem, 10vw, 6rem); color: var(--navy); margin-bottom: 1rem; line-height: 1; }
.error-404__text { font-size: 1.25rem; color: var(--body); margin-bottom: 2rem; }

/* ============================================================
   Editor-canvas niceties: partials render a placeholder note.
   ============================================================ */
.dtw-part-placeholder {
	border: 1px dashed var(--border);
	padding: 1.5rem;
	text-align: center;
	color: var(--muted);
	font-style: italic;
	background: var(--surface);
}


/* ===== components/woocommerce.css ===== */
/* woocommerce.css — restyle native WooCommerce (shop, product, cart, checkout)
   to the navy/gold design. Loaded only on Woo pages (inc/enqueue.php). */

/* The theme template wraps Woo content in .woo-wrap > .container */
.woo-wrap { padding-block: 4rem 5rem; }

/* ---------- Global Woo buttons → brand ---------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt {
	background: var(--gold);
	color: #fff;
	border-radius: 0;
	font-family: 'Inter', sans-serif;
	font-weight: 500;
	letter-spacing: .03em;
	text-transform: uppercase;
	font-size: .95rem;
	padding: .75rem 1.75rem;
	transition: background-color .2s ease;
	border: 0;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover { background: var(--gold-dark); color: #fff; }

.woocommerce .button.loading { opacity: .6; }

/* Woo notices in brand tone */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top-color: var(--gold);
	border-radius: 0;
}
.woocommerce-message::before,
.woocommerce-info::before { color: var(--gold); }
.woocommerce .woocommerce-message a.button { vertical-align: middle; }

/* Price color + keep "9 500 Ft" on one line (space thousands separator) */
.woocommerce .price,
.woocommerce span.amount,
.woocommerce .woocommerce-Price-amount { color: var(--navy); font-weight: 600; white-space: nowrap; }

/* ============================================================
   SHOP ARCHIVE  (e-Books)
   ============================================================ */
.woocommerce-products-header { text-align: center; margin-bottom: 1.5rem; }
.woocommerce-products-header__title.page-title,
.woocommerce .woocommerce-products-header__title {
	font-size: clamp(2.25rem, 4vw, 3rem);
	color: var(--navy);
	margin-bottom: 0;
}

/* The design shows an intro paragraph under the title + no result-count / ordering */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering { display: none; }

.shop-intro {
	text-align: center;
	max-width: 48rem;
	margin: 0 auto 3rem;
	color: var(--body);
	line-height: 1.7;
}

/* 2-up product grid, centered cards (cover on soft gradient panel) */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 3rem;
	max-width: 56rem;
	margin: 0 auto;
	padding: 0;
	list-style: none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none; display: none; }
@media (max-width: 700px) { .woocommerce ul.products { grid-template-columns: 1fr; gap: 2rem; } }

.woocommerce ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	text-align: center;
}
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link { display: block; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: 'Trirong', serif;
	font-size: 1.5rem;
	font-weight: 300;
	color: var(--navy);
	padding: 0;
	margin: 1.25rem 0 .5rem;
}
.woocommerce ul.products li.product:hover .woocommerce-loop-product__title { color: var(--gold); }
/* Cover panel: a soft gradient card; the book cover sits inside it in its real
   portrait (book) proportions, never cropped to a square. */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	background: linear-gradient(to bottom right, var(--surface), #fff);
	padding: 2.5rem;
	display: block;
	max-width: 18rem;
	margin: 0 auto;
	transition: box-shadow .2s ease;
}
.woocommerce ul.products li.product:hover a.woocommerce-LoopProduct-link { box-shadow: var(--shadow-card); }
.woocommerce ul.products li.product img {
	margin: 0 auto;
	width: 100%;
	height: auto;                  /* uncropped portrait cover keeps its own ratio */
	background: none;
	padding: 0;
	box-shadow: var(--shadow-card);
}
.woocommerce ul.products li.product .price {
	font-size: 1.25rem;
	color: var(--navy);
	display: block;
	margin-top: .25rem;
}
/* Hide the loop "BUY NOW" button on the shop archive — design shows price only */
.woocommerce ul.products li.product a.button.add_to_cart_button,
.woocommerce ul.products li.product a.added_to_cart { display: none; }

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
/* Breadcrumb (Home / e-Books / Title) */
.woocommerce .woocommerce-breadcrumb {
	color: var(--muted);
	font-size: .9rem;
	margin-bottom: 2rem;
	padding: 1rem 0;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--muted); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--navy); }

.woocommerce div.product { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
@media (max-width: 860px) { .woocommerce div.product { grid-template-columns: 1fr; } }

.woocommerce div.product .woocommerce-product-gallery {
	width: 100% !important;
	margin: 0;
	background: linear-gradient(to bottom right, var(--surface), #fff);
	padding: 3rem;
	align-self: start;
}
.woocommerce div.product .woocommerce-product-gallery img {
	box-shadow: var(--shadow-lg);
	height: auto;                  /* uncropped portrait cover keeps its own ratio */
}

.woocommerce div.product .summary { margin: 0 !important; width: auto !important; float: none !important; }
.woocommerce div.product .product_title {
	font-size: clamp(2rem, 3vw, 2.5rem);
	color: var(--navy);
	margin-bottom: 1rem;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-size: 1.875rem;
	color: var(--navy);
	font-weight: 600;
	margin-bottom: 1.5rem;
}
.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--body);
	line-height: 1.7;
	margin-bottom: 1.5rem;
}
.woocommerce div.product form.cart { margin-bottom: 1.5rem; }
.woocommerce div.product form.cart .quantity { margin-right: .75rem; }
.woocommerce div.product form.cart .quantity input.qty {
	width: 4rem; padding: .75rem .5rem; border: 1px solid var(--border); border-radius: 0; text-align: center;
}
.woocommerce div.product .single_add_to_cart_button {
	width: 100%;
	padding: 1rem;
	font-size: 1.05rem;
}
.woocommerce div.product .product_meta { font-size: .9rem; color: var(--muted); margin-top: 1rem; }
.woocommerce div.product .product_meta .posted_in a { color: var(--navy); }

/* Four meta cards (from SCF, rendered by paf_render_product_meta_cards) */
.product-meta-cards {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
	margin: 2rem 0;
}
.product-meta-card {
	background: var(--navy);
	border: 2px solid var(--navy-border);
	color: #fff;
	padding: 2rem;
	text-align: center;
}
.product-meta-card__icon { display: inline-flex; color: var(--gold); margin-bottom: 1rem; }
.product-meta-card__icon svg { width: 3rem; height: 3rem; }
.product-meta-card__label {
	font-family: 'Trirong', serif;
	font-size: 1.25rem;
	font-weight: 600;
	color: #fff;
	margin: 0 0 .5rem;
}
.product-meta-card__value { font-size: 1.05rem; color: var(--navy-soft); margin: 0; }

/* Full description box (navy) — placed via the description tab; design shows a navy block.
   We render the long description inside tabs; give the tab panel a navy treatment only
   when it's the description below the summary is handled by the tabs styling below. */

/* Tabs (Description / Reviews) */
.woocommerce div.product .woocommerce-tabs { grid-column: 1 / -1; margin-top: 3rem; }
.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding: 0 0 0 0;
	margin: 0 0 2rem;
	border-bottom: 1px solid var(--border);
	display: flex;
	gap: 2rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: none;
	border: 0;
	border-radius: 0;
	padding: 0 0 1rem;
	margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { border: 0; box-shadow: none; content: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	color: var(--muted);
	font-weight: 600;
	padding: 0;
	font-size: 1.05rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--navy); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	border-bottom: 2px solid var(--navy);
	margin-bottom: -1px;
}
.woocommerce div.product .woocommerce-tabs .panel {
	color: var(--body);
	line-height: 1.8;
	margin: 0;
	padding: 0;
	max-width: 60rem;             /* readable prose measure, not full page width */
}
.woocommerce div.product .woocommerce-tabs .panel h2 { color: var(--navy); }

/* Related products */
.woocommerce .related.products {
	grid-column: 1 / -1;
	margin-top: 4rem;
	padding-top: 3rem;
	border-top: 1px solid var(--border);
}
.woocommerce .related.products > h2 {
	font-size: 2rem;
	color: var(--navy);
	margin-bottom: 2rem;
}

/* ============================================================
   CART  (classic table layout)
   ============================================================ */
.woocommerce-cart .woo-wrap > .container > h1,
.woocommerce-cart .entry-title { color: var(--navy); margin-bottom: 2rem; }

.woocommerce-cart table.shop_table {
	border: 1px solid var(--border);
	border-radius: 0;
	background: #fff;
	box-shadow: var(--shadow-card);
}
.woocommerce-cart table.shop_table th {
	background: var(--surface);
	color: var(--navy);
	font-weight: 600;
	padding: 1rem;
	border-bottom: 1px solid var(--border);
}
.woocommerce-cart table.shop_table td { padding: 1.25rem 1rem; border-top: 1px solid var(--border); vertical-align: middle; }
.woocommerce-cart table.shop_table img {
	width: 3.25rem;
	height: auto;                  /* keep the cover's own portrait ratio, no crop */
	box-shadow: var(--shadow-card);
}
.woocommerce-cart .product-name a { color: var(--navy); font-weight: 500; }
.woocommerce-cart .product-name a:hover { color: var(--gold); }
.woocommerce a.remove {
	color: #ef4444 !important;
	border-radius: 0;
	font-weight: 400;
}
.woocommerce a.remove:hover { background: transparent; color: #b91c1c !important; }
.woocommerce-cart td.actions .coupon {
	display: flex;
	gap: 1rem;
	max-width: 32rem;
	float: none;
}
.woocommerce-cart td.actions .coupon .input-text {
	border: 1px solid var(--border);
	border-radius: 0;
	padding: .65rem 1rem;
	flex: 1 1 auto;
	width: auto !important;       /* Woo sets a tiny fixed width — override */
	min-width: 0;
}
.woocommerce-cart td.actions .coupon .button { flex: 0 0 auto; white-space: nowrap; }
.woocommerce-cart td.actions .coupon .button { background: #fff; color: var(--gold); border: 1px solid var(--gold); }
.woocommerce-cart td.actions .coupon .button:hover { background: var(--gold); color: #fff; }

/* Cart totals box */
.woocommerce-cart .cart-collaterals,
.woocommerce-cart .cart-collaterals .cross-sells { width: 100% !important; }
.woocommerce-cart .cart_totals {
	background: #fff;
	border: 1px solid var(--border);
	box-shadow: var(--shadow-card);
	padding: 1.5rem;
	float: none !important;        /* Woo floats this 48% — override to fill the column */
	width: 100% !important;
}
.woocommerce-cart .cart_totals h2 { color: var(--navy); font-size: 1.5rem; margin-bottom: 1.5rem; }
.woocommerce-cart .cart_totals table { border: 0; width: 100%; margin: 0; border-collapse: collapse; }
.woocommerce-cart .cart_totals table tr { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; border-top: 1px solid var(--border); }
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
	border: 0;
	padding: .85rem 0;
	background: transparent;
}
.woocommerce-cart .cart_totals table th { color: var(--body); font-weight: 500; text-align: left; }
.woocommerce-cart .cart_totals table td { text-align: right; font-weight: 600; color: var(--navy); }
.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td { font-size: 1.15rem; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	background: var(--gold); color: #fff; width: 100%; text-align: center; padding: 1rem; font-size: 1.05rem;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover { background: var(--gold-dark); }

/* Two-column cart layout on desktop (table left, totals right) — design shows this */
@media (min-width: 1024px) {
	.woocommerce-cart .woocommerce { display: grid; grid-template-columns: 2fr 1fr; gap: 2rem; align-items: start; }
	.woocommerce-cart .woocommerce-cart-form { grid-column: 1; }
	.woocommerce-cart .cart-collaterals { grid-column: 2; }
	.woocommerce-cart .woocommerce-notices-wrapper { grid-column: 1 / -1; }
}

/* ============================================================
   CHECKOUT
   ============================================================ */
.woocommerce-checkout .entry-title { color: var(--navy); margin-bottom: 2rem; }
.woocommerce-checkout h3 { color: var(--navy); font-size: 1.5rem; margin-bottom: 1.5rem; }
.woocommerce-checkout .col2-set,
.woocommerce-checkout #customer_details { width: 100%; }
.woocommerce form .form-row label { color: #374151; font-weight: 500; margin-bottom: .35rem; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout select,
.select2-container .select2-selection {
	border: 1px solid var(--border) !important;
	border-radius: 0 !important;
	padding: .75rem 1rem !important;
	min-height: auto;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { outline: none; border-color: var(--gold) !important; }

.woocommerce-checkout #payment {
	background: #fff;
	border: 1px solid var(--border);
	border-radius: 0;
}
.woocommerce-checkout #payment ul.payment_methods { border-bottom: 1px solid var(--border); }
.woocommerce-checkout #payment div.payment_box { background: var(--surface); border-radius: 0; }
.woocommerce-checkout #payment div.payment_box::before { display: none; }
.woocommerce-checkout #place_order { width: 100%; padding: 1rem; font-size: 1.1rem; }

.woocommerce-checkout .woocommerce-checkout-review-order table.shop_table {
	border: 1px solid var(--border); border-radius: 0;
}
.woocommerce-checkout .woocommerce-checkout-review-order th { color: var(--navy); }

@media (min-width: 1024px) {
	.woocommerce-checkout form.checkout { display: grid; grid-template-columns: 2fr 1fr; gap: 2rem; align-items: start; }
	.woocommerce-checkout #customer_details { grid-column: 1; }
	.woocommerce-checkout #order_review_heading,
	.woocommerce-checkout #order_review { grid-column: 2; }
}

/* ============================================================
   Closing testimonial band (shop + single product)
   ============================================================ */
.woo-testimonial { margin-top: 4rem; margin-bottom: 2rem; }
.woo-testimonial__card {
	background: var(--navy);
	color: #fff;
	padding: 3rem;
	box-shadow: var(--shadow-lg);
	max-width: 56rem;
	margin: 0 auto;
	text-align: center;
}
.woo-testimonial__quote {
	font-family: 'Trirong', serif;
	font-size: 1.25rem;
	line-height: 1.7;
	font-style: italic;
	color: #fff;
	margin: 0 0 1.5rem;
	border: 0;
	padding: 0;
}
.woo-testimonial__author { font-weight: 600; color: #fff; margin: 0; }

