/*
Theme Name: AS Infocom
Theme URI: https://asinfocom.com/
Author: Sahara Cyber Tech
Author URI: https://saharacybertech.com/
Description: AS Infocom is a production-grade, WooCommerce-ready e-commerce theme for IT hardware, networking, computing and electronics retail. Built on the standard WordPress template hierarchy with a responsive, accessible, dark-tech design system. Scales from a single store to a high-traffic catalog.
Version: 1.4.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: as-infocom
Tags: e-commerce, woocommerce, two-columns, right-sidebar, custom-menu, custom-logo, featured-images, full-width-template, block-styles, translation-ready, accessibility-ready, responsive
WC requires at least: 7.0
WC tested up to: 8.9

AS Infocom WordPress Theme, (C) 2026 Sahara Cyber Tech.
AS Infocom is distributed under the terms of the GNU GPL v2 or later.
*/

/* =========================================================================
   1. Design Tokens (CSS Custom Properties)
   ========================================================================= */
:root {
	--asi-primary: #1559ed;
	--asi-primary-600: #0f47c4;
	--asi-primary-700: #0b1f3a;
	--asi-accent: #ff7a18;
	--asi-accent-600: #e96a0c;
	--asi-success: #16a34a;
	--asi-danger: #dc2626;
	--asi-warning: #f59e0b;

	--asi-ink: #0f172a;
	--asi-body: #334155;
	--asi-muted: #64748b;
	--asi-line: #e2e8f0;
	--asi-bg: #f5f7fb;
	--asi-surface: #ffffff;
	--asi-surface-alt: #f1f5f9;
	--asi-dark: #0b1224;
	--asi-dark-2: #131c33;

	--asi-radius: 12px;
	--asi-radius-sm: 8px;
	--asi-radius-lg: 20px;
	--asi-shadow-sm: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .08);
	--asi-shadow: 0 4px 16px rgba(15, 23, 42, .08);
	--asi-shadow-lg: 0 18px 40px rgba(11, 31, 58, .16);

	--asi-font: "Inter", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
	--asi-font-head: "Sora", "Inter", system-ui, sans-serif;

	--asi-container: 1240px;
	--asi-gutter: clamp(16px, 4vw, 28px);
	--asi-header-h: 76px;

	--asi-ease: cubic-bezier(.4, 0, .2, 1);
}

/* =========================================================================
   2. Reset & Base
   ========================================================================= */
*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--asi-font);
	font-size: 16px;
	line-height: 1.6;
	color: var(--asi-body);
	background: var(--asi-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body.asi-no-scroll { overflow: hidden; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--asi-font-head);
	color: var(--asi-ink);
	line-height: 1.2;
	margin: 0 0 .5em;
	font-weight: 700;
	letter-spacing: -.01em;
}

h1 { font-size: clamp(1.9rem, 4vw, 2.8rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.5rem); }

p { margin: 0 0 1rem; }

a {
	color: var(--asi-primary);
	text-decoration: none;
	transition: color .2s var(--asi-ease);
}
a:hover,
a:focus { color: var(--asi-primary-600); }

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

ul, ol { margin: 0 0 1rem; padding-left: 1.25rem; }

figure { margin: 0; }

hr { border: 0; border-top: 1px solid var(--asi-line); margin: 2rem 0; }

code, pre {
	font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
	background: var(--asi-surface-alt);
	border-radius: var(--asi-radius-sm);
}
code { padding: .15em .4em; font-size: .9em; }
pre { padding: 1rem; overflow: auto; }

/* =========================================================================
   3. Accessibility helpers
   ========================================================================= */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	word-wrap: normal !important;
}
.screen-reader-text:focus {
	background-color: #fff;
	clip: auto !important;
	clip-path: none;
	color: var(--asi-primary-700);
	display: block;
	font-size: 1rem;
	font-weight: 700;
	height: auto;
	left: 6px;
	line-height: normal;
	padding: 14px 22px;
	text-decoration: none;
	top: 6px;
	width: auto;
	z-index: 100000;
	border-radius: var(--asi-radius-sm);
	box-shadow: var(--asi-shadow);
}

.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100000;
}

:focus-visible {
	outline: 3px solid var(--asi-accent);
	outline-offset: 2px;
}

/* =========================================================================
   4. Layout
   ========================================================================= */
.asi-container {
	width: 100%;
	max-width: var(--asi-container);
	margin-inline: auto;
	padding-inline: var(--asi-gutter);
}

.asi-site { display: flex; flex-direction: column; min-height: 100vh; }
.asi-content-area { flex: 1 0 auto; padding-block: clamp(28px, 5vw, 56px); }

.asi-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: clamp(24px, 4vw, 40px);
}
.asi-has-sidebar .asi-layout { grid-template-columns: minmax(0, 1fr) 300px; }

@media (max-width: 900px) {
	.asi-has-sidebar .asi-layout { grid-template-columns: minmax(0, 1fr); }
}

.asi-section { padding-block: clamp(36px, 6vw, 72px); }
.asi-section--alt { background: var(--asi-surface); }

.asi-section-head { text-align: center; max-width: 720px; margin: 0 auto clamp(24px, 4vw, 44px); }
.asi-section-head .eyebrow {
	display: inline-block;
	font-size: .8rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--asi-primary);
	margin-bottom: .5rem;
}
.asi-section-head p { color: var(--asi-muted); }

/* =========================================================================
   5. Buttons
   ========================================================================= */
.asi-btn,
.button,
button,
input[type="submit"],
input[type="button"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	font-family: var(--asi-font);
	font-weight: 600;
	font-size: .95rem;
	line-height: 1;
	padding: .85rem 1.5rem;
	border-radius: var(--asi-radius-sm);
	border: 1px solid transparent;
	background: var(--asi-primary);
	color: #fff;
	cursor: pointer;
	text-decoration: none;
	transition: none;
	-webkit-appearance: none;
	appearance: none;
}

.asi-btn--accent,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce input.button.alt {
	background: var(--asi-accent);
}

.asi-btn--ghost {
	background: transparent;
	color: var(--asi-ink);
}

.asi-btn--lg { padding: 1.05rem 1.9rem; font-size: 1.05rem; }
.asi-btn--block { width: 100%; }

/* =========================================================================
   6. Forms
   ========================================================================= */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="date"],
textarea,
select {
	width: 100%;
	font-family: var(--asi-font);
	font-size: 1rem;
	color: var(--asi-ink);
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius-sm);
	padding: .75rem 1rem;
	transition: border-color .2s var(--asi-ease), box-shadow .2s var(--asi-ease);
}
input:focus,
textarea:focus,
select:focus {
	border-color: var(--asi-primary);
	box-shadow: 0 0 0 3px rgba(21, 89, 237, .15);
	outline: none;
}
textarea { min-height: 140px; resize: vertical; }
label { font-weight: 600; color: var(--asi-ink); display: inline-block; margin-bottom: .35rem; }

/* =========================================================================
   7. Header
   ========================================================================= */
.asi-topbar {
	background: var(--asi-dark);
	color: #cbd5e1;
	font-size: .85rem;
}
.asi-topbar a { color: #e2e8f0; }
.asi-topbar .asi-container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	min-height: 40px;
	flex-wrap: wrap;
}
.asi-topbar__list { display: flex; gap: 1.25rem; list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.asi-topbar__list li { display: flex; align-items: center; gap: .4rem; }

.asi-header {
	position: sticky;
	top: 0;
	z-index: 900;
	background: rgba(255, 255, 255, .92);
	backdrop-filter: saturate(140%) blur(10px);
	border-bottom: 1px solid var(--asi-line);
	transition: box-shadow .2s var(--asi-ease);
}
.asi-header--scrolled { box-shadow: var(--asi-shadow); }
.asi-header__inner {
	display: flex;
	align-items: center;
	gap: clamp(16px, 3vw, 32px);
	min-height: var(--asi-header-h);
}

.asi-brand { display: flex; align-items: center; gap: .6rem; flex-shrink: 0; }
.asi-brand__logo img { max-height: 46px; width: auto; }
.asi-brand__text { display: flex; flex-direction: column; line-height: 1.1; }
.asi-brand__name {
	font-family: var(--asi-font-head);
	font-weight: 800;
	font-size: 1.4rem;
	color: var(--asi-ink);
	letter-spacing: -.02em;
}
.asi-brand__name span { color: var(--asi-primary); }
.asi-brand__tag { font-size: .72rem; color: var(--asi-muted); letter-spacing: .04em; }

.asi-header__search { flex: 1 1 auto; max-width: 560px; }
.asi-header__actions { display: flex; align-items: center; gap: .5rem; margin-left: auto; }

.asi-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .4rem;
	width: 44px;
	height: 44px;
	border-radius: var(--asi-radius-sm);
	color: var(--asi-ink);
	background: transparent;
	border: 1px solid transparent;
	position: relative;
}
.asi-icon-btn:hover { background: var(--asi-surface-alt); color: var(--asi-primary); }
.asi-icon-btn svg { width: 22px; height: 22px; }

.asi-cart-count {
	position: absolute;
	top: 4px;
	right: 2px;
	min-width: 18px;
	height: 18px;
	padding: 0 4px;
	border-radius: 999px;
	background: var(--asi-accent);
	color: #fff;
	font-size: .68rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Primary navigation */
.asi-primary-nav { background: var(--asi-surface); border-bottom: 1px solid var(--asi-line); }
.asi-primary-nav .asi-container { display: flex; align-items: center; gap: 1rem; }
.asi-menu {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: .25rem;
}
.asi-menu a {
	display: block;
	padding: .9rem 1rem;
	font-weight: 600;
	font-size: .95rem;
	color: var(--asi-ink);
	border-radius: var(--asi-radius-sm);
}

/* Primary navbar: keep every item on one smart line, spread full width,
   with responsive spacing/size so it never wraps on desktop. */
.asi-primary-nav .asi-menu {
	flex-wrap: nowrap;
	width: 100%;
	justify-content: space-between;
	gap: clamp(0px, .3vw, .4rem);
}
.asi-primary-nav .asi-menu > li > a {
	white-space: nowrap;
	padding: .9rem clamp(.3rem, .6vw, .9rem);
	font-size: clamp(.78rem, .85vw, .92rem);
	letter-spacing: -.01em;
}
.asi-primary-nav .asi-menu .asi-caret { margin-left: .1rem; font-size: .7em; }
.asi-menu a:hover,
.asi-menu .current-menu-item > a { color: var(--asi-primary); background: var(--asi-surface-alt); }
.asi-menu li { position: relative; }
.asi-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	box-shadow: var(--asi-shadow-lg);
	padding: .4rem;
	list-style: none;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: all .2s var(--asi-ease);
	z-index: 50;
}
.asi-menu li:hover > .sub-menu,
.asi-menu li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.asi-menu .sub-menu a { padding: .6rem .8rem; font-size: .9rem; }

.asi-menu-toggle {
	display: none;
	align-items: center;
	gap: .5rem;
	background: transparent;
	border: 1px solid var(--asi-line);
	color: var(--asi-ink);
	padding: .6rem .9rem;
	border-radius: var(--asi-radius-sm);
	font-weight: 600;
}

/* =========================================================================
   8. Search form
   ========================================================================= */
.asi-search-form { position: relative; display: flex; }
.asi-search-form input[type="search"] { padding-right: 3rem; border-radius: 999px; }
.asi-search-form button {
	position: absolute;
	right: 4px;
	top: 4px;
	bottom: 4px;
	width: 44px;
	padding: 0;
	border-radius: 999px;
	background: var(--asi-primary);
}
.asi-search-form button svg { width: 18px; height: 18px; }

/* =========================================================================
   9. Hero
   ========================================================================= */
.asi-hero {
	position: relative;
	background: linear-gradient(135deg, var(--asi-dark) 0%, #16235b 55%, var(--asi-primary-600) 100%);
	color: #e2e8f0;
	overflow: hidden;
}
.asi-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle at 20% 20%, rgba(255, 122, 24, .18), transparent 38%),
		radial-gradient(circle at 85% 60%, rgba(21, 89, 237, .35), transparent 45%);
	pointer-events: none;
}
.asi-hero__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: clamp(24px, 5vw, 56px);
	align-items: center;
	padding-block: clamp(48px, 8vw, 96px);
}
.asi-hero h1 { color: #fff; }
.asi-hero p.lead { font-size: clamp(1rem, 1.6vw, 1.2rem); color: #cbd5e1; max-width: 48ch; }
.asi-hero__badges { display: flex; flex-wrap: wrap; gap: 1.25rem; margin-top: 1.5rem; }
.asi-hero__badge { display: flex; align-items: center; gap: .5rem; font-size: .9rem; color: #e2e8f0; }
.asi-hero__visual {
	background: rgba(255, 255, 255, .06);
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: var(--asi-radius-lg);
	padding: clamp(20px, 3vw, 32px);
	box-shadow: var(--asi-shadow-lg);
}
.asi-hero__visual ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .9rem; }
.asi-hero__visual li {
	display: flex;
	align-items: center;
	gap: .9rem;
	background: rgba(255, 255, 255, .05);
	border: 1px solid rgba(255, 255, 255, .08);
	border-radius: var(--asi-radius);
	padding: .9rem 1rem;
}
.asi-hero__visual .ico {
	width: 42px; height: 42px; flex-shrink: 0;
	display: grid; place-items: center;
	border-radius: var(--asi-radius-sm);
	background: rgba(21, 89, 237, .25);
	color: #fff;
}
.asi-hero__visual strong { color: #fff; display: block; }
.asi-hero__visual span { font-size: .82rem; color: #94a3b8; }

@media (max-width: 880px) {
	.asi-hero__inner { grid-template-columns: 1fr; }
}

/* =========================================================================
   10. Feature / USP strip
   ========================================================================= */
.asi-usp {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background: var(--asi-line);
	border-radius: var(--asi-radius);
	overflow: hidden;
	box-shadow: var(--asi-shadow-sm);
}
.asi-usp__item {
	background: var(--asi-surface);
	padding: 1.4rem 1.25rem;
	display: flex;
	align-items: center;
	gap: .85rem;
}
.asi-usp__item .ico { color: var(--asi-primary); flex-shrink: 0; }
.asi-usp__item strong { display: block; color: var(--asi-ink); font-size: .98rem; }
.asi-usp__item span { font-size: .82rem; color: var(--asi-muted); }
@media (max-width: 880px) { .asi-usp { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px) { .asi-usp { grid-template-columns: 1fr; } }

/* =========================================================================
   11. Category cards
   ========================================================================= */
.asi-cat-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: clamp(14px, 2vw, 22px);
}
.asi-cat-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: .75rem;
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	padding: 1.5rem 1rem;
	transition: transform .2s var(--asi-ease), box-shadow .2s var(--asi-ease), border-color .2s var(--asi-ease);
}
.asi-cat-card:hover { transform: translateY(-4px); box-shadow: var(--asi-shadow); border-color: var(--asi-primary); }
.asi-cat-card__icon {
	width: 64px; height: 64px;
	display: grid; place-items: center;
	border-radius: 50%;
	background: linear-gradient(135deg, rgba(21, 89, 237, .12), rgba(255, 122, 24, .12));
	color: var(--asi-primary);
}
.asi-cat-card h3 { font-size: 1rem; margin: 0; color: var(--asi-ink); }
.asi-cat-card span { font-size: .8rem; color: var(--asi-muted); }

/* =========================================================================
   12. Promo banners
   ========================================================================= */
.asi-promo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2.5vw, 24px); }
@media (max-width: 880px) { .asi-promo-grid { grid-template-columns: 1fr; } }
.asi-promo {
	position: relative;
	border-radius: var(--asi-radius-lg);
	padding: clamp(24px, 3vw, 36px);
	color: #fff;
	overflow: hidden;
	min-height: 200px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}
.asi-promo h3 { color: #fff; }
.asi-promo--blue { background: linear-gradient(135deg, var(--asi-primary), var(--asi-primary-700)); }
.asi-promo--dark { background: linear-gradient(135deg, #1f2937, var(--asi-dark)); }
.asi-promo--accent { background: linear-gradient(135deg, var(--asi-accent), #c2410c); }
.asi-promo .asi-btn { margin-top: 1rem; align-self: flex-start; }

/* =========================================================================
   13. Cards / posts
   ========================================================================= */
.asi-card {
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	overflow: hidden;
	box-shadow: var(--asi-shadow-sm);
}
.asi-post-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: clamp(18px, 3vw, 28px);
}
.asi-article { background: var(--asi-surface); border: 1px solid var(--asi-line); border-radius: var(--asi-radius); overflow: hidden; }
.asi-article__thumb img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.asi-article__body { padding: 1.25rem 1.4rem 1.5rem; }
.asi-article__meta { font-size: .8rem; color: var(--asi-muted); display: flex; gap: 1rem; margin-bottom: .5rem; }
.asi-article__title { font-size: 1.15rem; margin-bottom: .5rem; }
.asi-article__title a { color: var(--asi-ink); }
.asi-article__title a:hover { color: var(--asi-primary); }
.asi-readmore { font-weight: 600; display: inline-flex; align-items: center; gap: .35rem; }

.asi-page-header { margin-bottom: clamp(20px, 3vw, 32px); }
.asi-page-header h1 { margin-bottom: .25rem; }
.asi-breadcrumb { font-size: .85rem; color: var(--asi-muted); }
.asi-breadcrumb a { color: var(--asi-muted); }
.asi-breadcrumb a:hover { color: var(--asi-primary); }

.entry-content > * { margin-bottom: 1rem; }
.entry-content img { border-radius: var(--asi-radius-sm); }
.entry-content blockquote {
	border-left: 4px solid var(--asi-primary);
	margin: 1.5rem 0;
	padding: .5rem 1.25rem;
	background: var(--asi-surface-alt);
	border-radius: var(--asi-radius-sm);
	color: var(--asi-ink);
}

/* =========================================================================
   14. Sidebar & widgets
   ========================================================================= */
.asi-sidebar .widget {
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	padding: 1.25rem 1.4rem;
	margin-bottom: 1.5rem;
}
.asi-sidebar .widget-title {
	font-size: 1.05rem;
	margin-bottom: 1rem;
	padding-bottom: .65rem;
	border-bottom: 1px solid var(--asi-line);
}
.asi-sidebar ul { list-style: none; padding: 0; margin: 0; }
.asi-sidebar ul li { padding: .45rem 0; border-bottom: 1px dashed var(--asi-line); }
.asi-sidebar ul li:last-child { border-bottom: 0; }

/* =========================================================================
   15. Pagination
   ========================================================================= */
.asi-pagination { margin-top: 2.5rem; }
.asi-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 .75rem;
	margin: 0 .15rem;
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius-sm);
	background: var(--asi-surface);
	color: var(--asi-ink);
	font-weight: 600;
}
.asi-pagination .page-numbers.current,
.asi-pagination .page-numbers:hover { background: var(--asi-primary); color: #fff; border-color: var(--asi-primary); }

/* =========================================================================
   16. Footer
   ========================================================================= */
.asi-footer { background: var(--asi-dark); color: #94a3b8; margin-top: auto; }
.asi-footer a { color: #cbd5e1; }
.asi-footer a:hover { color: #fff; }
.asi-footer__top {
	display: grid;
	grid-template-columns: 1.6fr repeat(3, 1fr);
	gap: clamp(24px, 4vw, 48px);
	padding-block: clamp(40px, 6vw, 64px);
}
@media (max-width: 880px) { .asi-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .asi-footer__top { grid-template-columns: 1fr; } }
.asi-footer h4 { color: #fff; font-size: 1rem; margin-bottom: 1rem; }
.asi-footer ul { list-style: none; padding: 0; margin: 0; }
.asi-footer ul li { padding: .35rem 0; }
.asi-footer__brand .asi-brand__name { color: #fff; }
.asi-footer__brand p { color: #94a3b8; max-width: 38ch; }
.asi-footer__social { display: flex; gap: .6rem; margin-top: 1rem; }
.asi-footer__social a {
	width: 40px; height: 40px;
	display: grid; place-items: center;
	border-radius: var(--asi-radius-sm);
	background: rgba(255, 255, 255, .06);
	color: #cbd5e1;
}
.asi-footer__social a:hover { background: var(--asi-primary); color: #fff; }
.asi-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, .08);
	padding-block: 1.25rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	font-size: .85rem;
}
.asi-payment-icons { display: flex; gap: .5rem; align-items: center; }
.asi-payment-icons span {
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .04em;
	padding: .3rem .55rem;
	border-radius: 4px;
	background: rgba(255, 255, 255, .08);
	color: #e2e8f0;
}

/* =========================================================================
   17. Newsletter
   ========================================================================= */
.asi-newsletter {
	background: linear-gradient(135deg, var(--asi-primary), var(--asi-primary-700));
	border-radius: var(--asi-radius-lg);
	color: #fff;
	padding: clamp(28px, 4vw, 48px);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(20px, 3vw, 40px);
	align-items: center;
}
@media (max-width: 760px) { .asi-newsletter { grid-template-columns: 1fr; } }
.asi-newsletter h2 { color: #fff; }
.asi-newsletter p { color: rgba(255, 255, 255, .85); }
.asi-newsletter form { display: flex; gap: .5rem; flex-wrap: wrap; }
.asi-newsletter input[type="email"] { flex: 1 1 240px; }

/* =========================================================================
   18. Mobile drawer
   ========================================================================= */
.asi-drawer {
	position: fixed;
	inset: 0 30% 0 0;
	max-width: 360px;
	background: var(--asi-surface);
	box-shadow: var(--asi-shadow-lg);
	transform: translateX(-105%);
	transition: transform .3s var(--asi-ease);
	z-index: 1000;
	overflow-y: auto;
	padding: 1.25rem;
}
.asi-drawer.is-open { transform: translateX(0); }
.asi-drawer__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.asi-drawer .asi-menu { flex-direction: column; }
.asi-drawer .asi-menu .sub-menu {
	position: static; opacity: 1; visibility: visible; transform: none;
	box-shadow: none; border: 0; padding-left: 1rem;
}
.asi-overlay {
	position: fixed;
	inset: 0;
	background: rgba(11, 18, 36, .55);
	opacity: 0;
	visibility: hidden;
	transition: opacity .3s var(--asi-ease);
	z-index: 999;
}
.asi-overlay.is-open { opacity: 1; visibility: visible; }

@media (max-width: 980px) {
	.asi-header__search { display: none; }
}
/* The full one-line nav shows on wide screens where every item fits; below
   this the clean hamburger drawer takes over (it lists all items). */
@media (max-width: 1080px) {
	.asi-primary-nav { display: none; }
	.asi-menu-toggle { display: inline-flex; }
}

/* =========================================================================
   19. Utilities
   ========================================================================= */
.asi-grid { display: grid; gap: var(--asi-gutter); }
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.asi-badge {
	display: inline-flex;
	align-items: center;
	padding: .25rem .6rem;
	border-radius: 999px;
	font-size: .72rem;
	font-weight: 700;
	background: rgba(21, 89, 237, .1);
	color: var(--asi-primary);
}
.asi-badge--sale { background: rgba(220, 38, 38, .1); color: var(--asi-danger); }
.asi-badge--new { background: rgba(22, 163, 74, .12); color: var(--asi-success); }

.asi-empty {
	text-align: center;
	padding: clamp(40px, 8vw, 80px) 1rem;
	background: var(--asi-surface);
	border: 1px dashed var(--asi-line);
	border-radius: var(--asi-radius);
}
.asi-empty svg { width: 64px; height: 64px; color: var(--asi-muted); margin: 0 auto 1rem; }

/* =========================================================================
   20. Reduced motion
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .001ms !important;
		scroll-behavior: auto !important;
	}
}

/* =========================================================================
   Home page — native-block bridges (so the Home page is built from editable
   core blocks but renders with the theme's storefront design).
   ========================================================================= */
/* Keep the theme's container/section-head centering (don't blanket-reset group
   margins — that would kill .asi-container's margin-inline:auto). */
.asi-home-page .wp-block-group { margin-block: 0; }
.asi-home-page .wp-block-group.asi-container { margin-inline: auto; }
.asi-home-page .wp-block-group.asi-section-head { margin: 0 auto clamp(24px, 4vw, 44px); }

/* Core button blocks styled like the theme's buttons */
.asi-home-page .wp-block-buttons { margin: 0; align-items: center; }
.asi-home-page .wp-block-button { margin: 0; display: inline-flex; line-height: 1; }
.asi-home-page .wp-block-button__link {
	display: inline-flex; align-items: center; justify-content: center;
	font-family: var(--asi-font); font-weight: 600; font-size: .95rem; line-height: 1;
	padding: .85rem 1.5rem; border-radius: var(--asi-radius-sm); border: 1px solid transparent;
	background: var(--asi-primary); color: #fff; text-decoration: none;
	transition: none;
}
.asi-home-page .asi-btn--lg .wp-block-button__link { padding: 1.05rem 1.9rem; font-size: 1.05rem; }
.asi-home-page .asi-btn--accent .wp-block-button__link { background: var(--asi-accent); }
.asi-home-page .asi-btn--ghost .wp-block-button__link { background: transparent; color: #fff; }

/* core/columns reused for the hero + promo layouts behave like the existing grids */
.asi-home-page .asi-hero__inner.wp-block-columns,
.asi-home-page .asi-promo-grid.wp-block-columns { display: grid; align-items: center; }
.asi-home-page .asi-promo-grid.wp-block-columns { align-items: stretch; }
.asi-home-page .asi-hero__inner .wp-block-column,
.asi-home-page .asi-promo-grid .wp-block-column { flex-basis: auto !important; margin: 0; }
.asi-home-page .asi-hero__copy > *:first-child { margin-top: 0; }
.asi-home-page .asi-promo p { color: rgba(255, 255, 255, .88); }
.asi-home-page .asi-promo .wp-block-button { margin-top: 1rem; align-self: flex-start; }
.asi-home-page .asi-newsletter p { color: rgba(255, 255, 255, .85); }
.asi-home-page .wp-block-buttons.text-center { justify-content: center; margin-top: 2rem; }
@media (max-width: 880px) {
	.asi-home-page .asi-promo-grid.wp-block-columns { grid-template-columns: 1fr; }
}

/* Certificate / authorization grid (Certified Dealers page) */
.asi-cert-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: clamp(14px, 2vw, 22px);
	margin: 1.5rem 0 2rem;
	padding: 0;
	list-style: none;
}
.asi-cert-grid figure {
	margin: 0;
	background: var(--asi-surface);
	border: 1px solid var(--asi-line);
	border-radius: var(--asi-radius);
	overflow: hidden;
	box-shadow: var(--asi-shadow-sm);
	transition: transform .2s var(--asi-ease), box-shadow .2s var(--asi-ease);
}
.asi-cert-grid figure:hover { transform: translateY(-4px); box-shadow: var(--asi-shadow); }
.asi-cert-grid img { width: 100%; height: auto; display: block; }
.asi-cert-grid figcaption { padding: .7rem 1rem; font-size: .85rem; font-weight: 600; color: var(--asi-ink); border-top: 1px solid var(--asi-line); }

/* WordPress core alignment classes */
.alignleft { float: left; margin: .5rem 1.5rem 1rem 0; }
.alignright { float: right; margin: .5rem 0 1rem 1.5rem; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: .85rem; color: var(--asi-muted); text-align: center; }
.sticky, .gallery-caption, .bypostauthor { display: block; }
.wp-block-button__link { border-radius: var(--asi-radius-sm); }
