/*
Theme Name: Iceberg
Theme URI: https://github.com/NoamMuchtar/iceberg-theme
Author: Noam Muchtar
Author URI: https://github.com/NoamMuchtar
Description: A modern WordPress + WooCommerce theme with clean design and RTL support.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: iceberg
Domain Path: /languages
Tags: woocommerce, rtl-language-support, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready

Iceberg WordPress Theme, (C) 2026 Noam Muchtar
Iceberg is distributed under the terms of the GNU GPL v2 or later.
*/

/* ==========================================================================
   Variables
   ========================================================================== */

:root {
	--primary: #3f2d8f;
	--primary-hover: #342476;
	--primary-5: rgba(63, 45, 143, 0.05);
	--primary-10: rgba(63, 45, 143, 0.1);
	--primary-20: rgba(63, 45, 143, 0.2);
	--primary-30: rgba(63, 45, 143, 0.3);
	--bg-light: #f6f6f8;
	--bg-dark: #16141e;
	--white: #ffffff;
	--slate-50: #f8fafc;
	--slate-100: #f1f5f9;
	--slate-200: #e2e8f0;
	--slate-300: #cbd5e1;
	--slate-400: #94a3b8;
	--slate-500: #64748b;
	--slate-600: #475569;
	--slate-700: #334155;
	--slate-800: #1e293b;
	--slate-900: #0f172a;
	--green-600: #16a34a;
	--red-600: #dc2626;
	--radius: 0.25rem;
	--radius-lg: 0.5rem;
	--radius-xl: 0.75rem;
	--radius-2xl: 1rem;
	--radius-full: 9999px;
	--shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
	--shadow-md: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -2px rgba(0,0,0,0.1);
	--shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -4px rgba(0,0,0,0.1);
	--shadow-xl: 0 20px 25px -5px rgba(0,0,0,0.1), 0 8px 10px -6px rgba(0,0,0,0.1);
	--transition: 0.2s ease;
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */

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

body {
	margin: 0;
	font-family: 'Assistant', sans-serif;
	font-size: 16px;
	line-height: 1.6;
	color: var(--slate-900);
	background: var(--bg-light);
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--primary-hover); }

h1, h2, h3, h4, h5, h6 { margin-top: 0; line-height: 1.25; }

ul, ol { padding: 0; margin: 0; }

.screen-reader-text {
	border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
	height: 1px; margin: -1px; overflow: hidden; padding: 0;
	position: absolute !important; width: 1px; word-wrap: normal !important;
}

/* ==========================================================================
   Header
   ========================================================================== */

.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255,255,255,0.95);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--primary-10);
	padding: 0 1rem;
}

@media (min-width: 1024px) { .site-header { padding: 0 5rem; } }

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1rem 0;
}

.header-brand {
	display: flex;
	align-items: center;
	gap: 0;
}
@media (min-width: 1024px) { .header-brand { gap: 3rem; } }

.header-brand__link {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration: none;
}

.header-brand__icon {
	background: var(--primary);
	padding: 0.5rem;
	border-radius: var(--radius-lg);
	color: var(--white);
	display: flex;
}

.header-brand__name {
	color: var(--primary);
	font-size: 1.25rem;
	font-weight: 900;
	line-height: 1.25;
	letter-spacing: -0.025em;
	margin: 0;
}

.header-nav {
	display: none;
	align-items: center;
	gap: 2rem;
}

@media (min-width: 1024px) { .header-nav { display: flex; } }

.header-nav__link {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--slate-700);
	text-decoration: none;
	transition: color var(--transition);
}
.header-nav__link:hover, .header-nav__link.is-active { color: var(--primary); }

.header-actions {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.header-phone {
	display: none;
	flex-direction: column;
	align-items: flex-end;
	margin-inline-start: 1rem;
	text-decoration: none;
}

@media (min-width: 768px) { .header-phone { display: flex; } }

.header-phone__label {
	font-size: 0.75rem;
	color: var(--slate-500);
}

.header-phone__number {
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--slate-900);
}

.header-quote-btn {
	display: none;
	background: var(--primary);
	color: var(--white);
	padding: 0.625rem 1.5rem;
	border-radius: var(--radius-lg);
	font-size: 0.875rem;
	font-weight: 700;
	border: none;
	cursor: pointer;
	transition: background var(--transition);
	box-shadow: 0 4px 12px rgba(63,45,143,0.2);
	font-family: inherit;
}
.header-quote-btn:hover { background: var(--primary-hover); }

@media (min-width: 768px) { .header-quote-btn { display: inline-flex; } }

.header-search {
	display: flex;
	align-items: center;
	background: var(--primary-5);
	border-radius: var(--radius-lg);
	padding: 0.375rem 0.75rem;
	border: 1px solid var(--primary-10);
	transition: border-color var(--transition);
}
.header-search:focus-within { border-color: var(--primary); }


.header-search .material-symbols-outlined { color: var(--slate-500); font-size: 1.25rem; }

.header-search input {
	background: transparent;
	border: none;
	outline: none;
	font-size: 0.875rem;
	width: 6rem;
	font-family: inherit;
	color: var(--slate-900);
}
@media (max-width: 1023px) {
	.header-search { flex: 1; }
	.header-search input { width: 100%; }
}
@media (min-width: 640px) and (max-width: 1023px) { .header-search input { width: 100%; } }
@media (min-width: 1024px) { .header-search input { width: 12rem; } }
.header-search input::placeholder { color: var(--slate-400); }

.header-search form { display: flex; align-items: center; }

.mobile-menu-toggle {
	display: none;
	background: transparent;
	border: none;
	color: var(--slate-700);
	cursor: pointer;
}
.mobile-menu-toggle .material-symbols-outlined { font-size: 1.875rem; }

@media (max-width: 1023px) { .mobile-menu-toggle { display: block; } }

/* Mobile menu – fullscreen overlay */
.mobile-menu {
	position: fixed;
	inset: 0;
	z-index: 100;
	background: var(--white);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	transform: translateX(-100%);
	opacity: 0;
	visibility: hidden;
	transition: transform 0.4s cubic-bezier(.4,0,.2,1), opacity 0.35s, visibility 0s 0.4s;
}

.mobile-menu__close {
	position: absolute;
	top: 1rem;
	left: 1rem;
	background: transparent;
	border: none;
	color: var(--slate-700);
	cursor: pointer;
	padding: 0.5rem;
	z-index: 1;
}
.mobile-menu__close .material-symbols-outlined { font-size: 2rem; }
.mobile-menu.is-open {
	transform: translateX(0);
	opacity: 1;
	visibility: visible;
	transition: transform 0.4s cubic-bezier(.4,0,.2,1), opacity 0.35s, visibility 0s 0s;
}

.mobile-menu nav { width: 100%; }
.mobile-menu nav ul {
	list-style: none;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	padding: 0;
	margin: 0;
}
.mobile-menu nav a {
	display: block;
	padding: 0.75rem 1rem;
	color: var(--slate-700);
	font-weight: 700;
	font-size: 1.375rem;
	text-decoration: none;
	text-align: center;
	transition: color 0.2s;
}
.mobile-menu nav a:hover { color: var(--primary); }

.mobile-menu__phone {
	padding: 1.5rem 1rem 0;
	text-align: center;
}
.mobile-menu__phone a {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--primary);
	font-weight: 700;
	font-size: 1.125rem;
	text-decoration: none;
}

.mobile-menu__cta { padding: 1.5rem 2rem 0; width: 100%; max-width: 320px; }

.mobile-menu__quote-btn {
	width: 100%;
	background: var(--primary);
	color: var(--white);
	padding: 1rem 1.5rem;
	border-radius: var(--radius-lg);
	font-size: 1rem;
	font-weight: 700;
	border: none;
	cursor: pointer;
	font-family: inherit;
}

.iceberg-popup__desc {
	color: var(--slate-500);
	font-size: 0.875rem;
	margin-bottom: 1.5rem;
}

/* ==========================================================================
   Single Product
   ========================================================================== */

.sp-main {
	max-width: 1280px;
	margin: 0 auto;
	padding: 2rem 1rem;
}

/* ── Breadcrumbs ── */
.sp-breadcrumb {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--slate-500);
	margin-bottom: 1.5rem;
	list-style: none;
}
.sp-breadcrumb a { color: var(--slate-500); text-decoration: none; }
.sp-breadcrumb a:hover { color: var(--primary); }
.sp-breadcrumb .material-symbols-outlined { font-size: 0.75rem; }
.sp-breadcrumb__current { color: var(--slate-900); font-weight: 500; }

/* ── Hero Grid ── */
.sp-hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}
@media (min-width: 1024px) {
	.sp-hero { grid-template-columns: 7fr 5fr; }
}

/* ── Gallery ── */
.sp-gallery { display: flex; flex-direction: column; gap: 1rem; }

.sp-gallery__main {
	position: relative;
	aspect-ratio: 16/9;
	background: var(--white);
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid var(--slate-200);
	box-shadow: var(--shadow-sm);
}
.sp-gallery__main img { width: 100%; height: 100%; object-fit: cover; cursor: pointer; transition: transform 0.4s ease; }
.sp-gallery__main:hover img { transform: scale(1.03); }

.sp-gallery__badge {
	position: absolute;
	top: 1rem;
	right: 1rem;
	background: rgba(255,255,255,0.9);
	backdrop-filter: blur(4px);
	padding: 0.25rem 0.75rem;
	border-radius: var(--radius-full);
	display: flex;
	align-items: center;
	gap: 0.5rem;
	box-shadow: var(--shadow-sm);
	border: 1px solid var(--slate-100);
}
.sp-gallery__badge .flag { width: 1rem; height: 0.625rem; border-radius: 2px; display: inline-block; }
.sp-gallery__badge .flag--green { background: #16a34a; }
.sp-gallery__badge .flag--white { background: var(--white); border: 1px solid var(--slate-200); }
.sp-gallery__badge .flag--red { background: #dc2626; }
.sp-gallery__badge span:last-child { font-size: 10px; font-weight: 700; color: var(--slate-800); }

.sp-gallery__thumbs {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}

.sp-gallery__thumb {
	aspect-ratio: 1;
	background: var(--white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 2px solid var(--slate-200);
	opacity: 0.7;
	cursor: pointer;
	transition: opacity var(--transition), border-color var(--transition);
}
.sp-gallery__thumb:hover { opacity: 1; }
.sp-gallery__thumb.is-active { border-color: var(--primary); opacity: 1; }
.sp-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

.sp-gallery__thumb--more {
	position: relative;
	aspect-ratio: 1;
	background: var(--slate-200);
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}
.sp-gallery__thumb--more img { width: 100%; height: 100%; object-fit: cover; opacity: 0.3; }
.sp-gallery__thumb--more span {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	color: var(--slate-700);
}

/* Description under images */
.sp-description {
	margin-top: 1rem;
	color: var(--slate-600);
	line-height: 1.75;
}
.sp-description p { margin: 0 0 1em; }

/* ── Info Panel ── */
.sp-info { display: flex; flex-direction: column; gap: 1.5rem; }

.sp-info__series-label {
	color: var(--primary);
	font-weight: 700;
	font-size: 0.875rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.sp-info__title {
	font-size: 2.25rem;
	font-weight: 900;
	color: var(--slate-900);
	margin-top: 0.5rem;
	line-height: 1.15;
}

/* Highlights (key benefits in info panel) */
.sp-info .sp-highlights {
	background: var(--slate-50);
	padding: 1.5rem;
	border-radius: var(--radius-xl);
	border: 1px solid var(--slate-100);
}

/* Compatible-with tags */
.sp-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; }

.sp-tag {
	display: inline-flex;
	align-items: center;
	padding: 0.25rem 0.75rem;
	border-radius: var(--radius-full);
	background: var(--slate-100);
	color: var(--slate-700);
	font-size: 0.75rem;
	font-weight: 600;
	border: 1px solid var(--slate-200);
}

/* Series alert */
.sp-series-alert {
	background: var(--primary-5);
	border: 1px solid var(--primary-20);
	border-radius: var(--radius-xl);
	padding: 1rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.sp-series-alert__content { display: flex; align-items: center; gap: 0.75rem; }

.sp-series-alert__icon {
	padding: 0.5rem;
	background: var(--primary-10);
	border-radius: var(--radius-lg);
	color: var(--primary);
	display: flex;
}

.sp-series-alert__title { font-size: 0.875rem; font-weight: 700; color: var(--primary); margin: 0; }
.sp-series-alert__sub { font-size: 0.75rem; color: var(--slate-500); margin: 0; }

.sp-series-alert__link {
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--primary);
	text-decoration: underline;
	text-underline-offset: 4px;
	white-space: nowrap;
}
.sp-series-alert__link:hover { opacity: 0.8; }

/* CTA buttons */
.sp-cta { display: flex; flex-direction: column; gap: 0.75rem; padding-top: 1rem; border-top: 1px solid var(--slate-100); }

.sp-cta__primary {
	width: 100%;
	background: var(--primary);
	color: var(--white);
	padding: 1rem;
	border-radius: var(--radius-xl);
	font-weight: 700;
	font-size: 1.125rem;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: inherit;
	transition: box-shadow var(--transition);
}
.sp-cta__primary:hover { box-shadow: 0 10px 20px -5px rgba(63,45,143,0.2); }

.sp-cta__secondary {
	width: 100%;
	background: var(--white);
	color: var(--slate-900);
	border: 1px solid var(--slate-200);
	padding: 0.75rem;
	border-radius: var(--radius-xl);
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	text-decoration: none;
	font-family: inherit;
	font-size: 1rem;
	transition: background var(--transition);
}
.sp-cta__secondary:hover { background: var(--slate-50); color: var(--slate-900); }

/* ── Overview & FAQ ── */
.sp-overview {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	margin-top: 3rem;
}
@media (min-width: 1024px) { .sp-overview { grid-template-columns: 7fr 5fr; } }

.sp-section-title {
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.sp-section-title__accent {
	width: 2rem;
	height: 0.25rem;
	background: var(--primary);
	border-radius: var(--radius-full);
	display: inline-block;
}

.sp-overview__content { color: var(--slate-600); line-height: 1.75; }
.sp-overview__content p { margin: 0 0 1em; }

.sp-highlights {
	background: var(--slate-50);
	padding: 2rem;
	border-radius: var(--radius-2xl);
	border: 1px solid var(--slate-100);
}
.sp-highlights__title { font-size: 1.125rem; font-weight: 700; margin-bottom: 1.5rem; }

.sp-highlights__list { list-style: none; }
.sp-highlights__list li {
	display: flex;
	gap: 0.75rem;
	align-items: flex-start;
	padding-bottom: 1rem;
	margin-bottom: 1rem;
	border-bottom: 1px solid rgba(0,0,0,0.06);
	font-size: 0.875rem;
	color: var(--slate-600);
}
.sp-highlights__list li:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.sp-highlights__list .material-symbols-outlined { color: var(--primary); font-weight: 700; }

/* ── Specs & Dimensions ── */
.sp-specs { margin-top: 3rem; }

.sp-specs__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

.sp-specs__table-wrap {
	overflow: hidden;
	border: 1px solid var(--slate-200);
	border-radius: var(--radius-xl);
}
.sp-specs__table-scroll { overflow-x: auto; }

.sp-specs__table {
	width: 100%;
	text-align: right;
	font-size: 0.875rem;
	border-collapse: collapse;
}
.sp-specs__table tr { border-bottom: 1px solid var(--slate-100); }
.sp-specs__table tr:last-child { border-bottom: none; }
.sp-specs__table td { padding: 1rem 1.5rem; }
.sp-specs__table td:first-child {
	font-weight: 700;
	color: var(--slate-700);
	background: var(--slate-50);
	white-space: nowrap;
}
.sp-specs__table td:not(:first-child) { text-align: center; }

.sp-dims { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.sp-dim-card {
	background: var(--white);
	padding: 1.5rem;
	border-radius: var(--radius-xl);
	border: 1px solid var(--slate-200);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.sp-dim-card__label { font-size: 0.75rem; font-weight: 700; color: var(--slate-400); display: block; margin-bottom: 0.5rem; }
.sp-dim-card__value { font-size: 1.875rem; font-weight: 900; color: var(--primary); }
.sp-dim-card__unit { font-size: 0.875rem; font-weight: 700; color: var(--slate-500); margin-inline-start: 0.25rem; }
.sp-dim-card__note { margin-top: 1rem; border-top: 1px solid var(--slate-100); padding-top: 0.5rem; font-size: 10px; color: var(--slate-400); }

/* ── Manufacturer Link ── */
.sp-manufacturer {
	background: linear-gradient(to left, var(--primary-10), transparent);
	padding: 1.5rem;
	border-radius: var(--radius-2xl);
	border: 1px solid var(--primary-20);
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 2rem;
	gap: 1rem;
}
.sp-manufacturer__content { display: flex; align-items: center; gap: 1rem; }
.sp-manufacturer__icon {
	width: 3rem; height: 3rem;
	background: var(--white);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--shadow-sm);
	flex-shrink: 0;
}
.sp-manufacturer__icon .material-symbols-outlined { color: var(--primary); font-size: 1.875rem; }
.sp-manufacturer__title { font-weight: 700; margin: 0; }
.sp-manufacturer__sub { font-size: 0.875rem; color: var(--slate-500); margin: 0; }
.sp-manufacturer__link {
	padding: 0.5rem 1.5rem;
	background: var(--white);
	color: var(--primary);
	border: 1px solid var(--primary-30);
	border-radius: var(--radius-lg);
	font-weight: 700;
	font-size: 0.875rem;
	text-decoration: none;
	white-space: nowrap;
	transition: background var(--transition), color var(--transition);
}
.sp-manufacturer__link:hover { background: var(--primary); color: var(--white); }

/* ── Inquiries ── */
.sp-inquiries {
	margin-top: 3rem;
}

.sp-contact-form {
	background: var(--white);
	padding: 2rem;
	border-radius: var(--radius-2xl);
	box-shadow: var(--shadow-xl), 0 0 40px rgba(63,45,143,0.05);
	border: 1px solid var(--slate-100);
}
.sp-contact-form__title { font-size: 1.25rem; font-weight: 700; margin-bottom: 1.5rem; }

.sp-form { display: flex; flex-direction: column; gap: 1rem; }
.sp-form__label { display: block; font-size: 0.75rem; font-weight: 700; color: var(--slate-400); margin-bottom: 0.25rem; }
.sp-form__input,
.sp-form__textarea {
	width: 100%;
	border-radius: var(--radius-lg);
	border: 1px solid var(--slate-200);
	background: var(--slate-50);
	padding: 0.625rem 0.875rem;
	font-size: 0.875rem;
	font-family: inherit;
	color: var(--slate-900);
	transition: border-color var(--transition), box-shadow var(--transition);
}
.sp-form__input:focus, .sp-form__textarea:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 3px var(--primary-10);
}
.sp-form__input::placeholder, .sp-form__textarea::placeholder { color: var(--slate-400); }
.sp-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.sp-form__submit {
	width: 100%;
	background: var(--primary);
	color: var(--white);
	padding: 0.75rem;
	border-radius: var(--radius-lg);
	font-weight: 700;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: 1rem;
	transition: background var(--transition);
}
.sp-form__submit:hover { background: var(--primary-hover); }

.sp-form__note { font-size: 10px; text-align: center; color: var(--slate-400); margin-top: 0.5rem; font-style: italic; }

.iceberg-form-message { text-align: center; font-size: 0.875rem; font-weight: 700; padding: 0.5rem; border-radius: var(--radius-lg); }
.iceberg-form-message.hidden { display: none; }
.iceberg-form-message.success { background: #f0fdf4; color: var(--green-600); border: 1px solid #bbf7d0; }
.iceberg-form-message.error { background: #fef2f2; color: var(--red-600); border: 1px solid #fecaca; }

/* ── FAQ ── */
.sp-faq__title { font-size: 1.25rem; font-weight: 700; margin-bottom: 1.5rem; }

.sp-faq__item { border-bottom: 1px solid var(--slate-100); padding-bottom: 1rem; margin-bottom: 1rem; }
.sp-faq__item:last-child { border-bottom: none; margin-bottom: 0; }

.sp-faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	text-align: right;
	font-weight: 700;
	color: var(--slate-900);
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 0;
	font-size: 1rem;
	font-family: inherit;
	transition: color var(--transition);
}
.sp-faq__question:hover { color: var(--primary); }

.sp-faq__icon { transition: transform 0.3s ease; }
.sp-faq__icon.is-open { transform: rotate(180deg); }

.sp-faq__answer {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: max-height 0.3s ease, opacity 0.3s ease;
	font-size: 0.875rem;
	color: var(--slate-500);
	margin-top: 0.5rem;
}
.sp-faq__answer.is-open { max-height: 500px; opacity: 1; }

/* ── Related Products ── */
.sp-related {
	border-top: 1px solid var(--slate-200);
	margin-top: 3rem;
	padding-top: 2.5rem;
	margin-bottom: 5rem;
}
.sp-related__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 2.5rem; }
.sp-related__title { font-size: 1.5rem; font-weight: 700; margin: 0; }
.sp-related__link {
	color: var(--primary);
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 0.25rem;
	text-decoration: none;
}
.sp-related__link:hover { text-decoration: underline; }
.sp-related__link .material-symbols-outlined { font-size: 0.875rem; }

.sp-related__wrap { position: relative; }

.sp-related__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 640px) { .sp-related__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .sp-related__grid { grid-template-columns: repeat(4, 1fr); } }

/* Carousel mode */
.sp-related__carousel { overflow: hidden; }
.sp-related__track { display: flex; gap: 1.5rem; transition: transform 0.3s ease; width: max-content; }
.sp-related__track .sp-product-card { flex-shrink: 0; width: calc(25% - 18px); min-width: 240px; }

.sp-carousel-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	width: 2.5rem;
	height: 2.5rem;
	background: var(--white);
	border: 1px solid var(--slate-200);
	border-radius: var(--radius-full);
	box-shadow: var(--shadow-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.sp-carousel-btn:hover { background: var(--primary); color: var(--white); border-color: var(--primary); }
.sp-carousel-btn--prev { right: 0; transform: translateY(-50%) translateX(-1rem); }
.sp-carousel-btn--next { left: 0; transform: translateY(-50%) translateX(1rem); }

/* Product card */
.sp-product-card {
	background: var(--white);
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid var(--slate-100);
	transition: box-shadow var(--transition);
}
.sp-product-card:hover { box-shadow: var(--shadow-xl); }

.sp-product-card__image { aspect-ratio: 1; overflow: hidden; }
.sp-product-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition); }
.sp-product-card:hover .sp-product-card__image img { transform: scale(1.05); }

.sp-product-card__body { padding: 1rem; }
.sp-product-card__sku { font-size: 10px; font-weight: 700; color: var(--slate-400); }
.sp-product-card__name { font-weight: 700; color: var(--slate-900); margin-top: 0.25rem; }
.sp-product-card__footer { margin-top: 1rem; display: flex; align-items: center; justify-content: space-between; }
.sp-product-card__meta { font-size: 0.75rem; color: var(--slate-500); }
.sp-product-card__view {
	color: var(--primary);
	padding: 0.5rem;
	border-radius: var(--radius-lg);
	transition: background var(--transition);
	text-decoration: none;
	display: flex;
}
.sp-product-card__view:hover { background: var(--primary-10); }

/* ==========================================================================
   Modals / Popups
   ========================================================================== */

/* ── Popup Overlay ── */
.iceberg-popup {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,0.6);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	padding: 1rem;
}
.iceberg-popup.is-open { display: flex; }

/* ── Quote Modal Container ── */
.quote-modal {
	width: 100%;
	max-width: 42rem;
	max-height: 90vh;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	border-radius: 1rem;
	border: 1px solid rgba(255,255,255,0.1);
	box-shadow: 0 25px 60px rgba(0,0,0,0.5);
	position: relative;
	animation: popupSlideUp 0.3s ease-out;
	background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
}
.quote-modal::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="4" height="4"><rect width="4" height="4" fill="%23ffffff" fill-opacity="0.03"/><rect width="1" height="1" fill="%23ffffff" fill-opacity="0.05"/></svg>');
	opacity: 0.3;
	pointer-events: none;
	border-radius: 1rem;
}

@keyframes popupSlideUp {
	from { transform: translateY(20px); opacity: 0; }
	to { transform: translateY(0); opacity: 1; }
}

@media (min-width: 768px) {
	.quote-modal {
		flex-direction: row;
	}
}

/* ── Close Button ── */
.quote-modal__close {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	z-index: 10;
	color: rgba(255,255,255,0.5);
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 50%;
	width: 2rem;
	height: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all 0.2s;
}
.quote-modal__close .material-symbols-outlined { font-size: 1.125rem; }
.quote-modal__close:hover {
	color: #fff;
	background: rgba(255,255,255,0.1);
}

/* ── Sidebar ── */
.quote-modal__sidebar {
	display: none;
	flex-direction: column;
	justify-content: space-between;
	padding: 2rem;
	background: rgba(45,63,143,0.1);
	border-bottom: 1px solid rgba(255,255,255,0.05);
	position: relative;
}
@media (min-width: 768px) {
	.quote-modal__sidebar {
		display: flex;
		width: 35%;
		border-bottom: none;
		border-left: 1px solid rgba(255,255,255,0.05);
	}
}

.quote-modal__logo { margin-bottom: 1.5rem; }
.quote-modal__logo-img { max-width: 120px; height: auto; }
.quote-modal__logo-icon {
	width: 3rem;
	height: 3rem;
	background: #2D3F8F;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.5rem;
	color: #fff;
	box-shadow: 0 4px 12px rgba(45,63,143,0.4);
}

.quote-modal__sidebar-title {
	color: #fff;
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 1.5rem;
}

.quote-modal__trust-list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.quote-modal__trust-item {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.quote-modal__trust-icon {
	flex-shrink: 0;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #60a5fa;
}
.quote-modal__trust-icon .material-symbols-outlined { font-size: 1.25rem; }

.quote-modal__trust-title {
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
	margin: 0;
}
.quote-modal__trust-desc {
	color: #94a3b8;
	font-size: 0.75rem;
	margin: 0;
}

.quote-modal__sidebar-bottom {
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(255,255,255,0.05);
}
.quote-modal__sidebar-bottom p {
	color: #64748b;
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	margin: 0;
}

/* ── Form Section ── */
.quote-modal__form-section {
	flex: 1;
	padding: 2rem;
	position: relative;
}
@media (min-width: 768px) {
	.quote-modal__form-section { padding: 2.5rem 3rem; }
}

.quote-modal__form-header { margin-bottom: 2.5rem; }

.quote-modal__title {
	color: #fff;
	font-size: 1.75rem;
	font-weight: 900;
	letter-spacing: -0.025em;
	margin: 0 0 0.5rem;
}
.quote-modal__subtitle {
	color: #94a3b8;
	font-size: 0.875rem;
	margin: 0;
}

/* ── Form ── */
.quote-modal__form {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.quote-modal__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 768px) {
	.quote-modal__row { grid-template-columns: 1fr 1fr; }
}

/* ── Floating Label Fields ── */
.quote-modal__field {
	position: relative;
}

.quote-modal__input {
	display: block;
	width: 100%;
	padding: 0.75rem 0;
	font-size: 1.125rem;
	font-family: inherit;
	color: #fff;
	background: rgba(255,255,255,0.03);
	border: none;
	border-bottom: 2px solid rgba(255,255,255,0.1);
	border-radius: 0;
	outline: none;
	transition: all 0.3s;
	-webkit-appearance: none;
}
.quote-modal__input:focus {
	border-bottom-color: #2D3F8F;
	background: rgba(45,63,143,0.1);
	box-shadow: none;
}

.quote-modal__textarea {
	resize: none;
}

.quote-modal__field label {
	position: absolute;
	top: 0.75rem;
	right: 0;
	color: rgba(255,255,255,0.5);
	font-size: 1rem;
	pointer-events: none;
	transition: all 0.2s ease-out;
}

.quote-modal__input:focus ~ label,
.quote-modal__input:not(:placeholder-shown) ~ label {
	top: -1.25rem;
	font-size: 0.8rem;
	color: #94a3b8;
}

/* ── Submit Button ── */
.quote-modal__submit {
	width: 100%;
	padding: 1rem;
	margin-top: 0.5rem;
	border: none;
	border-radius: 0.75rem;
	background: linear-gradient(90deg, #2D3F8F 0%, #4a5db5 100%);
	box-shadow: 0 4px 15px rgba(45,63,143,0.4);
	color: #fff;
	font-size: 1.125rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	transition: all 0.3s;
}
.quote-modal__submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(45,63,143,0.6);
	filter: brightness(1.1);
}
.quote-modal__submit .material-symbols-outlined {
	font-size: 1.25rem;
	transition: transform 0.3s;
}
.quote-modal__submit:hover .material-symbols-outlined {
	transform: translateX(-4px);
}

/* ── Form Message inside modal ── */
.quote-modal__form .iceberg-form-message {
	text-align: center;
	padding: 0.75rem;
	border-radius: 0.5rem;
	font-size: 0.875rem;
}
.quote-modal__form .iceberg-form-message.success {
	background: rgba(34,197,94,0.15);
	color: #4ade80;
}
.quote-modal__form .iceberg-form-message.error {
	background: rgba(239,68,68,0.15);
	color: #f87171;
}

/* ── Lightbox ── */
.iceberg-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,0.9);
	backdrop-filter: blur(4px);
}
.iceberg-lightbox.is-open { display: flex; }

.iceberg-lightbox__close {
	position: absolute; top: 1.5rem; left: 1.5rem; z-index: 10;
	color: rgba(255,255,255,0.7); background: transparent; border: none; cursor: pointer;
	transition: color var(--transition);
}
.iceberg-lightbox__close:hover { color: var(--white); }
.iceberg-lightbox__close .material-symbols-outlined { font-size: 2.25rem; }

.iceberg-lightbox__nav {
	position: absolute; top: 50%; transform: translateY(-50%);
	color: rgba(255,255,255,0.7); background: rgba(255,255,255,0.1);
	border: none; border-radius: var(--radius-full); padding: 0.5rem;
	cursor: pointer; z-index: 10;
	transition: background var(--transition), color var(--transition);
}
.iceberg-lightbox__nav:hover { background: rgba(255,255,255,0.2); color: var(--white); }
.iceberg-lightbox__nav .material-symbols-outlined { font-size: 1.875rem; }
.iceberg-lightbox__nav--prev { right: 1.5rem; }
.iceberg-lightbox__nav--next { left: 1.5rem; }

.iceberg-lightbox__img-wrap { max-width: 64rem; max-height: 85vh; margin: 0 auto; padding: 0 4rem; }
.iceberg-lightbox__img-wrap img { max-width: 100%; max-height: 85vh; object-fit: contain; margin: 0 auto; display: block; }

.iceberg-lightbox__counter {
	position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%);
	color: rgba(255,255,255,0.6); font-size: 0.875rem;
}

/* ==========================================================================
   Footer
   ========================================================================== */

.site-footer {
	background: var(--slate-900);
	color: var(--white);
	padding: 5rem 1rem 2.5rem;
}

@media (min-width: 1024px) { .site-footer { padding: 5rem 5rem 2.5rem; } }

.footer-grid {
	max-width: 1280px;
	margin: 0 auto 5rem;
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}

@media (min-width: 768px)  { .footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: repeat(5, 1fr); } }

.footer-brand {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration: none;
	margin-bottom: 1.5rem;
}

.footer-brand__icon {
	background: var(--primary);
	padding: 0.5rem;
	border-radius: var(--radius-lg);
	color: var(--white);
	display: flex;
}

.footer-brand__name {
	color: var(--white);
	font-size: 1.25rem;
	font-weight: 900;
	letter-spacing: -0.025em;
	margin: 0;
}

.footer-about__desc {
	color: var(--slate-400);
	font-size: 0.875rem;
	line-height: 1.7;
}

.footer-col__title {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0 0 1.5rem;
	border-right: 2px solid var(--primary);
	padding-right: 1rem;
}

.footer-col__menu {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-col__menu li { margin-bottom: 1rem; }

.footer-col__menu a {
	color: var(--slate-400);
	text-decoration: none;
	font-size: 0.875rem;
	transition: color var(--transition);
}
.footer-col__menu a:hover { color: var(--white); }

.footer-contact {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-contact li {
	display: flex;
	gap: 0.75rem;
	margin-bottom: 1rem;
	color: var(--slate-400);
	font-size: 0.875rem;
}

.footer-contact .material-symbols-outlined {
	color: var(--primary);
}

.footer-contact a {
	color: var(--slate-400);
	text-decoration: none;
	transition: color var(--transition);
}
.footer-contact a:hover { color: var(--white); }

.footer-bottom {
	max-width: 1280px;
	margin: 0 auto;
	padding-top: 2.5rem;
	border-top: 1px solid rgba(255,255,255,0.1);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	color: var(--slate-500);
	font-size: 0.75rem;
}

@media (min-width: 768px) { .footer-bottom { flex-direction: row; } }

.footer-bottom p { margin: 0; }

.footer-bottom__links {
	display: flex;
	gap: 1.5rem;
}

.footer-bottom__links a {
	color: var(--slate-500);
	text-decoration: none;
	transition: color var(--transition);
}
.footer-bottom__links a:hover { color: var(--white); }

.footer-bottom__credit { color: var(--slate-500); }
.footer-bottom__credit a { color: var(--slate-400); text-decoration: none; transition: color var(--transition); }
.footer-bottom__credit a:hover { color: var(--white); }

/* Footer Social Links */
.footer-social {
	display: flex;
	gap: 0.75rem;
	margin-top: 1.5rem;
}

.footer-social__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: var(--radius-full);
	background: rgba(255,255,255,0.1);
	color: var(--slate-400);
	transition: background var(--transition), color var(--transition);
}

.footer-social__link:hover {
	background: var(--primary);
	color: var(--white);
}

/* Footer Accordion (mobile) */
.footer-col__toggle {
	display: none;
}

@media (max-width: 768px) {
	.footer-grid {
		grid-template-columns: 1fr !important;
	}

	.footer-col--accordion .footer-col__title {
		cursor: pointer;
		display: flex;
		align-items: center;
		justify-content: space-between;
	}

	.footer-col__toggle {
		display: inline-block;
		font-size: 1.25rem;
		transition: transform 0.3s;
	}

	.footer-col--accordion.is-open .footer-col__toggle {
		transform: rotate(45deg);
	}

	.footer-col--accordion .footer-col__body {
		display: none;
	}

	.footer-col--accordion.is-open .footer-col__body {
		display: block;
	}

	.footer-col--info {
		border-top: 1px solid rgba(255,255,255,0.1);
		padding-top: 1.5rem;
	}
}

/* ==========================================================================
   WooCommerce General
   ========================================================================== */

.single-product .woocommerce-breadcrumb,
.single-product .related.products,
.single-product .woocommerce-tabs,
.single-product .woocommerce-product-rating { display: none !important; }

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	background-color: var(--primary);
	color: var(--white);
	border: none;
	border-radius: var(--radius-lg);
	padding: 0.75rem 1.5rem;
	font-weight: 600;
	font-family: 'Assistant', sans-serif;
	cursor: pointer;
	transition: background var(--transition), box-shadow var(--transition);
	text-decoration: none;
	display: inline-block;
	text-align: center;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover {
	background-color: var(--primary-hover);
	box-shadow: var(--shadow-md);
}

.woocommerce span.onsale {
	background: var(--red-600);
	border-radius: var(--radius-xl);
	padding: 6px 12px;
	font-size: 0.75rem;
	font-weight: 700;
	line-height: 1;
	min-height: auto;
	min-width: auto;
}

.woocommerce .star-rating span::before { color: #f59e0b; }

.woocommerce-message, .woocommerce-info { border-top-color: var(--primary) !important; }
.woocommerce-message::before, .woocommerce-info::before { color: var(--primary) !important; }
.woocommerce-error { border-top-color: var(--red-600) !important; }

/* ==========================================================================
   Archive / Category Page (ar-*)
   ========================================================================== */

/* ── Hero ── */
.ar-hero {
	position: relative;
	background: var(--white);
	overflow: hidden;
	padding: 2rem 0;
}
.ar-hero__bg-orb {
	position: absolute;
	width: 24rem;
	height: 24rem;
	background: var(--primary);
	border-radius: 50%;
	opacity: 0.05;
	pointer-events: none;
	filter: blur(80px);
}
.ar-hero__bg-orb--right { right: -5rem; top: -5rem; }
.ar-hero__bg-orb--left  { left: -5rem; bottom: -5rem; }

.ar-hero__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 1rem;
	position: relative;
}
@media (min-width: 640px)  { .ar-hero__inner { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .ar-hero__inner { padding: 0 2rem; } }

.ar-hero__title {
	font-size: 2.25rem;
	font-weight: 900;
	color: var(--slate-900);
	margin: 0 0 0.5rem;
}
@media (min-width: 768px) { .ar-hero__title { font-size: 3rem; } }

.ar-hero__desc {
	font-size: 1.125rem;
	color: var(--slate-600);
	line-height: 1.7;
	max-width: 48rem;
	margin: 0;
}

/* ── Breadcrumb ── */
.ar-breadcrumb { margin-bottom: 0.5rem; }
.ar-breadcrumb ol {
	list-style: none;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--slate-500);
}
.ar-breadcrumb a { color: var(--slate-500); text-decoration: none; }
.ar-breadcrumb a:hover { color: var(--primary); }
.ar-breadcrumb .material-symbols-outlined { font-size: 0.75rem; }
.ar-breadcrumb__current { font-weight: 600; color: var(--primary); }

/* ── Main Content ── */
.ar-content {
	max-width: 1280px;
	margin: 0 auto;
	padding: 1.5rem 1rem;
}
@media (min-width: 640px)  { .ar-content { padding: 1.5rem; } }
@media (min-width: 1024px) { .ar-content { padding: 1.5rem 2rem; } }

.ar-layout {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}
@media (min-width: 1024px) {
	.ar-layout { flex-direction: row; }
}

/* ── Sidebar ── */
.ar-sidebar {
	display: none;
	width: 100%;
}
@media (min-width: 1024px) {
	.ar-sidebar {
		display: block;
		width: 18rem;
		flex-shrink: 0;
	}
}

.ar-sidebar.is-open {
	display: block;
	position: fixed;
	inset: 0;
	z-index: 60;
}

.ar-sidebar__overlay {
	display: none;
}
.ar-sidebar.is-open .ar-sidebar__overlay {
	display: block;
	position: fixed;
	inset: 0;
	background: rgba(15,23,42,0.6);
}

.ar-sidebar__inner {
	background: var(--white);
	padding: 1.25rem;
}
.ar-sidebar.is-open .ar-sidebar__inner {
	position: relative;
	height: 100%;
	width: 20rem;
	overflow-y: auto;
	z-index: 1;
	box-shadow: var(--shadow-xl);
	border-left: 1px solid var(--slate-200);
}

@media (min-width: 1024px) {
	.ar-sidebar__inner {
		border-radius: var(--radius-xl);
		border: 1px solid var(--slate-100);
	}
}

.ar-sidebar__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1.5rem;
}
.ar-sidebar__title { font-size: 1.125rem; font-weight: 700; margin: 0; }
.ar-sidebar__actions { display: flex; align-items: center; gap: 1rem; }
.ar-sidebar__reset { font-size: 0.75rem; color: var(--primary); font-weight: 500; text-decoration: none; }
.ar-sidebar__reset:hover { text-decoration: underline; }
.ar-sidebar__close {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--slate-400);
}
.ar-sidebar.is-open .ar-sidebar__close { display: block; }
@media (min-width: 1024px) { .ar-sidebar__close { display: none !important; } }

/* ── Filter Groups ── */
.ar-filters { display: flex; flex-direction: column; gap: 0; }

.ar-filter-group {
	padding: 1.25rem 0;
	border-top: 1px solid var(--slate-100);
}
.ar-filter-group:first-child { border-top: none; padding-top: 0; }

.ar-filter-group__title {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--slate-400);
	margin: 0 0 0.75rem;
}

.ar-filter-group__options { display: flex; flex-direction: column; gap: 0.5rem; }

.ar-filter-option {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	cursor: pointer;
}
.ar-filter-option input[type="checkbox"] {
	width: 1rem;
	height: 1rem;
	border-radius: 3px;
	accent-color: var(--primary);
	cursor: pointer;
}
.ar-filter-option__label {
	font-size: 0.875rem;
	color: var(--slate-700);
	transition: color var(--transition);
}
.ar-filter-option:hover .ar-filter-option__label { color: var(--primary); }

/* ── Button Grid Filters (compatible-with) ── */
.ar-filter-buttons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.5rem;
}

.ar-filter-btn {
	padding: 0.5rem 0.75rem;
	font-size: 0.75rem;
	font-family: inherit;
	font-weight: 500;
	border: 1px solid var(--slate-200);
	border-radius: var(--radius);
	background: var(--white);
	color: var(--slate-700);
	cursor: pointer;
	text-align: center;
	transition: border-color var(--transition), color var(--transition), background var(--transition);
}
.ar-filter-btn:hover { border-color: var(--primary); color: var(--primary); }
.ar-filter-btn.is-active {
	background: var(--primary);
	color: var(--white);
	border-color: var(--primary);
}

.ar-filter-btn--hidden { display: none; }
.ar-filter-buttons.is-expanded .ar-filter-btn--hidden { display: block; }

.ar-filter-btn--more {
	grid-column: 1 / -1;
	background: var(--slate-50);
	color: var(--primary);
	font-weight: 700;
	border-style: dashed;
}
.ar-filter-btn--more:hover { background: var(--primary-5); }
.ar-filter-buttons.is-expanded .ar-filter-btn--more { display: none; }

/* ── Mobile Filter Toggle ── */
.ar-mobile-filter-toggle { display: block; }
@media (min-width: 1024px) { .ar-mobile-filter-toggle { display: none; } }

.ar-mobile-filter-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
	padding: 1rem;
	background: var(--primary);
	color: var(--white);
	font-weight: 700;
	font-family: inherit;
	font-size: 1rem;
	border: none;
	border-radius: var(--radius-xl);
	cursor: pointer;
	box-shadow: var(--shadow-lg);
	transition: background var(--transition);
}
.ar-mobile-filter-btn:hover { background: var(--primary-hover); }

/* ── Products Area ── */
.ar-products { flex: 1; min-width: 0; }

/* ── Toolbar ── */
.ar-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: var(--white);
	border-radius: var(--radius-lg);
	border: 1px solid var(--primary-5);
	padding: 0.75rem;
	margin-bottom: 1rem;
}
.ar-toolbar__count { font-size: 0.875rem; color: var(--slate-500); margin: 0; }
.ar-toolbar__count strong { color: var(--slate-900); }

.ar-toolbar__sort { display: flex; align-items: center; gap: 0.5rem; }
.ar-toolbar__sort-label { font-size: 0.875rem; color: var(--slate-500); }

.ar-toolbar__select {
	border: none;
	background: transparent;
	font-size: 0.875rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	color: var(--slate-900);
	padding: 0.25rem;
	outline: none;
}

/* ── Product Grid ── */
.ar-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 640px)  { .ar-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .ar-grid { grid-template-columns: repeat(3, 1fr); } }

/* ── Product Card ── */
.ar-card {
	background: var(--white);
	border-radius: var(--radius-xl);
	border: 1px solid var(--slate-200);
	overflow: hidden;
	transition: box-shadow 0.3s ease, border-color 0.3s ease;
}
.ar-card:hover { box-shadow: var(--shadow-xl); border-color: var(--primary-30); }

.ar-card__link { text-decoration: none; color: inherit; display: block; }

.ar-card__image {
	position: relative;
	aspect-ratio: 1;
	overflow: hidden;
	background: var(--slate-100);
}
.ar-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}
.ar-card:hover .ar-card__image img { transform: scale(1.1); }

.ar-card__badges {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.ar-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.25rem 0.5rem;
	border-radius: 2px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	box-shadow: var(--shadow-lg);
}
.ar-card__badge--italy {
	background: var(--primary);
	color: var(--white);
}
.ar-card__badge .flag { width: 0.75rem; height: 0.5rem; border-radius: 1px; display: inline-block; }
.ar-card__badge .flag--green { background: #16a34a; }
.ar-card__badge .flag--white { background: var(--white); border: 1px solid var(--slate-200); }
.ar-card__badge .flag--red   { background: #dc2626; }

.ar-card__body { padding: 1rem; }

.ar-card__title {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0 0 0.25rem;
	transition: color var(--transition);
}
.ar-card:hover .ar-card__title { color: var(--primary); }

.ar-card__attrs { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 0.5rem; }

.ar-card__attr {
	display: inline-block;
	padding: 0.25rem 0.5rem;
	border-radius: var(--radius);
	font-size: 10px;
	font-weight: 700;
}
.ar-card__attr--primary { background: var(--primary-5); color: var(--primary); }
.ar-card__attr--muted   { background: var(--slate-100); color: var(--slate-500); }

.ar-card__excerpt {
	font-size: 0.875rem;
	color: var(--slate-500);
	line-height: 1.6;
	margin: 0 0 1rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ar-card__cta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
	padding: 0.75rem;
	background: var(--primary);
	color: var(--white);
	font-weight: 700;
	border-radius: var(--radius-lg);
	margin-top: 2rem;
	transition: background var(--transition);
}
.ar-card__cta .material-symbols-outlined { font-size: 0.875rem; }
.ar-card:hover .ar-card__cta { background: var(--primary-hover); }

/* ── Pagination ── */
.ar-pagination {
	display: flex;
	justify-content: center;
	margin-top: 2rem;
}
.ar-pagination ul {
	list-style: none;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.ar-pagination li { display: inline-block; }

.ar-pagination a,
.ar-pagination span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: var(--radius-lg);
	border: 1px solid var(--slate-200);
	font-weight: 700;
	font-size: 0.875rem;
	text-decoration: none;
	color: var(--slate-700);
	transition: border-color var(--transition), color var(--transition), background var(--transition);
}
.ar-pagination a:hover { border-color: var(--primary); color: var(--primary); }
.ar-pagination .current {
	background: var(--primary);
	color: var(--white);
	border-color: var(--primary);
}
.ar-pagination .dots { border: none; }
.ar-pagination .prev,
.ar-pagination .next { border: 1px solid var(--slate-200); }

/* ── No Products ── */
.ar-no-products {
	text-align: center;
	padding: 4rem 2rem;
	color: var(--slate-400);
}
.ar-no-products .material-symbols-outlined { font-size: 3rem; margin-bottom: 1rem; }
.ar-no-products p { font-size: 1.125rem; margin-bottom: 1.5rem; }
.ar-no-products__reset {
	display: inline-block;
	padding: 0.75rem 2rem;
	background: var(--primary);
	color: var(--white);
	border-radius: var(--radius-lg);
	font-weight: 700;
	text-decoration: none;
}

/* ── SEO Footer ── */
.ar-seo-footer {
	background: var(--white);
	border-top: 1px solid var(--slate-200);
	padding: 3rem 0;
	margin-top: 3rem;
}
.ar-seo-footer__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 1rem;
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}
@media (min-width: 768px) {
	.ar-seo-footer__inner { grid-template-columns: 2fr 1fr; padding: 0 2rem; }
}

.ar-seo-footer__title { font-size: 1.5rem; font-weight: 700; margin: 0 0 1.5rem; }

.ar-seo-footer__faq-list { display: flex; flex-direction: column; gap: 1.5rem; }

.ar-seo-faq__question {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--primary);
	margin: 0 0 0.5rem;
}
.ar-seo-faq__answer {
	color: var(--slate-600);
	margin: 0;
	line-height: 1.7;
}

.ar-seo-footer__link-list {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.ar-seo-footer__link-list a {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--slate-600);
	text-decoration: none;
	font-size: 0.875rem;
	transition: color var(--transition);
}
.ar-seo-footer__link-list a:hover { color: var(--primary); }
.ar-seo-footer__link-list .material-symbols-outlined { font-size: 0.875rem; }

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1023px) {
	.sp-hero { gap: 2rem; }
	.sp-info__title { font-size: 1.75rem; }
}

@media (max-width: 767px) {
	.sp-overview { grid-template-columns: 1fr; }
	.sp-manufacturer { flex-direction: column; text-align: center; }
	.sp-series-alert { flex-direction: column; text-align: center; }
	.sp-form__row { grid-template-columns: 1fr; }
	.ar-toolbar { flex-direction: column; gap: 0.5rem; align-items: flex-start; }
}

/* ==========================================================================
   Front Page (fp-*)
   ========================================================================== */

.fp-main { padding: 0; }

.fp-container {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 1rem;
}

@media (min-width: 1024px) { .fp-container { padding: 0 5rem; } }

.fp-section-header { text-align: center; margin-bottom: 4rem; }

.fp-section-title {
	font-size: 1.875rem;
	font-weight: 900;
	margin: 0 0 1rem;
}

.fp-section-title--right { text-align: right; }

.fp-section-divider {
	width: 5rem;
	height: 0.375rem;
	background: var(--primary);
	margin: 0 auto;
	border-radius: var(--radius-full);
}

/* ── Hero ── */

.fp-hero {
	position: relative;
	display: flex;
	align-items: center;
	overflow: hidden;
	min-height: 600px;
}

.fp-hero__media {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	overflow: hidden;
	pointer-events: none;
}

.fp-hero__video {
	position: absolute;
	top: 50%;
	left: 50%;
	min-width: 100%;
	min-height: 130%;
	width: max(177.78vh, 100%); /* 16:9 */
	height: max(56.25vw, 100%);
	transform: translate(-50%, -50%);
	border: 0;
}

@media (min-width: 1024px) {
	.fp-hero__video { min-height: 100%; }
}

.fp-hero__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.fp-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to left, rgba(246,246,248,0.95), rgba(246,246,248,0.7), transparent);
}

.fp-hero__content {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin: 0 auto;
	padding: 5rem 1rem;
	width: 100%;
}

@media (min-width: 1024px) { .fp-hero__content { padding: 5rem; } }

.fp-hero__text { max-width: 42rem; }

.fp-hero__badge {
	display: inline-block;
	padding: 0.25rem 1rem;
	background: var(--primary-10);
	color: var(--primary);
	font-size: 0.75rem;
	font-weight: 700;
	border-radius: var(--radius-full);
	margin-bottom: 1.5rem;
}

.fp-hero__title {
	font-size: 3rem;
	font-weight: 900;
	line-height: 1.1;
	margin: 0 0 1.5rem;
	color: var(--slate-900);
}

@media (min-width: 1024px) { .fp-hero__title { font-size: 4.5rem; } }

.fp-hero__title-accent { color: var(--primary); }

.fp-hero__desc {
	font-size: 1.125rem;
	color: var(--slate-600);
	margin: 0 0 2.5rem;
	line-height: 1.7;
}

.fp-hero__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 4rem;
}

.fp-hero__btn-primary {
	background: var(--primary);
	color: var(--white);
	padding: 1rem 2rem;
	border-radius: var(--radius-xl);
	font-weight: 700;
	font-size: 1.125rem;
	text-decoration: none;
	transition: transform var(--transition);
	box-shadow: 0 10px 25px rgba(63,45,143,0.3);
}
.fp-hero__btn-primary:hover { transform: scale(1.05); color: var(--white); }

.fp-hero__btn-secondary {
	background: var(--white);
	border: 1px solid var(--slate-200);
	padding: 1rem 2rem;
	border-radius: var(--radius-xl);
	font-weight: 700;
	font-size: 1.125rem;
	color: var(--slate-900);
	text-decoration: none;
	transition: background var(--transition);
	cursor: pointer;
	font-family: inherit;
}
.fp-hero__btn-secondary:hover { background: var(--slate-50); color: var(--slate-900); }

/* Trust Badges */

.fp-trust-badges {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.75rem;
}

@media (min-width: 768px) { .fp-trust-badges { gap: 1.5rem; } }

.fp-trust-badge {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	background: rgba(255,255,255,0.5);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	padding: 0.625rem 0.5rem;
	border-radius: var(--radius-xl);
	border: 1px solid rgba(255,255,255,0.2);
}

@media (min-width: 768px) {
	.fp-trust-badge { gap: 1rem; padding: 1rem; }
}

.fp-trust-badge__icon { color: var(--primary); font-size: 1.25rem; }
@media (min-width: 768px) { .fp-trust-badge__icon { font-size: 1.5rem; } }

.fp-trust-badge__number {
	font-size: 0.875rem;
	font-weight: 900;
	margin: 0;
	line-height: 1;
}
@media (min-width: 768px) { .fp-trust-badge__number { font-size: 1.25rem; } }

.fp-trust-badge__text {
	font-size: 0.6rem;
	font-weight: 500;
	color: var(--slate-500);
	margin: 0;
}
@media (min-width: 768px) { .fp-trust-badge__text { font-size: 0.75rem; } }

/* ── Features ── */

.fp-features {
	padding: 6rem 0;
	background: var(--white);
}

.fp-features__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

@media (min-width: 768px)  { .fp-features__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .fp-features__grid { grid-template-columns: repeat(4, 1fr); } }

.fp-feature-card {
	padding: 2rem;
	border-radius: var(--radius-2xl);
	background: var(--bg-light);
	border: 1px solid transparent;
	transition: all 0.3s ease;
}
.fp-feature-card:hover {
	border-color: var(--primary-20);
	box-shadow: 0 25px 50px rgba(63,45,143,0.05);
}

.fp-feature-card__icon {
	width: 3.5rem;
	height: 3.5rem;
	background: var(--primary-10);
	border-radius: var(--radius-xl);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--primary);
	margin-bottom: 1.5rem;
	transition: background var(--transition), color var(--transition);
}
.fp-feature-card:hover .fp-feature-card__icon { background: var(--primary); color: var(--white); }

.fp-feature-card__title {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
}

.fp-feature-card__desc {
	font-size: 0.875rem;
	color: var(--slate-500);
	line-height: 1.7;
	margin: 0;
}

/* ── Categories ── */

/* ── Categories Section ── */
.fp-categories {
	padding: 6rem 0;
	background: var(--slate-900);
	color: var(--white);
	position: relative;
	overflow: hidden;
}
.fp-categories::before {
	content: "";
	position: absolute;
	top: -50%;
	right: -20%;
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(45,63,143,0.15) 0%, transparent 70%);
	pointer-events: none;
}
.fp-categories::after {
	content: "";
	position: absolute;
	bottom: -40%;
	left: -10%;
	width: 500px;
	height: 500px;
	background: radial-gradient(circle, rgba(96,165,250,0.08) 0%, transparent 70%);
	pointer-events: none;
}

.fp-categories__header {
	text-align: center;
	margin-bottom: 3.5rem;
	position: relative;
}

.fp-categories__badge {
	display: inline-block;
	padding: 0.375rem 1.25rem;
	border-radius: 2rem;
	background: rgba(45,63,143,0.2);
	border: 1px solid rgba(45,63,143,0.3);
	color: #93c5fd;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	margin-bottom: 1rem;
}

.fp-categories__header .fp-section-title {
	color: var(--white);
}

.fp-categories__subtitle {
	color: var(--slate-400);
	margin: 0;
}

/* ── Track: mobile carousel / desktop grid ── */
.fp-categories__track {
	display: flex;
	gap: 1.25rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 0.5rem;
}
.fp-categories__track::-webkit-scrollbar { display: none; }

@media (min-width: 1024px) {
	.fp-categories__track {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 2rem;
		overflow-x: visible;
		scroll-snap-type: none;
	}
}

/* ── Category Card ── */
.fp-category-item {
	flex: 0 0 78%;
	scroll-snap-align: center;
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: var(--white);
	border-radius: 1rem;
	overflow: hidden;
	position: relative;
	background: rgba(255,255,255,0.03);
	border: 1px solid rgba(255,255,255,0.06);
	transition: transform 0.4s cubic-bezier(.25,.8,.25,1), box-shadow 0.4s, border-color 0.4s;
}
@media (min-width: 768px) {
	.fp-category-item { flex: 0 0 45%; }
}
@media (min-width: 1024px) {
	.fp-category-item { flex: none; }
}

.fp-category-item:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0,0,0,0.3), 0 0 30px rgba(45,63,143,0.15);
	border-color: rgba(45,63,143,0.3);
	color: var(--white);
}

/* Image */
.fp-category-item__image {
	position: relative;
	aspect-ratio: 4/3;
	overflow: hidden;
}
.fp-category-item__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(.25,.8,.25,1), filter 0.6s;
}
.fp-category-item:hover .fp-category-item__image img {
	transform: scale(1.1);
	filter: brightness(0.7);
}

/* Gradient overlay */
.fp-category-item__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(0deg, rgba(15,23,42,0.85) 0%, rgba(15,23,42,0.1) 50%, transparent 100%);
	transition: opacity 0.4s;
}

/* Content area */
.fp-category-item__content {
	padding: 1.25rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: rgba(255,255,255,0.02);
	border-top: 1px solid rgba(255,255,255,0.05);
}

.fp-category-item__title {
	font-size: 1.125rem;
	font-weight: 800;
	margin: 0;
	color: var(--white);
}

.fp-category-item__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: #93c5fd;
	opacity: 0;
	transform: translateX(8px);
	transition: opacity 0.3s, transform 0.3s;
}
.fp-category-item__cta .material-symbols-outlined { font-size: 1rem; }
.fp-category-item:hover .fp-category-item__cta {
	opacity: 1;
	transform: translateX(0);
}

/* ── Scroll Hint (mobile only) ── */
.fp-categories__scroll-hint {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 1.5rem;
	color: rgba(255,255,255,0.4);
	font-size: 0.8rem;
	animation: catScrollHint 2s ease-in-out infinite;
}
.fp-categories__scroll-hint .material-symbols-outlined {
	font-size: 1.25rem;
	animation: catScrollSwipe 2s ease-in-out infinite;
}

@keyframes catScrollHint {
	0%, 100% { opacity: 0.4; }
	50% { opacity: 0.8; }
}
@keyframes catScrollSwipe {
	0%, 100% { transform: translateX(0); }
	50% { transform: translateX(-8px); }
}

@media (min-width: 1024px) {
	.fp-categories__scroll-hint { display: none; }
}

/* ── Footer ── */
.fp-categories__footer {
	text-align: center;
	margin-top: 3rem;
}

.fp-categories__all-link {
	color: var(--white);
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	padding: 0.75rem 2rem;
	border-radius: 3rem;
	border: 1px solid rgba(255,255,255,0.15);
	background: rgba(255,255,255,0.05);
	transition: all 0.3s;
}
.fp-categories__all-link:hover {
	background: rgba(255,255,255,0.1);
	border-color: rgba(255,255,255,0.3);
	color: var(--white);
}

/* ── SEO Content ── */

.fp-seo {
	padding: 5rem 0;
	background: var(--white);
	border-top: 1px solid var(--slate-100);
	border-bottom: 1px solid var(--slate-100);
}

.fp-seo__title {
	font-size: 1.875rem;
	font-weight: 900;
	margin: 0 0 3rem;
	border-right: 4px solid var(--primary);
	padding-right: 1.5rem;
}

.fp-seo__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	line-height: 1.7;
	color: var(--slate-600);
}

@media (min-width: 768px) { .fp-seo__grid { grid-template-columns: repeat(2, 1fr); } }

/* ── Featured Products ── */

.fp-products {
	padding: 6rem 0;
}

.fp-products__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

@media (min-width: 768px)  { .fp-products__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .fp-products__grid { grid-template-columns: repeat(4, 1fr); } }

.fp-product-card {
	background: var(--white);
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	border: 1px solid var(--slate-100);
	transition: box-shadow 0.3s ease;
	position: relative;
}
.fp-product-card:hover { box-shadow: var(--shadow-xl); }

.fp-product-card__badge {
	position: absolute;
	z-index: 2;
	font-size: 10px;
	font-weight: 900;
	padding: 0.25rem 0.5rem;
	border-radius: var(--radius);
}

.fp-product-card__badge--sale {
	top: 1rem;
	right: 1rem;
	background: var(--red-600);
	color: var(--white);
}

.fp-product-card__badge--featured {
	top: 1rem;
	left: 1rem;
	background: var(--primary);
	color: var(--white);
}

.fp-product-card__image {
	height: 16rem;
	background: var(--slate-50);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
}
.fp-product-card__image img {
	max-height: 100%;
	object-fit: contain;
}

.fp-product-card__body { padding: 1.5rem; }

.fp-product-card__cat {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	color: var(--slate-400);
	text-transform: uppercase;
	background: var(--slate-100);
	padding: 0.125rem 0.5rem;
	border-radius: var(--radius);
	margin-bottom: 0.5rem;
}

.fp-product-card__title {
	font-weight: 700;
	font-size: 1.125rem;
	margin: 0 0 1rem;
}

.fp-product-card__attrs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1.5rem;
}

.fp-product-card__attr {
	background: var(--slate-100);
	padding: 0.25rem 0.5rem;
	border-radius: var(--radius);
	font-size: 0.75rem;
}

.fp-product-card__cta {
	display: block;
	width: 100%;
	padding: 0.75rem;
	border: 2px solid var(--primary);
	color: var(--primary);
	font-weight: 700;
	border-radius: var(--radius-xl);
	text-align: center;
	text-decoration: none;
	transition: background var(--transition), color var(--transition);
}
.fp-product-card__cta:hover {
	background: var(--primary);
	color: var(--white);
}

/* ── Stats / Trust ── */

.fp-stats {
	padding: 5rem 0;
	background: var(--primary);
	color: var(--white);
	text-align: center;
}

.fp-stats__title {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0 0 3rem;
	opacity: 0.8;
	text-transform: uppercase;
	letter-spacing: 0.15em;
}

.fp-stats__logos {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 3rem;
	margin-bottom: 5rem;
	opacity: 0.5;
	filter: grayscale(1) invert(1);
}

@media (min-width: 1024px) { .fp-stats__logos { gap: 6rem; } }

.fp-stats__logos img {
	height: 2rem;
	object-fit: contain;
}

.fp-stats__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	border-top: 1px solid rgba(255,255,255,0.1);
	padding-top: 4rem;
}

@media (min-width: 768px) { .fp-stats__grid { grid-template-columns: repeat(4, 1fr); } }

.fp-stats__number {
	font-size: 2.5rem;
	font-weight: 900;
	margin: 0 0 0.5rem;
}

@media (min-width: 1024px) { .fp-stats__number { font-size: 3rem; } }

.fp-stats__text {
	font-size: 0.875rem;
	opacity: 0.7;
	margin: 0;
}

/* ── Clients Carousel ── */

.fp-clients {
	padding: 5rem 0;
	background: var(--bg-light);
	overflow: hidden;
}

.fp-clients__carousel {
	position: relative;
	direction: ltr;
	overflow: hidden;
	cursor: grab;
	-webkit-user-select: none;
	user-select: none;
}

.fp-clients__carousel:active {
	cursor: grabbing;
}

.fp-clients__track {
	display: flex;
	gap: 3rem;
	width: max-content;
	animation: clientsScroll 40s linear infinite;
}

.fp-clients__carousel.is-dragging .fp-clients__track {
	animation-play-state: paused;
}

@media (hover: hover) {
	.fp-clients__carousel:hover .fp-clients__track {
		animation-play-state: paused;
	}
}

.fp-clients__slide {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 5rem;
	padding: 0 1rem;
}

.fp-clients__slide img {
	max-height: 100%;
	max-width: 10rem;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.6;
	transition: filter 0.3s, opacity 0.3s;
}

.fp-clients__slide img:hover {
	filter: grayscale(0);
	opacity: 1;
}

@keyframes clientsScroll {
	0% { transform: translateX(0); }
	100% { transform: translateX(-25%); }
}

/* ── CTA Section ── */

.fp-cta {
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}

.fp-cta__card {
	max-width: 64rem;
	margin: 0 auto;
	background: var(--white);
	border-radius: var(--radius-2xl);
	box-shadow: 0 25px 50px rgba(0,0,0,0.1);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border: 1px solid var(--slate-100);
}

@media (min-width: 768px) { .fp-cta__card { flex-direction: row; } }

.fp-cta__info {
	padding: 3rem;
	background: var(--primary-5);
}

@media (min-width: 768px) { .fp-cta__info { width: 50%; } }

.fp-cta__title {
	font-size: 1.875rem;
	font-weight: 900;
	margin: 0 0 1.5rem;
}

.fp-cta__desc {
	color: var(--slate-600);
	margin: 0 0 2rem;
	line-height: 1.7;
}

.fp-cta__contact {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.fp-cta__contact-item {
	display: flex;
	align-items: center;
	gap: 1rem;
	color: var(--primary);
	font-weight: 700;
}

.fp-cta__contact-item a {
	color: var(--primary);
	text-decoration: none;
}

.fp-cta__form-wrap {
	padding: 3rem;
}

@media (min-width: 768px) { .fp-cta__form-wrap { width: 50%; } }

.fp-cta__submit {
	width: 100%;
	padding: 1rem;
	background: var(--primary);
	color: var(--white);
	border-radius: var(--radius-xl);
	font-weight: 900;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: 1rem;
	margin-top: 1rem;
	transition: background var(--transition);
	box-shadow: 0 4px 12px rgba(63,45,143,0.2);
}
.fp-cta__submit:hover { background: var(--primary-hover); }

/* ==========================================================================
   WhatsApp Floating Button
   ========================================================================== */

.btn-whatsapp-pulse {
	background: #25d366;
	color: #fff;
	position: fixed;
	bottom: 20px;
	right: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 70px;
	height: 70px;
	text-decoration: none;
	border-radius: 50%;
	z-index: 999;
	animation: whatsapp-pulse 1.5s ease-out infinite;
	transition: transform 0.2s ease;
}

.btn-whatsapp-pulse:hover {
	transform: scale(1.1);
	color: #fff;
}

.btn-whatsapp-pulse svg { width: 32px; height: 32px; }

@keyframes whatsapp-pulse {
	0%  { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.5); }
	80% { box-shadow: 0 0 0 14px rgba(37, 211, 102, 0); }
}

@media (max-width: 900px) {
	.btn-whatsapp-pulse {
		bottom: 55px;
		width: 55px;
		height: 55px;
	}
	.btn-whatsapp-pulse svg { width: 26px; height: 26px; }
}

/* ==========================================================================
   Front Page Responsive
   ========================================================================== */

@media (max-width: 767px) {
	.fp-hero { min-height: 500px; }
	.fp-hero__title { font-size: 2.25rem; }
	.fp-categories__track { gap: 1rem; }
	.fp-cta__card { flex-direction: column; }
}
