/* ==========================================================================
   SIGN MAX — COMPONENTS
   Buttons, badges, cards, ratings, forms, sliders, pills.
   ========================================================================== */

/* ---- Buttons ---- */
.smx-btn {
  --_bg: var(--smx-primary); --_fg: #fff; --_bd: transparent;
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6em;
  font-family: var(--smx-font-body); font-weight: 600; font-size: var(--smx-fs-base);
  line-height: 1; text-align: center; white-space: nowrap;
  padding: 0.95em 1.7em; border-radius: var(--smx-radius-pill);
  background: var(--_bg); color: var(--_fg); border: 1.5px solid var(--_bd);
  transition: transform var(--smx-dur-fast) var(--smx-ease), box-shadow var(--smx-dur) var(--smx-ease), background var(--smx-dur-fast) var(--smx-ease);
  will-change: transform;
}
.smx-btn:hover { color: var(--_fg); transform: translateY(-2px); box-shadow: var(--smx-shadow-primary); }
.smx-btn:active { transform: translateY(0); }
.smx-btn svg { width: 1.1em; height: 1.1em; }

.smx-btn--primary { --_bg: var(--smx-primary); --_fg: #fff; }
.smx-btn--primary:hover { --_bg: var(--smx-primary-600); }
.smx-btn--secondary { --_bg: var(--smx-secondary); --_fg: #1A1A1A; }
.smx-btn--secondary:hover { --_bg: var(--smx-secondary-600); box-shadow: 0 12px 28px rgba(248,156,28,0.3); }
.smx-btn--accent { --_bg: var(--smx-accent); --_fg: #fff; }
.smx-btn--accent:hover { --_bg: var(--smx-accent-600); box-shadow: 0 12px 28px rgba(0,90,169,0.28); }
.smx-btn--dark { --_bg: var(--smx-ink); --_fg: #fff; }
.smx-btn--ghost { --_bg: transparent; --_fg: var(--smx-ink); --_bd: var(--smx-border-strong); }
.smx-btn--ghost:hover { --_bg: var(--smx-ink); --_fg: #fff; box-shadow: var(--smx-shadow); }
.smx-btn--outline-light { --_bg: transparent; --_fg: #fff; --_bd: rgba(255,255,255,0.5); }
.smx-btn--outline-light:hover { --_bg: #fff; --_fg: var(--smx-ink); }
.smx-btn--sm { padding: 0.65em 1.2em; font-size: var(--smx-fs-sm); }
.smx-btn--lg { padding: 1.1em 2.1em; font-size: var(--smx-fs-md); }
.smx-btn--block { width: 100%; }

/* Async loading state (JS toggles .is-loading + aria-busy on AJAX buttons):
   dims the label, shows an inline spinner, and blocks double-submits. */
.smx-btn.is-loading { position: relative; pointer-events: none; color: transparent !important; }
.smx-btn.is-loading > * { opacity: 0; }
.smx-btn.is-loading::after {
  content: ""; position: absolute; left: 50%; top: 50%; width: 18px; height: 18px;
  margin: -9px 0 0 -9px; border: 2.5px solid rgba(255,255,255,0.35); border-top-color: #fff;
  border-radius: 50%; animation: smx-btn-spin 0.7s linear infinite;
}
.smx-btn--ghost.is-loading::after { border-color: rgba(0,0,0,0.15); border-top-color: var(--smx-ink); }
@keyframes smx-btn-spin { to { transform: rotate(360deg); } }

/* ---- Badges ---- */
.smx-badge {
  display: inline-flex; align-items: center; gap: 0.4em;
  font-size: var(--smx-fs-xs); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 0.35em 0.7em; border-radius: var(--smx-radius-sm); line-height: 1;
}
.smx-badge--sale { background: var(--smx-primary); color: #fff; }
.smx-badge--new { background: var(--smx-accent); color: #fff; }
.smx-badge--hot { background: var(--smx-secondary); color: #1A1A1A; }
.smx-badge--out { background: #efefef; color: var(--smx-text); }

/* ---- Star ratings ---- */
.smx-stars { display: inline-flex; gap: 2px; color: var(--smx-star); line-height: 1; }
.smx-stars svg { width: 1em; height: 1em; }
.smx-stars .is-empty { color: var(--smx-border-strong); }

/* ---- Cards (generic) ---- */
.smx-card {
  background: var(--smx-bg); border: 1px solid var(--smx-border);
  border-radius: var(--smx-radius-lg); overflow: hidden;
  transition: transform var(--smx-dur) var(--smx-ease), box-shadow var(--smx-dur) var(--smx-ease), border-color var(--smx-dur) var(--smx-ease);
}
.smx-card:hover { transform: translateY(-6px); box-shadow: var(--smx-shadow-lg); border-color: transparent; }

/* ---- Feature / icon card ---- */
.smx-feature-card {
  background: var(--smx-bg); border: 1px solid var(--smx-border);
  border-radius: var(--smx-radius-lg); padding: var(--smx-space-6);
  transition: transform var(--smx-dur) var(--smx-ease), box-shadow var(--smx-dur) var(--smx-ease);
  position: relative; overflow: hidden;
}
.smx-feature-card::after {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 4px;
  background: linear-gradient(90deg, var(--smx-primary), var(--smx-secondary));
  transform: scaleX(0); transform-origin: left; transition: transform var(--smx-dur) var(--smx-ease);
}
.smx-feature-card:hover { transform: translateY(-6px); box-shadow: var(--smx-shadow-lg); }
.smx-feature-card:hover::after { transform: scaleX(1); }
.smx-feature-card__icon {
  width: 60px; height: 60px; border-radius: var(--smx-radius); display: grid; place-items: center;
  background: var(--smx-primary-050); color: var(--smx-primary); margin-bottom: var(--smx-space-4);
}
.smx-feature-card__icon svg { width: 28px; height: 28px; }
.smx-feature-card h3 { font-size: var(--smx-fs-md); margin-bottom: var(--smx-space-2); }

/* ---- Stat pill ---- */
.smx-stat { text-align: center; }
.smx-stat__num { font-family: var(--smx-font-head); font-size: var(--smx-fs-2xl); font-weight: 700; color: var(--smx-ink); line-height: 1; }
.smx-stat__label { font-size: var(--smx-fs-sm); color: var(--smx-text); margin-top: 0.35em; }

/* ---- Trust logos ---- */
.smx-logos { display: flex; flex-wrap: wrap; align-items: center; gap: var(--smx-space-6); }
.smx-logos img { height: 34px; width: auto; filter: grayscale(1); opacity: 0.55; transition: opacity var(--smx-dur), filter var(--smx-dur); }
.smx-logos img:hover { filter: grayscale(0); opacity: 1; }

/* ---- Sliders (scroll-snap, no heavy JS dependency) ---- */
.smx-slider { position: relative; }
.smx-slider__track {
  display: grid; grid-auto-flow: column; grid-auto-columns: minmax(292px, 1fr);
  gap: var(--smx-space-5); overflow-x: auto; scroll-snap-type: x mandatory;
  padding-bottom: var(--smx-space-3); scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
.smx-slider__track::-webkit-scrollbar { display: none; }
.smx-slider__track > * { scroll-snap-align: start; }
.smx-slider__nav { display: flex; gap: var(--smx-space-2); }
.smx-slider__btn {
  width: 48px; height: 48px; border-radius: var(--smx-radius-pill);
  border: 1.5px solid var(--smx-border-strong); color: var(--smx-ink);
  display: grid; place-items: center; transition: all var(--smx-dur-fast) var(--smx-ease);
}
.smx-slider__btn:hover { background: var(--smx-ink); color: #fff; border-color: var(--smx-ink); }
.smx-slider__btn[disabled] { opacity: 0.35; cursor: not-allowed; }

/* ---- Forms ---- */
.smx-field { display: flex; flex-direction: column; gap: 0.4rem; }
.smx-field label { font-size: var(--smx-fs-sm); font-weight: 600; color: var(--smx-ink); }
.smx-input, .smx-select, .smx-textarea {
  width: 100%; padding: 0.85em 1.1em; border: 1.5px solid var(--smx-border);
  border-radius: var(--smx-radius-sm); background: var(--smx-bg); color: var(--smx-ink);
  transition: border-color var(--smx-dur-fast), box-shadow var(--smx-dur-fast);
}
.smx-select, select { cursor: pointer; }
.smx-input:focus, .smx-select:focus, .smx-textarea:focus {
  outline: none; border-color: var(--smx-accent); box-shadow: 0 0 0 4px rgba(0,90,169,0.12);
}
.smx-input::placeholder { color: #b4b4b4; }

/* ---- Newsletter inline ---- */
.smx-newsletter { display: flex; gap: var(--smx-space-2); max-width: 460px; }
.smx-newsletter .smx-input { border-radius: var(--smx-radius-pill); }

/* ---- Quantity stepper ---- */
.smx-qty { display: inline-flex; align-items: center; border: 1.5px solid var(--smx-border); border-radius: var(--smx-radius-pill); overflow: hidden; }
.smx-qty button { width: 44px; height: 46px; font-size: 1.2rem; color: var(--smx-ink); } /* 44px = min touch target */
.smx-qty input { width: 48px; text-align: center; border: none; background: transparent; }

/* ---- Breadcrumbs ---- */
.smx-breadcrumbs { font-size: var(--smx-fs-sm); color: var(--smx-text); display: flex; flex-wrap: wrap; gap: 0.4em; align-items: center; }
.smx-breadcrumbs a { color: var(--smx-text); }
.smx-breadcrumbs a:hover { color: var(--smx-primary); }
.smx-breadcrumbs .sep { color: var(--smx-border-strong); }

/* ---- FAQ accordion ---- */
.smx-faqs { max-width: 820px; }
.smx-faqs__title { margin-bottom: var(--smx-space-5); }
.smx-faq { border: 1px solid var(--smx-border); border-radius: var(--smx-radius); margin-bottom: var(--smx-space-3); overflow: hidden; background: #fff; }
.smx-faq summary { display: flex; align-items: center; justify-content: space-between; gap: var(--smx-space-3); padding: var(--smx-space-4) var(--smx-space-5); font-family: var(--smx-font-head); font-weight: 600; color: var(--smx-ink); cursor: pointer; list-style: none; }
.smx-faq summary::-webkit-details-marker { display: none; }
.smx-faq__chev { transition: transform var(--smx-dur) var(--smx-ease); color: var(--smx-primary); flex-shrink: 0; }
.smx-faq[open] .smx-faq__chev { transform: rotate(90deg); }
.smx-faq__body { padding: 0 var(--smx-space-5) var(--smx-space-5); }

/* ---- Pagination ---- */
.smx-pagination .nav-links, .woocommerce-pagination ul { display: flex; gap: 0.4rem; justify-content: center; list-style: none; padding: 0; margin-top: var(--smx-space-7); flex-wrap: wrap; }
.smx-pagination a, .smx-pagination span, .woocommerce-pagination a, .woocommerce-pagination span {
  display: grid; place-items: center; min-width: 46px; height: 46px; padding: 0 0.6rem; border-radius: var(--smx-radius-sm);
  border: 1.5px solid var(--smx-border); color: var(--smx-ink); font-weight: 600;
}
.smx-pagination .current, .woocommerce-pagination .current { background: var(--smx-primary); color: #fff; border-color: var(--smx-primary); }
.smx-pagination a:hover, .woocommerce-pagination a:hover { border-color: var(--smx-primary); color: var(--smx-primary); }

/* ---- Quote / contact forms ---- */
.smx-quote-layout { display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--smx-space-5); align-items: start; }
.smx-quote-card { padding: clamp(1.5rem, 3vw, 2.5rem); }
.smx-quote-card h2 { font-size: var(--smx-fs-xl); }
.smx-quote-card__lead { margin: 0.4rem 0 var(--smx-space-5); font-size: var(--smx-fs-sm); }
.smx-quote-form { display: flex; flex-direction: column; gap: var(--smx-space-4); }
.smx-quote-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--smx-space-4); }
.smx-quote-form .required { color: var(--smx-primary); }
.smx-quote-form__note { font-size: var(--smx-fs-xs); color: var(--smx-text-soft); text-align: center; }
.smx-hp { position: absolute !important; left: -9999px !important; height: 1px; overflow: hidden; }
.smx-quote-aside { display: flex; flex-direction: column; gap: var(--smx-space-4); position: sticky; top: calc(var(--smx-header-h) + 16px); }
.smx-quote-aside__card { padding: var(--smx-space-5); }
.smx-quote-aside__card h3 { font-size: var(--smx-fs-md); margin-bottom: var(--smx-space-3); }
.smx-quote-steps { counter-reset: smx-step; display: flex; flex-direction: column; gap: var(--smx-space-4); }
.smx-quote-steps li { counter-increment: smx-step; position: relative; padding-left: 3rem; list-style: none; }
.smx-quote-steps li::before {
  content: counter(smx-step); position: absolute; left: 0; top: 0;
  width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center;
  background: var(--smx-primary-050); color: var(--smx-primary); font-weight: 700; font-size: var(--smx-fs-sm);
}
.smx-quote-steps strong { display: block; color: var(--smx-ink); }
.smx-quote-steps span { font-size: var(--smx-fs-sm); }
.smx-quote-contact li { display: flex; gap: 0.6rem; margin-bottom: 0.8rem; }
.smx-quote-contact svg { color: var(--smx-accent); flex-shrink: 0; margin-top: 3px; }
.smx-form-success {
  display: flex; gap: var(--smx-space-3); align-items: flex-start;
  background: #e4f6ec; border: 1px solid #bfe8d2; border-radius: var(--smx-radius);
  padding: var(--smx-space-4) var(--smx-space-5); margin-bottom: var(--smx-space-5);
}
.smx-form-success__icon { width: 44px; height: 44px; border-radius: 50%; background: #1f7a48; color: #fff; display: grid; place-items: center; flex-shrink: 0; }
.smx-form-success strong { color: var(--smx-ink); }
.smx-form-success p { margin-top: 0.2rem; font-size: var(--smx-fs-sm); }

/* Contact page info cards */
.smx-contact-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: var(--smx-space-4); } /* auto-fit: no hole when a card is unset */
.smx-contact-card { padding: var(--smx-space-5); text-align: center; }
.smx-contact-card__icon { width: 52px; height: 52px; border-radius: var(--smx-radius); background: var(--smx-primary-050); color: var(--smx-primary); display: grid; place-items: center; margin: 0 auto var(--smx-space-3); }
.smx-contact-card h3 { font-size: var(--smx-fs-md); margin-bottom: 0.4rem; }
.smx-contact-card a { font-weight: 600; }
@media (max-width: 992px) {
  .smx-quote-layout { grid-template-columns: 1fr; }
  .smx-quote-aside { position: static; }
  .smx-contact-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .smx-quote-form__row { grid-template-columns: 1fr; }
  .smx-contact-cards { grid-template-columns: 1fr; }
}

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */
.smx-abhero { position: relative; overflow: hidden; background: var(--smx-ink); color: #fff; isolation: isolate; }
.smx-abhero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.35; z-index: -1; }
.smx-abhero::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(105deg, rgba(26,26,26,0.9), rgba(26,26,26,0.35)); }
.smx-abhero--plain { background: linear-gradient(150deg, #232323 0%, var(--smx-ink) 55%, #003a6e 130%); }
.smx-abhero__inner { padding-block: clamp(3.5rem, 8vw, 6.5rem); max-width: 720px; }
.smx-abhero h1 { color: #fff; font-size: var(--smx-fs-3xl); margin: var(--smx-space-3) 0; }
.smx-abhero p { color: rgba(255,255,255,0.85); font-size: var(--smx-fs-md); }
.smx-abhero .smx-breadcrumbs, .smx-abhero .smx-breadcrumbs a { color: rgba(255,255,255,0.7); }
.smx-abhero .smx-breadcrumbs a:hover { color: #fff; }
.smx-abhero .smx-eyebrow { color: var(--smx-secondary); }

/* statistics band */
.smx-abstats { background: var(--smx-ink); }
.smx-abstats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--smx-space-5); }
.smx-abstat { text-align: center; padding: var(--smx-space-4) 0; }
.smx-abstat__num { font-family: var(--smx-font-head); font-weight: 700; font-size: var(--smx-fs-2xl); line-height: 1; background: linear-gradient(100deg, var(--smx-primary), var(--smx-secondary)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.smx-abstat__label { color: rgba(255,255,255,0.7); margin-top: 0.5rem; font-size: var(--smx-fs-sm); }

/* mission & vision */
.smx-mv { display: grid; grid-template-columns: 1fr 1fr; gap: var(--smx-space-5); }
.smx-mv__card { padding: clamp(1.75rem, 3vw, 2.75rem); position: relative; overflow: hidden; }
.smx-mv__card::after { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: linear-gradient(90deg, var(--smx-primary), var(--smx-secondary)); }
.smx-mv__card--alt::after { background: linear-gradient(90deg, var(--smx-accent), var(--smx-secondary)); }
.smx-mv__icon { width: 54px; height: 54px; border-radius: var(--smx-radius); display: grid; place-items: center; background: var(--smx-primary-050); color: var(--smx-primary); margin-bottom: var(--smx-space-4); }
.smx-mv__card--alt .smx-mv__icon { background: #e6f0fb; color: var(--smx-accent); }
.smx-mv__card h3 { margin-bottom: var(--smx-space-3); }

/* process timeline */
.smx-process { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--smx-space-4); position: relative; padding: 0; }
.smx-process::before { content: ""; position: absolute; top: 27px; left: 8%; right: 8%; height: 2px; background: var(--smx-border-strong); z-index: 0; }
.smx-process__step { position: relative; text-align: center; padding: 0 var(--smx-space-2); list-style: none; z-index: 1; }
.smx-process__num {
  width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center; margin: 0 auto var(--smx-space-3);
  background: #fff; border: 2px solid var(--smx-primary); color: var(--smx-primary);
  font-family: var(--smx-font-head); font-weight: 700; font-size: var(--smx-fs-md);
  transition: all var(--smx-dur) var(--smx-ease);
}
.smx-process__step:hover .smx-process__num { background: var(--smx-primary); color: #fff; transform: scale(1.08); }
.smx-process__step h3 { font-size: var(--smx-fs-md); margin-bottom: 0.4rem; }
.smx-process__step p { font-size: var(--smx-fs-sm); }

/* team */
.smx-team { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--smx-space-5); }
.smx-team-card { text-align: center; }
.smx-team-card__photo { aspect-ratio: 1/1; border-radius: var(--smx-radius-lg); overflow: hidden; background: var(--smx-bg-soft); border: 1px solid var(--smx-border); margin-bottom: var(--smx-space-3); }
.smx-team-card__photo img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--smx-dur-slow) var(--smx-ease); }
.smx-team-card:hover .smx-team-card__photo img { transform: scale(1.05); }
.smx-team-card h3 { font-size: var(--smx-fs-md); }
.smx-team-card__role { display: block; color: var(--smx-primary); font-size: var(--smx-fs-sm); font-weight: 600; margin: 0.2rem 0 0.5rem; }
.smx-team-card p { font-size: var(--smx-fs-sm); }

/* contact page: map + trust list + centered faqs */
.smx-map { border-radius: var(--smx-radius-lg); overflow: hidden; border: 1px solid var(--smx-border); box-shadow: var(--smx-shadow-sm); }
.smx-map iframe { display: block; width: 100%; height: 420px; border: 0; }
.smx-contact-trust { display: flex; flex-direction: column; gap: 0.8rem; }
.smx-contact-trust li { display: flex; align-items: center; gap: 0.6rem; font-weight: 500; color: var(--smx-ink); }
.smx-contact-trust svg { color: var(--smx-primary); flex-shrink: 0; }
.smx-faqs-center .smx-faqs { margin-inline: auto; }

@media (max-width: 992px) {
  .smx-abstats__grid { grid-template-columns: repeat(2, 1fr); }
  .smx-mv { grid-template-columns: 1fr; }
  .smx-process { grid-template-columns: repeat(2, 1fr); row-gap: var(--smx-space-6); }
  .smx-process::before { display: none; }
  .smx-team { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .smx-process { grid-template-columns: 1fr; }
  .smx-team { grid-template-columns: 1fr; }
  .smx-map iframe { height: 300px; }
}

/* ---- Toast / mini-notice ---- */
.smx-toast-wrap { position: fixed; right: 1.25rem; bottom: 1.25rem; z-index: var(--smx-z-modal); display: flex; flex-direction: column; gap: 0.5rem; }
.smx-toast {
  background: var(--smx-ink); color: #fff; padding: 0.9rem 1.2rem; border-radius: var(--smx-radius);
  box-shadow: var(--smx-shadow-lg); display: flex; align-items: center; gap: 0.6rem; font-size: var(--smx-fs-sm);
  transform: translateY(12px); opacity: 0; transition: all var(--smx-dur) var(--smx-ease);
}
.smx-toast.is-shown { transform: none; opacity: 1; }
.smx-toast--success { border-left: 4px solid var(--smx-success); }
