/* ============================================================
 *  Ecraft — Premium Engraving Theme · Main stylesheet
 *  Palette: white · charcoal · warm beige · gold accent
 *  ============================================================ */

:root {
	--clr-bg:        #ffffff;
	--clr-bg-alt:    #f5ede1;            /* warm beige */
	--clr-bg-cream:  #faf6ef;
	--clr-ink:       #131313;
	--clr-ink-soft:  #2a2622;
	--clr-mute:      #6e6a64;
	--clr-line:      #e7dfd0;
	--clr-line-dark: #1f1f1f;
	--clr-accent:      #8b2942;      /* deep burgundy / wine — primary brand accent */
	--clr-accent-soft: #b85575;      /* lighter burgundy */
	--clr-accent-bg:   #f6e6ea;      /* very pale burgundy wash */
	--clr-gold:        var(--clr-accent);       /* legacy alias — points to accent */
	--clr-gold-soft:   var(--clr-accent-soft);  /* legacy alias */
	--clr-pill:        #efece4;      /* button pill background */
	--clr-pill-info:   #e3e7f4;      /* customer-support pill background */
	--clr-cart-badge:  #d83a4c;      /* cart count badge */
	--clr-success:   #1f7a4c;
	--clr-danger:    #b3261e;

	--font-sans:     'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
	--font-display:  'Cormorant Garamond', Georgia, serif;

	--radius-xs:   6px;
	--radius-sm:   10px;
	--radius-md:   14px;
	--radius-lg:   22px;
	--radius-pill: 999px;

	--shadow-sm:   0 1px 2px rgba(19,19,19,.05), 0 1px 1px rgba(19,19,19,.03);
	--shadow-md:   0 12px 30px rgba(19,19,19,.07), 0 2px 6px rgba(19,19,19,.04);
	--shadow-lg:   0 30px 80px rgba(19,19,19,.12);

	--ease:        cubic-bezier(.22,.61,.36,1);
	--ease-out:    cubic-bezier(.16,1,.3,1);
	--dur:         .35s;
	--dur-slow:    .65s;

	--container:   1320px;
	--gutter:      clamp(20px, 4vw, 56px);
	--header-h:    72px;
}

/* Reset / base */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; font-family: var(--font-sans); font-size: 16px; line-height: 1.55; color: var(--clr-ink); background: #faf6ee; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img, svg, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
.screen-reader-text { position: absolute; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }
.skip-link:focus { position: fixed; top: 12px; left: 12px; background: #000; color: #fff; padding: 8px 14px; border-radius: 6px; z-index: 9999; }
::selection { background: var(--clr-gold); color: #fff; }

/* Typography */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.1; letter-spacing: -.01em; margin: 0 0 .4em; color: var(--clr-ink); }
h1 { font-size: clamp(2.4rem, 5.5vw, 4.4rem); }
h2 { font-size: clamp(1.9rem, 4vw, 3.2rem); }
h3 { font-size: clamp(1.2rem, 2.2vw, 1.6rem); }
p  { margin: 0 0 1rem; color: var(--clr-ink-soft); }

.ecraft-eyebrow { display: inline-block; font-size: .78rem; text-transform: uppercase; letter-spacing: .22em; font-weight: 600; color: var(--clr-mute); margin-bottom: 14px; }
.ecraft-eyebrow--light { color: rgba(255,255,255,.7); }
.ecraft-eyebrow--gold  { color: var(--clr-gold); }

/* Layout primitives */
.ecraft-container { max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.ecraft-section { padding: clamp(64px, 9vw, 120px) 0; }
.ecraft-section--cream { background: var(--clr-bg-cream); }
.ecraft-section--beige { background: var(--clr-bg-alt); }
.ecraft-section--dark  { background: #1a1815; color: #fff; }
.ecraft-section--ink   { background: var(--clr-ink); color: #fff; }
.ecraft-section--dark h2, .ecraft-section--ink h2, .ecraft-section--dark h3, .ecraft-section--ink h3 { color: #fff; }
.ecraft-section--dark p, .ecraft-section--ink p { color: rgba(255,255,255,.72); }

.ecraft-section__head { margin-bottom: clamp(36px, 5vw, 64px); max-width: 760px; }
.ecraft-section__head--centered { margin-inline: auto; text-align: center; }
.ecraft-section__head--narrow { max-width: 680px; margin-inline: auto; text-align: center; }
.ecraft-section__head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 32px; max-width: none; flex-wrap: wrap; }
.ecraft-section__title { font-size: clamp(1.9rem, 4vw, 3rem); }
.ecraft-section__title--editorial { font-style: italic; font-weight: 500; }
.ecraft-section__sub { font-size: 1.05rem; color: var(--clr-mute); }
.ecraft-section__cta { margin-top: clamp(36px, 5vw, 56px); text-align: center; }

.ecraft-grid { display: grid; gap: clamp(20px, 2.5vw, 32px); }
.ecraft-grid--products   { grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); }
.ecraft-grid--categories { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.ecraft-grid--features   { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.ecraft-grid--gallery    { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

/* Buttons */
.ecraft-btn { display: inline-flex; align-items: center; gap: 10px; padding: 14px 26px; font-weight: 500; font-size: .95rem; border-radius: var(--radius-pill); border: 1px solid transparent; cursor: pointer; transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); white-space: nowrap; text-decoration: none; }
.ecraft-btn--lg    { padding: 17px 30px; font-size: 1rem; }
.ecraft-btn--sm    { padding: 9px 16px; font-size: .85rem; }
.ecraft-btn--block { width: 100%; justify-content: center; }
.ecraft-btn--solid { background: var(--clr-ink); color: #fff; }
.ecraft-btn--solid:hover { background: #fff; color: var(--clr-ink); box-shadow: var(--shadow-lg); transform: translateY(-2px); border-color: var(--clr-ink); }
.ecraft-btn--ghost { background: transparent; color: var(--clr-ink); border-color: var(--clr-ink); }
.ecraft-btn--ghost:hover { background: var(--clr-ink); color: #fff; transform: translateY(-2px); }
.ecraft-btn--gold { background: var(--clr-gold); color: #fff; }
.ecraft-btn--gold:hover { background: var(--clr-ink); color: #fff; transform: translateY(-2px); }
.ecraft-btn--glass { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.4); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.ecraft-btn--glass:hover { background: #fff; color: var(--clr-ink); }
.ecraft-btn__arrow { display: inline-flex; transition: transform var(--dur) var(--ease); }
.ecraft-btn:hover .ecraft-btn__arrow { transform: translateX(4px); }

/* Links */
.ecraft-link-arrow { display: inline-flex; align-items: center; gap: 8px; font-weight: 500; border-bottom: 1px solid currentColor; padding-bottom: 4px; transition: gap var(--dur) var(--ease); }
.ecraft-link-arrow:hover { gap: 14px; }
.ecraft-link-arrow--lg { font-size: 1.02rem; }

/* Forms */
.ecraft-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.ecraft-field > span { font-size: .85rem; color: var(--clr-mute); font-weight: 500; }
input[type="text"], input[type="email"], input[type="tel"], input[type="number"], input[type="url"], input[type="search"], select, textarea {
	font: inherit; width: 100%; padding: 14px 16px;
	border: 1px solid var(--clr-line); border-radius: var(--radius-sm);
	background: #fff; color: var(--clr-ink);
	transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--clr-ink); box-shadow: 0 0 0 4px rgba(19,19,19,.06); }
.ecraft-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 600px) { .ecraft-field-row { grid-template-columns: 1fr; } }

/* ============================================================
 *  Ventro-style header
 *   - Black announcement bar + burgundy underline
 *   - White floating card with rounded TOP corners
 *   - Row 1: search-left · centered logo · account+cart-right (bare icons)
 *   - Row 2: centered nav, minimal text
 *  ============================================================ */

body.ecraft-body { background: #faf6ee; }

/* Black announcement bar */
.ecraft-announcement {
	background: #000;
	color: #fff;
	font-size: .9rem;
	border-bottom: 2px solid var(--clr-accent);
}
.ecraft-announcement__inner {
	padding: 14px 0;
	display: flex; align-items: center; justify-content: center; gap: 10px;
	font-style: italic;
	letter-spacing: 0.01em;
}
.ecraft-announcement__icon { display: inline-flex; opacity: .9; }
.ecraft-announcement__text strong { font-weight: 600; font-style: normal; letter-spacing: 0.05em; }

/* Floating header card */
.ecraft-header {
	position: sticky; top: 0; z-index: 80;
	background: #fff;
	border-top-left-radius: 28px;
	border-top-right-radius: 28px;
	margin-top: 0;
	transition: box-shadow var(--dur) var(--ease);
}
.ecraft-header.is-scrolled {
	box-shadow: 0 4px 24px -8px rgba(0,0,0,.08);
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}

/* Row 1 — equal columns so brand is perfectly centered */
.ecraft-header__top {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 24px;
	padding: 26px 0 18px;
}
.ecraft-header__left    { justify-self: start; display: flex; align-items: center; gap: 4px; }
.ecraft-header__brand   { justify-self: center; }
.ecraft-header__actions { justify-self: end; display: flex; align-items: center; gap: 4px; }

/* Wordmark — geometric "E" mark + letterspaced ECRAFT */
.ecraft-wordmark { display: inline-flex; align-items: center; gap: 10px; color: var(--clr-ink); }
.ecraft-wordmark__mark { color: var(--clr-ink); line-height: 0; }
.ecraft-wordmark__primary {
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: 1.6rem;
	letter-spacing: 0.35em;
	color: var(--clr-ink);
	text-transform: uppercase;
	font-style: normal;
	line-height: 1;
}
.ecraft-wordmark--light { color: #fff; }
.ecraft-wordmark--light .ecraft-wordmark__mark,
.ecraft-wordmark--light .ecraft-wordmark__primary { color: #fff; }

/* Bare icon buttons (no pill background) */
.ecraft-icon-btn {
	position: relative;
	width: 44px; height: 44px;
	display: inline-flex; align-items: center; justify-content: center;
	background: transparent; border: none;
	color: var(--clr-ink);
	cursor: pointer;
	border-radius: 50%;
	transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.ecraft-icon-btn:hover { color: var(--clr-accent); background: rgba(139,41,66,0.05); }

/* Tiny cart count — minimal, no red, no border */
.ecraft-icon-btn__badge {
	position: absolute;
	top: 2px; right: 4px;
	min-width: auto; height: auto;
	padding: 0;
	background: transparent;
	color: var(--clr-accent);
	border: none;
	font-size: .72rem;
	font-weight: 700;
	font-family: var(--font-sans);
	letter-spacing: 0;
}

/* Hamburger (mobile only — hidden on desktop) */
.ecraft-header__menu-toggle { display: none; }
.ecraft-burger { width: 22px; height: 14px; display: inline-grid; gap: 4px; }
.ecraft-burger span { display: block; height: 1.6px; background: currentColor; }

/* Row 2 — centered nav */
.ecraft-header__nav {
	display: flex;
	justify-content: center;
	padding: 4px 0 22px;
}
.ecraft-primary-nav__list {
	display: flex;
	gap: 36px;
	list-style: none;
	margin: 0;
	padding: 0;
	flex-wrap: wrap;
	justify-content: center;
}
.ecraft-primary-nav__list > li > a {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: .94rem; font-weight: 500;
	padding: 4px 0;
	color: var(--clr-ink);
	transition: color var(--dur) var(--ease);
	position: relative;
}
.ecraft-primary-nav__list > li > a::after {
	content: ''; position: absolute; left: 0; right: 0; bottom: -4px;
	height: 1.5px; background: var(--clr-accent);
	transform: scaleX(0); transform-origin: left;
	transition: transform var(--dur) var(--ease);
}
.ecraft-primary-nav__list > li.current-menu-item > a,
.ecraft-primary-nav__list > li:hover > a { color: var(--clr-accent); }
.ecraft-primary-nav__list > li.current-menu-item > a::after,
.ecraft-primary-nav__list > li:hover > a::after { transform: scaleX(1); }

/* ===== Drawers ===== */
.ecraft-panel { position: fixed; top: 0; bottom: 0; width: min(440px, 92vw); background: #fff; z-index: 100; box-shadow: var(--shadow-lg); transform: translateX(-100%); transition: transform var(--dur) var(--ease-out); display: flex; flex-direction: column; }
.ecraft-panel--right { left: auto; right: 0; transform: translateX(100%); }
.ecraft-panel.is-open { transform: translateX(0); }
.ecraft-panel__header { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--clr-line); }
.ecraft-panel__title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 600; }
.ecraft-panel__body { flex: 1; overflow-y: auto; padding: 22px; }
.ecraft-panel__search { padding: 14px 22px; border-bottom: 1px solid var(--clr-line); }
.ecraft-panel__nav { flex: 1; overflow-y: auto; padding: 14px 22px; }
.ecraft-panel__menu { list-style: none; margin: 0; padding: 0; }
.ecraft-panel__menu li { border-bottom: 1px solid var(--clr-line); }
.ecraft-panel__menu a { display: block; padding: 16px 0; font-size: 1.02rem; font-weight: 500; }
.ecraft-panel__footer { padding: 18px 22px; display: grid; gap: 10px; border-top: 1px solid var(--clr-line); }

.ecraft-backdrop { position: fixed; inset: 0; background: rgba(19,19,19,.45); z-index: 99; opacity: 0; pointer-events: none; transition: opacity var(--dur) var(--ease); }
.ecraft-backdrop.is-active { opacity: 1; pointer-events: auto; }

.ecraft-overlay { position: fixed; inset: 0; background: rgba(255,255,255,.97); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); z-index: 120; display: flex; flex-direction: column; opacity: 0; pointer-events: none; transition: opacity var(--dur) var(--ease); }
.ecraft-overlay.is-open { opacity: 1; pointer-events: auto; }
.ecraft-overlay__close { position: absolute; top: 22px; right: 22px; width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--clr-line); background: #fff; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.ecraft-overlay__inner { margin: auto; width: min(720px, 92vw); padding: 60px var(--gutter); }
.ecraft-overlay__form { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: center; border-bottom: 1px solid var(--clr-ink); padding-bottom: 14px; }
.ecraft-overlay__form input[type="search"] { border: none; padding: 14px 0; font-size: 1.6rem; background: transparent; }
.ecraft-overlay__hints { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 10px 18px; align-items: center; font-size: .9rem; }
.ecraft-overlay__hint-label { color: var(--clr-mute); }
.ecraft-overlay__hints a { padding: 6px 12px; border: 1px solid var(--clr-line); border-radius: var(--radius-pill); }
.ecraft-overlay__hints a:hover { background: var(--clr-ink); color: #fff; border-color: var(--clr-ink); }

/* ===== Hero ===== */
.ecraft-hero { position: relative; min-height: clamp(560px, 80vh, 820px); display: flex; align-items: center; color: #fff; overflow: hidden; }
.ecraft-hero__media { position: absolute; inset: 0; z-index: 0; }
.ecraft-hero__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.04); animation: ecraft-hero-zoom 18s var(--ease) forwards; }
@keyframes ecraft-hero-zoom { to { transform: scale(1); } }
.ecraft-hero__placeholder { position: absolute; inset: 0; background:
	radial-gradient(1200px 600px at 20% 20%, rgba(184,137,60,.3), transparent 60%),
	radial-gradient(900px 500px at 80% 60%, rgba(255,255,255,.08), transparent 60%),
	linear-gradient(180deg, #1a1614 0%, #2a221d 100%); }
.ecraft-hero__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.55) 100%); }
.ecraft-hero__inner { position: relative; z-index: 1; padding: 100px 0; max-width: 760px; }
.ecraft-hero__title { color: #fff; font-size: clamp(2.4rem, 6vw, 5rem); margin-bottom: 18px; }
.ecraft-hero__sub { font-size: clamp(1rem, 1.5vw, 1.2rem); color: rgba(255,255,255,.85); max-width: 540px; margin-bottom: 36px; }
.ecraft-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.ecraft-hero__meta { margin-top: 48px; display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.ecraft-hero__rating { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,.9); font-size: .88rem; }
.ecraft-stars { display: inline-flex; gap: 2px; color: var(--clr-gold-soft); }
.ecraft-hero__divider { width: 1px; height: 20px; background: rgba(255,255,255,.3); }
.ecraft-hero__pill { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25); border-radius: var(--radius-pill); backdrop-filter: blur(12px); font-size: .85rem; }

/* ===== Trust strip ===== */
.ecraft-trust { background: var(--clr-bg-alt); padding: 36px 0; }
.ecraft-trust-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.ecraft-trust-row__item { display: flex; align-items: center; gap: 14px; }
.ecraft-trust-row__icon { width: 48px; height: 48px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-sm); display: inline-flex; align-items: center; justify-content: center; color: var(--clr-gold); flex-shrink: 0; }
.ecraft-trust-row__copy { display: flex; flex-direction: column; }
.ecraft-trust-row__copy strong { font-size: .92rem; font-weight: 600; }
.ecraft-trust-row__copy span { font-size: .82rem; color: var(--clr-mute); }
@media (max-width: 900px) { .ecraft-trust-row { grid-template-columns: 1fr 1fr; } }

/* ===== Process / how it works ===== */
.ecraft-process__list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; position: relative; }
.ecraft-process__step { padding: 24px; background: rgba(255,255,255,.03); border-radius: var(--radius-lg); border: 1px solid rgba(255,255,255,.08); }
.ecraft-process__num { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 50%; background: var(--clr-gold); color: #fff; font-family: var(--font-display); font-size: 1rem; font-weight: 600; margin-bottom: 14px; }
.ecraft-process__title { color: #fff; font-size: 1.2rem; margin-bottom: 8px; }
.ecraft-process__text { color: rgba(255,255,255,.7); font-size: .9rem; }
@media (max-width: 900px) { .ecraft-process__list { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .ecraft-process__list { grid-template-columns: 1fr; } }

/* ===== Category cards — 1:1 square, premium hover ===== */
.ecraft-cat-card {
	position: relative; border-radius: var(--radius-lg); overflow: hidden;
	background: var(--clr-bg-cream);
	transition: transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}
.ecraft-cat-card:hover { transform: translateY(-6px); box-shadow: 0 26px 60px -20px rgba(19,19,19,0.18); }
.ecraft-cat-card__link { display: block; color: inherit; }
.ecraft-cat-card__media { position: relative; aspect-ratio: 1/1; overflow: hidden; }
.ecraft-cat-card__media img,
.ecraft-cat-card__media .ecraft-svg-ph { width: 100%; height: 100%; object-fit: cover; transition: transform .65s var(--ease-out); display: block; }
.ecraft-cat-card:hover .ecraft-cat-card__media img,
.ecraft-cat-card:hover .ecraft-cat-card__media .ecraft-svg-ph { transform: scale(1.06); }
.ecraft-cat-card__placeholder { width: 100%; height: 100%; }
.ecraft-cat-card__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.55) 100%); pointer-events: none; }
.ecraft-cat-card__body { position: absolute; left: 22px; right: 22px; bottom: 22px; color: #fff; z-index: 2; }
.ecraft-cat-card__title { color: #fff; font-size: 1.4rem; margin: 0; }
.ecraft-cat-card__desc { color: rgba(255,255,255,.85); font-size: .88rem; margin: 4px 0 10px; }
.ecraft-cat-card__cta { display: inline-flex; align-items: center; gap: 6px; font-size: .88rem; font-weight: 500; transition: gap var(--dur) var(--ease); }
.ecraft-cat-card:hover .ecraft-cat-card__cta { gap: 12px; }

/* ===== Product card — 1:1 square media, uniform heights, refined hover ===== */
.ecraft-card {
	position: relative;
	display: flex; flex-direction: column;
	background: #fff;
	border-radius: var(--radius-md);
	overflow: hidden;
	transition: box-shadow .35s var(--ease-out), transform .35s var(--ease-out);
}
.ecraft-card:hover { box-shadow: 0 24px 50px -18px rgba(19,19,19,0.16); transform: translateY(-6px); }

.ecraft-card__media {
	position: relative;
	display: block;
	aspect-ratio: 1/1;        /* FIXED 1:1 — no stretch, no crop creep */
	overflow: hidden;
	background: var(--clr-bg-cream);
	padding: 20px;            /* uniform internal padding around every product image */
}
.ecraft-card__img,
.ecraft-card__media img,
.ecraft-svg-wrap .ecraft-svg-ph {
	width: 100% !important;
	height: 100% !important;
	object-fit: contain;       /* preserve product silhouette (no awkward crops) */
	transition: transform .6s var(--ease-out);
	display: block;
}
.ecraft-card:hover .ecraft-card__img,
.ecraft-card:hover .ecraft-svg-wrap .ecraft-svg-ph { transform: scale(1.05); }
.ecraft-card__img-wrap { position: relative; display: block; width: 100%; height: 100%; }
.ecraft-card__img--hover { position: absolute; inset: 0; opacity: 0; transition: opacity .35s var(--ease-out); }
.ecraft-card:hover .ecraft-card__img--hover { opacity: 1; }
.ecraft-svg-wrap { display: block; width: 100%; height: 100%; }
.ecraft-card__placeholder-img { aspect-ratio: 1/1; background: linear-gradient(135deg, #f5ede1 0%, #e6d4b3 100%); display: flex; align-items: center; justify-content: center; }

.ecraft-card__badges { position: absolute; top: 14px; left: 14px; display: flex; flex-direction: column; gap: 6px; z-index: 2; }
.ecraft-badge { display: inline-flex; align-items: center; padding: 4px 10px; border-radius: var(--radius-pill); font-size: .68rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; background: #fff; color: var(--clr-ink); box-shadow: var(--shadow-sm); }
.ecraft-badge--sale    { background: var(--clr-danger); color: #fff; }
.ecraft-badge--best    { background: var(--clr-ink);    color: #fff; }
.ecraft-badge--engrave { background: var(--clr-gold);   color: #fff; }
.ecraft-card__body {
	display: flex; flex-direction: column;
	flex: 1 1 auto;
	padding: 18px 20px 22px;
}
.ecraft-card__title { font-family: var(--font-sans); font-weight: 600; font-size: 1rem; margin: 0 0 4px; line-height: 1.35; }
.ecraft-card__title a:hover { color: var(--clr-accent); }
.ecraft-card__attrs { color: var(--clr-mute); font-size: .8rem; margin: 0 0 10px; }
.ecraft-card__row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; gap: 10px; }
.ecraft-card__price { font-weight: 600; font-size: 1.04rem; }
.ecraft-card__price del { color: var(--clr-mute); font-weight: 400; margin-right: 6px; font-size: .9em; }
.ecraft-card__cta { width: 100%; justify-content: center; margin-top: auto; }   /* pushes CTA to bottom → uniform heights */
.ecraft-card__actions { position: absolute; top: 14px; right: 14px; display: flex; flex-direction: column; gap: 8px; opacity: 0; transform: translateX(8px); transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease); z-index: 2; }
.ecraft-card:hover .ecraft-card__actions { opacity: 1; transform: translateX(0); }
.ecraft-card__action { width: 38px; height: 38px; border-radius: 50%; border: none; background: rgba(255,255,255,.95); display: inline-flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: var(--shadow-sm); transition: background var(--dur) var(--ease), color var(--dur) var(--ease); }
.ecraft-card__action:hover { background: var(--clr-ink); color: #fff; }
.ecraft-card-li { list-style: none; }

/* ===== Storytelling ===== */
.ecraft-story__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 80px); align-items: center; }
.ecraft-story__media { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3; }
.ecraft-story__media img { width: 100%; height: 100%; object-fit: cover; }
.ecraft-story__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #f5ede1 0%, #d9c9a7 100%); }
.ecraft-story__text { font-size: 1.02rem; color: var(--clr-mute); margin-bottom: 18px; }
.ecraft-story__list { list-style: none; padding: 0; margin: 0 0 22px; }
.ecraft-story__list li { padding: 6px 0; }
@media (max-width: 800px) { .ecraft-story__grid { grid-template-columns: 1fr; } }

/* ===== Reviews ===== */
.ecraft-reviews__track { display: grid; grid-auto-flow: column; grid-auto-columns: clamp(280px, 28vw, 380px); gap: 24px; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 10px; scrollbar-width: thin; }
.ecraft-review { scroll-snap-align: start; padding: 30px; background: #fff; border: 1px solid var(--clr-line); border-radius: var(--radius-lg); display: flex; flex-direction: column; gap: 16px; min-height: 260px; }
.ecraft-review__stars { color: var(--clr-gold); display: inline-flex; gap: 2px; }
.ecraft-review__quote { font-family: var(--font-display); font-size: 1.1rem; line-height: 1.5; margin: 0; color: var(--clr-ink-soft); font-style: italic; }
.ecraft-review__meta { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.ecraft-review__avatar { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; }
.ecraft-review__avatar--ph { background: var(--clr-ink); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 600; }
.ecraft-review__meta strong { font-size: .95rem; display: inline-flex; align-items: center; gap: 6px; }
.ecraft-verified { font-size: .68rem; padding: 2px 6px; border-radius: var(--radius-pill); background: rgba(31,122,76,.1); color: var(--clr-success); font-weight: 600; }
.ecraft-review__meta small { display: block; color: var(--clr-mute); font-size: .8rem; }
.ecraft-slider__nav { display: flex; gap: 10px; justify-content: center; margin-top: 24px; }
.ecraft-slider__btn { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--clr-line); background: #fff; cursor: pointer; font-size: 1.4rem; line-height: 1; transition: background var(--dur) var(--ease), color var(--dur) var(--ease); }
.ecraft-slider__btn:hover { background: var(--clr-ink); color: #fff; }

/* ===== Final CTA ===== */
.ecraft-final-cta__inner { text-align: center; max-width: 720px; margin-inline: auto; padding: 60px 0; }
.ecraft-final-cta__title { color: #fff; font-size: clamp(2.2rem, 5vw, 4rem); font-style: italic; margin-bottom: 18px; }
.ecraft-final-cta__sub { color: rgba(255,255,255,.75); font-size: 1.05rem; margin-bottom: 36px; }
.ecraft-final-cta__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ===== Newsletter ===== */
.ecraft-newsletter { background: var(--clr-ink); color: #fff; padding: 56px 0; }
.ecraft-newsletter__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.ecraft-newsletter h3 { color: #fff; font-size: clamp(1.6rem, 3vw, 2.4rem); margin: 0 0 8px; }
.ecraft-newsletter p { color: rgba(255,255,255,.7); margin: 0; }
.ecraft-newsletter__form { display: grid; grid-template-columns: 1fr auto; gap: 10px; }
.ecraft-newsletter__form input { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.18); color: #fff; }
.ecraft-newsletter__form input::placeholder { color: rgba(255,255,255,.55); }
.ecraft-newsletter__form .ecraft-btn--solid { background: var(--clr-gold); color: #fff; border-color: var(--clr-gold); }
.ecraft-newsletter__form .ecraft-btn--solid:hover { background: #fff; color: var(--clr-ink); }
@media (max-width: 900px) { .ecraft-newsletter__inner { grid-template-columns: 1fr; } }

/* ===== Footer ===== */
.ecraft-footer { background: #0e0e0e; color: rgba(255,255,255,.7); padding: 72px 0 32px; }
.ecraft-footer .ecraft-wordmark__primary { color: #fff; }
.ecraft-footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 44px; }
.ecraft-footer__tag { color: var(--clr-gold); font-family: var(--font-display); font-style: italic; margin: 18px 0 10px; }
.ecraft-footer__about { max-width: 360px; font-size: .92rem; }
.ecraft-social { list-style: none; padding: 0; margin: 22px 0 0; display: flex; gap: 10px; }
.ecraft-social a { width: 38px; height: 38px; border-radius: 50%; border: 1px solid rgba(255,255,255,.18); display: inline-flex; align-items: center; justify-content: center; transition: background var(--dur) var(--ease), color var(--dur) var(--ease); }
.ecraft-social a:hover { background: var(--clr-gold); color: #fff; }
.ecraft-footer__heading { color: #fff; font-family: var(--font-sans); font-weight: 600; font-size: .9rem; letter-spacing: .08em; text-transform: uppercase; margin: 0 0 18px; }
.ecraft-footer__menu { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.ecraft-footer__menu a:hover { color: #fff; }
.ecraft-footer__contact address { font-style: normal; font-size: .92rem; }
.ecraft-footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 36px; margin-top: 56px; border-top: 1px solid rgba(255,255,255,.08); gap: 24px; flex-wrap: wrap; }
.ecraft-payments { list-style: none; padding: 0; margin: 0; display: flex; gap: 6px; flex-wrap: wrap; }
.ecraft-pay { font-size: .65rem; letter-spacing: .08em; font-weight: 700; padding: 6px 10px; border: 1px solid rgba(255,255,255,.18); border-radius: 4px; }
.ecraft-pay--bkash  { background: #E2136E; color: #fff; border-color: #E2136E; }
.ecraft-pay--nagad  { background: #EC1C24; color: #fff; border-color: #EC1C24; }
.ecraft-pay--rocket { background: #8C2786; color: #fff; border-color: #8C2786; }
@media (max-width: 900px) { .ecraft-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .ecraft-footer__grid { grid-template-columns: 1fr; } }

/* ===== Floating WhatsApp ===== */
.ecraft-fab-whatsapp { position: fixed; right: 22px; bottom: 86px; width: 56px; height: 56px; background: #25D366; color: #fff; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 10px 30px rgba(37,211,102,.4); z-index: 70; animation: ecraft-pulse 2.4s var(--ease) infinite; }
@keyframes ecraft-pulse { 50% { box-shadow: 0 10px 40px rgba(37,211,102,.7); } }

/* ===== Reveal animations ===== */
[data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
[data-reveal].is-revealed { opacity: 1; transform: translateY(0); }
[data-reveal-child] { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--ease-out), transform .7s var(--ease-out); }
[data-reveal].is-revealed [data-reveal-child] { opacity: 1; transform: translateY(0); }
[data-reveal].is-revealed [data-reveal-child]:nth-child(2) { transition-delay: 80ms; }
[data-reveal].is-revealed [data-reveal-child]:nth-child(3) { transition-delay: 160ms; }
[data-reveal].is-revealed [data-reveal-child]:nth-child(4) { transition-delay: 240ms; }
[data-reveal].is-revealed [data-reveal-child]:nth-child(5) { transition-delay: 320ms; }

@media (prefers-reduced-motion: reduce) { * { animation-duration: 0s !important; transition-duration: 0s !important; } }

/* ===== Breadcrumbs ===== */
.ecraft-breadcrumbs { font-size: .82rem; color: var(--clr-mute); margin: 24px 0 16px; }
.ecraft-breadcrumbs a:hover { color: var(--clr-ink); }
.ecraft-breadcrumbs__sep { margin: 0 6px; }

/* ===== Shop ===== */
.ecraft-shop__hero { padding: 60px 0 30px; }
.ecraft-shop__title { font-size: clamp(2.2rem, 4vw, 3.4rem); }
.ecraft-shop__layout { display: grid; grid-template-columns: 260px 1fr; gap: 44px; padding-bottom: 80px; }
.ecraft-shop__sidebar { position: sticky; top: calc(var(--header-h) + 24px); align-self: start; }
.ecraft-shop__toolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--clr-line); margin-bottom: 24px; }
@media (max-width: 900px) { .ecraft-shop__layout { grid-template-columns: 1fr; } .ecraft-shop__sidebar { position: static; } }

/* ===== Page hero ===== */
.ecraft-page-hero { padding: 80px 0 60px; }
.ecraft-page-hero h1 { font-size: clamp(2.4rem, 5vw, 4rem); }
.ecraft-page-hero__sub { font-size: 1.1rem; color: var(--clr-mute); max-width: 620px; margin-bottom: 28px; }
.ecraft-page-content { padding: 60px 0 100px; max-width: 760px; margin-inline: auto; font-size: 1.05rem; }
.ecraft-page-content p { margin-bottom: 1.2em; }

/* ===== Features (engraving types) ===== */
.ecraft-feature-card { padding: 28px; background: #fff; border: 1px solid var(--clr-line); border-radius: var(--radius-lg); transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease); }
.ecraft-feature-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.ecraft-feature-card__icon { width: 56px; height: 56px; border-radius: 50%; background: var(--clr-bg-alt); color: var(--clr-gold); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.ecraft-feature-card__title { font-size: 1.25rem; margin-bottom: 6px; }

/* ===== Before/After ===== */
.ecraft-ba { position: relative; aspect-ratio: 4/5; border-radius: var(--radius-lg); overflow: hidden; margin: 0; cursor: pointer; }
.ecraft-ba__before, .ecraft-ba__after { position: absolute; inset: 0; }
.ecraft-ba__before img, .ecraft-ba__after img { width: 100%; height: 100%; object-fit: cover; }
.ecraft-ba__ph { width: 100%; height: 100%; background: linear-gradient(135deg, #f5ede1, #d9c9a7); }
.ecraft-ba__ph--after { background: linear-gradient(135deg, #2a2622, #4a3f33); }
.ecraft-ba__after { opacity: 0; transition: opacity var(--dur-slow) var(--ease); }
.ecraft-ba:hover .ecraft-ba__after, .ecraft-ba:focus .ecraft-ba__after { opacity: 1; }
.ecraft-ba__label { position: absolute; top: 14px; left: 14px; padding: 4px 10px; background: rgba(255,255,255,.95); color: var(--clr-ink); font-size: .7rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; border-radius: var(--radius-pill); }
.ecraft-ba__after .ecraft-ba__label { background: var(--clr-gold); color: #fff; }
.ecraft-ba__cap { position: absolute; left: 14px; right: 14px; bottom: 14px; color: #fff; font-size: .92rem; font-weight: 500; text-shadow: 0 1px 8px rgba(0,0,0,.5); }

/* ===== Corporate Orders ===== */
.ecraft-corporate__layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 64px); align-items: start; }
.ecraft-corporate__list { list-style: none; padding: 0; margin: 18px 0 28px; font-size: .95rem; }
.ecraft-corporate__list li { padding: 12px 0; border-bottom: 1px solid var(--clr-line); }
.ecraft-corporate__list li:last-child { border-bottom: none; }
.ecraft-corporate__sub-h { font-family: var(--font-sans); font-size: .9rem; letter-spacing: .08em; text-transform: uppercase; color: var(--clr-mute); margin: 8px 0 12px; }
.ecraft-corporate__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.ecraft-corporate__tags span { padding: 6px 14px; background: var(--clr-bg-alt); border-radius: var(--radius-pill); font-size: .85rem; }
.ecraft-corporate__form { background: #fff; border-radius: var(--radius-lg); padding: clamp(24px, 4vw, 40px); box-shadow: var(--shadow-md); position: sticky; top: calc(var(--header-h) + 24px); }
.ecraft-corporate__form-title { font-family: var(--font-display); font-weight: 600; font-size: 1.5rem; margin: 0 0 6px; }
.ecraft-corporate__form-sub { color: var(--clr-mute); font-size: .92rem; margin-bottom: 22px; }
.ecraft-corporate__status { margin-top: 14px; font-size: .9rem; }
.ecraft-corporate__status.is-success { color: var(--clr-success); }
.ecraft-corporate__status.is-error   { color: var(--clr-danger); }
.ecraft-corporate__or { text-align: center; margin-top: 18px; font-size: .9rem; color: var(--clr-mute); }
.ecraft-corporate__or a { color: var(--clr-ink); font-weight: 600; }
@media (max-width: 900px) { .ecraft-corporate__layout { grid-template-columns: 1fr; } .ecraft-corporate__form { position: static; } }

/* ===== Empty states / post grid ===== */
.ecraft-empty-state { text-align: center; padding: 100px 0; }
.ecraft-post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 32px; padding: 40px 0 80px; }
.ecraft-page-header { padding: 60px 0 20px; text-align: center; }
.ecraft-card__meta { font-size: .82rem; color: var(--clr-mute); margin-bottom: 10px; }

/* ===== 404 ===== */
.ecraft-404 { padding: 120px 0; text-align: center; }
.ecraft-404__code { font-family: var(--font-display); font-size: clamp(6rem, 14vw, 12rem); font-weight: 600; color: var(--clr-gold); line-height: 1; }
.ecraft-404__title { font-size: clamp(1.6rem, 3vw, 2.4rem); margin: 12px 0; }
.ecraft-404__sub { color: var(--clr-mute); max-width: 460px; margin: 0 auto 30px; }

/* ===== Accordion ===== */
.ecraft-product-faq { padding: 60px 0; border-top: 1px solid var(--clr-line); }
.ecraft-accordion__item { border-bottom: 1px solid var(--clr-line); }
.ecraft-accordion__q { cursor: pointer; padding: 22px 0; font-weight: 600; font-size: 1.05rem; display: flex; justify-content: space-between; align-items: center; list-style: none; }
.ecraft-accordion__q::-webkit-details-marker { display: none; }
.ecraft-accordion__icon { color: var(--clr-gold); font-size: 1.4rem; line-height: 1; transition: transform var(--dur) var(--ease); }
.ecraft-accordion__item[open] .ecraft-accordion__icon { transform: rotate(45deg); }
.ecraft-accordion__a { padding-bottom: 22px; color: var(--clr-mute); }
