/* ==========================================================================
   AbstractRealmss — Google Stitch design layer (layout + color fixes)
   ========================================================================== */

:root {
  --arss-font-display: 'Libre Caslon Text', Georgia, serif;
  --arss-max: 1440px;
  --arss-gutter: clamp(20px, 5vw, 80px);
  --arss-header-bar-h: 64px;
  --arss-header-top: 0;
  --arss-header-h: calc(var(--arss-header-bar-h) + 1px);
  --arss-radius: 0;
  --arss-radius-sm: 0;
}

/* --- Global overflow safety --- */
body.arss-branded {
  background: var(--arss-surface) !important;
  color: var(--arss-on-surface-variant) !important;
  overflow-x: clip;
}

body.arss-branded .arss-main {
  padding-top: 0;
}

.arss-wrap,
.arss-hero__layout,
.arss-section__head,
.arss-hero__copy,
.arss-cta__copy {
  min-width: 0;
}

.arss-hero__title,
.arss-h2,
.arss-cta__title,
.arss-quote p {
  overflow-wrap: break-word;
  word-wrap: break-word;
  hyphens: auto;
}

/* --- Film grain (disabled) --- */
.arss-noise-overlay {
  display: none !important;
}

/* --- Header --- */
.arss-header {
  position: sticky;
  top: 0;
  padding: 0;
  transform: none !important;
  pointer-events: auto !important;
}

.arss-header.is-hidden {
  transform: none;
  pointer-events: auto;
}

.arss-header__bar {
  width: 100%;
  max-width: none;
  min-height: var(--arss-header-bar-h);
  height: auto;
  padding: 0;
  border-radius: 0;
  background: var(--arss-header-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: none;
  border-bottom: 1px solid var(--arss-border);
  box-shadow: none;
  box-sizing: border-box;
}

.arss-header.is-scrolled .arss-header__bar,
body.arss-home .arss-header.is-at-top .arss-header__bar,
body:not(.arss-home) .arss-header.is-scrolled .arss-header__bar {
  background: var(--arss-header-bg);
  border-color: var(--arss-border);
  box-shadow: none;
}

.arss-header__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: min(var(--arss-max), 100%);
  margin-inline: auto;
  padding: 10px var(--arss-gutter);
  min-height: var(--arss-header-bar-h);
  box-sizing: border-box;
}

.arss-header__nav {
  flex: 1 1 0;
  min-width: 0;
  max-width: calc(50% - 120px);
}

.arss-header__brand {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  pointer-events: none;
  max-width: min(240px, 36vw);
}

.arss-header__brand .arss-brand {
  pointer-events: auto;
  justify-content: center;
  max-width: 100%;
}

.arss-brand {
  gap: 0;
}

.arss-brand__mark {
  display: none;
}

.arss-brand__name,
.arss-header .arss-brand__name {
  display: block;
  font: 400 clamp(17px, 2vw, 28px)/1.2 var(--arss-font-display);
  color: var(--arss-primary) !important;
  letter-spacing: -0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.arss-nav__list {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: clamp(10px, 1.4vw, 20px);
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.arss-nav__list::-webkit-scrollbar {
  display: none;
}

.arss-nav__list a {
  padding: 4px 0;
  border-radius: 0;
  font: 600 11px/1.2 var(--arss-font-body);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--arss-on-surface-variant);
  white-space: nowrap;
  flex-shrink: 0;
  transition: color 0.35s ease;
}

.arss-nav__list a:hover,
.arss-nav__list a.is-active {
  background: none;
  color: var(--arss-primary);
}

.arss-nav__realms-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 0;
  border-radius: 0;
  font: 600 11px/1.2 var(--arss-font-body);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--arss-on-surface-variant);
  background: none;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}

.arss-nav__realms-btn:hover,
.arss-nav__realms-btn[aria-expanded="true"] {
  color: var(--arss-primary);
  background: none;
}

body.arss-home .arss-header.is-at-top .arss-nav__list a:hover,
body.arss-home .arss-header.is-at-top .arss-nav__list a.is-active,
body.arss-home .arss-header.is-at-top .arss-nav__realms-btn:hover,
body:not(.arss-home) .arss-header.is-scrolled .arss-nav__list a:hover,
body:not(.arss-home) .arss-header.is-scrolled .arss-nav__list a.is-active {
  color: var(--arss-header-fg-hover);
}

.arss-menu-btn {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  gap: 5px;
  width: 34px;
  height: 34px;
  padding: 7px;
  margin: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--arss-header-fg);
  flex-shrink: 0;
}

.arss-menu-btn span {
  display: block;
  width: 100%;
  height: 2px;
  background: currentColor;
  border-radius: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.arss-menu-btn.is-open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.arss-menu-btn.is-open span:nth-child(2) {
  opacity: 0;
}

.arss-menu-btn.is-open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.arss-realms-menu {
  border-radius: 0;
  background: var(--arss-overlay-bg);
  border: 1px solid var(--arss-border-strong);
  backdrop-filter: blur(20px);
  max-width: min(320px, calc(100vw - 40px));
}

.arss-realms-menu__kicker {
  color: var(--arss-outline);
}

.arss-realms-menu__kicker--secondary {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--arss-border);
}

.arss-realms-menu__list a {
  border-radius: 0;
}

.arss-realms-menu__list strong {
  color: var(--arss-primary);
  font-family: var(--arss-font-display);
}

.arss-realms-menu__list span {
  color: var(--arss-on-surface-variant);
}

.arss-realms-menu__list--compact a {
  padding: 8px 12px;
  font-size: 13px;
  color: var(--arss-on-surface-variant);
}

.arss-realms-menu__list--compact a:hover {
  background: var(--arss-accent-surface);
  color: var(--arss-primary);
}

.arss-header__actions {
  flex: 0 0 auto;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(6px, 1vw, 10px);
}

/* --- Header search pill --- */
.arss-header-search {
  display: flex;
  align-items: center;
  gap: 10px;
  width: min(320px, 28vw);
  min-width: 200px;
  height: 38px;
  margin: 0;
  padding: 0 16px 0 14px;
  border-radius: 999px;
  border: 1px solid var(--arss-border-strong);
  background: var(--arss-surface-container-low);
  box-sizing: border-box;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.arss-header-search:focus-within {
  border-color: var(--arss-primary);
  background: var(--arss-surface-container);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--arss-primary) 18%, transparent);
}

.arss-header-search__icon {
  flex-shrink: 0;
  color: var(--arss-outline);
}

.arss-header-search:focus-within .arss-header-search__icon {
  color: var(--arss-primary);
}

.arss-header-search__input {
  flex: 1;
  min-width: 0;
  width: 100%;
  height: 100%;
  border: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  color: var(--arss-header-fg);
  font: 400 13px/1.3 var(--arss-font-body);
  letter-spacing: 0.01em;
}

.arss-header-search__input::placeholder {
  color: var(--arss-outline);
  opacity: 1;
}

.arss-header-search__input:focus {
  outline: none;
}

.arss-header-search__input::-webkit-search-cancel-button {
  -webkit-appearance: none;
}

.arss-nav__item--mobile-only {
  display: none;
}

.arss-header-search--mobile {
  width: 100%;
  min-width: 0;
  max-width: none;
}

.arss-nav__item--search {
  width: 100%;
  margin-bottom: 8px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--arss-border);
}

.arss-tool {
  border-radius: 0;
  color: var(--arss-primary);
}

.arss-tool:hover {
  background: var(--arss-hover-surface);
  color: var(--arss-primary);
}

.arss-tool--cart {
  overflow: visible;
}

.arss-tool__badge {
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(40%, -40%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  border: 2px solid var(--arss-header-bg);
  box-sizing: border-box;
  background: var(--arss-primary);
  color: var(--arss-primary-container);
  font: 700 10px/1 var(--arss-font-body);
  letter-spacing: 0;
  text-transform: none;
  text-align: center;
  pointer-events: none;
  z-index: 1;
}

.arss-header__cta {
  display: none !important;
}

/* --- Buttons (outlined system) --- */
.arss-btn,
.arss-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 0;
  font: 600 12px/1.3 var(--arss-font-body);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 14px 24px;
  transform: none;
  white-space: normal;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
  border: 1px solid var(--arss-btn-outline-border);
  background: transparent;
  color: var(--arss-btn-outline-fg);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.arss-btn:hover,
.arss-btn-outline:hover {
  transform: none;
  text-decoration: none;
  background: var(--arss-btn-outline-hover-bg);
  color: var(--arss-btn-outline-fg);
  border-color: var(--arss-btn-outline-border);
}

.arss-btn--lg {
  padding: 16px 32px;
  font-size: 12px;
}

.arss-btn--fill,
.arss-btn--line,
.arss-btn--ghost {
  background: transparent;
  color: var(--arss-btn-outline-fg);
  border: 1px solid var(--arss-btn-outline-border);
  box-shadow: none;
}

.arss-btn--fill:hover,
.arss-btn--line:hover,
.arss-btn--ghost:hover {
  background: var(--arss-btn-outline-hover-bg);
  color: var(--arss-btn-outline-fg);
  border-color: var(--arss-btn-outline-border);
}

.arss-btn--light {
  background: var(--arss-btn-emphasis-bg);
  color: var(--arss-btn-emphasis-fg);
  border: 1px solid var(--arss-btn-emphasis-border);
  box-shadow: none;
}

.arss-btn--light:hover {
  background: var(--arss-btn-emphasis-fg);
  color: var(--arss-btn-emphasis-bg);
  border-color: var(--arss-btn-emphasis-border);
}

.arss-section--midnight .arss-btn--fill,
.arss-section--midnight .arss-btn--line,
.arss-section--midnight .arss-btn--ghost,
.arss-video.arss-section--midnight .arss-btn--fill,
.arss-video.arss-section--midnight .arss-btn--line,
.arss-video.arss-section--midnight .arss-btn--ghost,
.arss-cta .arss-btn--fill,
.arss-cta .arss-btn--line,
.arss-cta .arss-btn--ghost {
  color: var(--arss-band-btn-fg);
  border-color: var(--arss-band-btn-border);
}

.arss-section--midnight .arss-btn--fill:hover,
.arss-section--midnight .arss-btn--line:hover,
.arss-section--midnight .arss-btn--ghost:hover,
.arss-video.arss-section--midnight .arss-btn--fill:hover,
.arss-video.arss-section--midnight .arss-btn--line:hover,
.arss-video.arss-section--midnight .arss-btn--ghost:hover,
.arss-cta .arss-btn--fill:hover,
.arss-cta .arss-btn--line:hover,
.arss-cta .arss-btn--ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--arss-band-btn-fg);
  border-color: var(--arss-band-btn-fg);
}

.arss-customize-btn,
.arss-btn-primary,
body.arss-branded .woocommerce a.button,
body.arss-branded .woocommerce button.button,
body.arss-branded .woocommerce input.button,
body.arss-branded .woocommerce #respond input#submit,
body.arss-branded .woocommerce #place_order,
body.arss-branded .woocommerce .wc-proceed-to-checkout a,
body.arss-branded .woocommerce .wc-proceed-to-checkout a.checkout-button,
body.arss-branded .wc-block-cart__submit-container a,
body.arss-branded .wc-block-cart__submit-button,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block a,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block .wp-block-button__link,
body.arss-branded .wc-block-components-button:not(.is-link),
body.arss-branded .wc-block-cart .wc-block-components-button,
body.arss-branded .wc-block-checkout .wc-block-components-button,
body.arss-branded .wc-block-components-checkout-place-order-button,
body.arss-branded .cart .button,
body.arss-branded .woocommerce .cart input.button,
body.arss-branded .woocommerce-MyAccount-content a.button,
body.arss-branded .woocommerce-MyAccount-content button.button,
body.arss-branded .woocommerce-message a.button,
body.arss-branded .woocommerce-info a.button,
body.arss-branded .woocommerce-error a.button,
body.arss-branded .woocommerce-form-login button.button,
body.arss-branded .woocommerce-form-register button.button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--arss-btn-outline-fg) !important;
  border: 1px solid var(--arss-btn-outline-border) !important;
  box-shadow: none !important;
  font: 600 12px/1.3 var(--arss-font-body) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  white-space: normal !important;
  text-decoration: none !important;
  padding: 14px 24px !important;
  min-height: 48px;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
}

.arss-customize-btn:hover,
.arss-btn-primary:hover,
body.arss-branded .woocommerce a.button:hover,
body.arss-branded .woocommerce button.button:hover,
body.arss-branded .woocommerce input.button:hover,
body.arss-branded .woocommerce #respond input#submit:hover,
body.arss-branded .woocommerce #place_order:hover,
body.arss-branded .woocommerce .wc-proceed-to-checkout a:hover,
body.arss-branded .woocommerce .wc-proceed-to-checkout a.checkout-button:hover,
body.arss-branded .wc-block-cart__submit-container a:hover,
body.arss-branded .wc-block-cart__submit-button:hover,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block a:hover,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block .wp-block-button__link:hover,
body.arss-branded .wc-block-components-button:not(.is-link):hover,
body.arss-branded .wc-block-cart .wc-block-components-button:hover,
body.arss-branded .wc-block-checkout .wc-block-components-button:hover,
body.arss-branded .wc-block-components-checkout-place-order-button:hover,
body.arss-branded .cart .button:hover,
body.arss-branded .woocommerce .cart input.button:hover {
  transform: none !important;
  background: var(--arss-btn-outline-hover-bg) !important;
  color: var(--arss-btn-outline-fg) !important;
  border-color: var(--arss-btn-outline-border) !important;
}

/* --- Typography --- */
.arss-kicker {
  font-size: 12px;
  letter-spacing: 0.1em;
  font-weight: 600;
  color: var(--arss-outline);
}

.arss-kicker--light {
  color: var(--arss-band-fg-muted);
}

.arss-h2 {
  color: var(--arss-primary);
  font-family: var(--arss-font-display);
  font-size: clamp(26px, 4vw, 32px);
  font-weight: 400;
  line-height: 1.3;
}

.arss-h2--light,
.arss-section--midnight .arss-h2 {
  color: var(--arss-band-fg);
  font-weight: 400;
}

.arss-hero__title {
  color: var(--arss-primary);
  font-family: var(--arss-font-display);
  font-size: clamp(36px, 6.5vw, 64px);
  line-height: 1.1;
  max-width: 14ch;
  margin-bottom: 32px;
}

.arss-hero__title em {
  background: none;
  -webkit-text-fill-color: inherit;
  color: var(--arss-primary);
  font-style: italic;
}

.arss-hero__text,
.arss-section__lead,
.arss-section__lead--light {
  color: var(--arss-on-surface-variant);
  font-weight: 300;
  font-size: clamp(16px, 2vw, 18px);
  line-height: 1.6;
  max-width: 42ch;
}

/* --- Hero --- */
.arss-hero {
  position: relative;
  min-height: min(860px, 100vh);
  background: var(--arss-surface);
  overflow: hidden;
}

/* Homepage: header overlays hero — no double gap below navbar */
body.arss-branded.arss-home .arss-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 0;
}

body.arss-branded.arss-home .arss-main {
  padding-top: 0 !important;
}

body.arss-branded.arss-home .arss-hero {
  display: flex;
  align-items: center;
  box-sizing: border-box;
  min-height: 100vh;
  min-height: 100dvh;
  padding-top: var(--arss-header-h);
}

body.arss-branded.arss-home .arss-hero__layout {
  padding-top: clamp(12px, 2vw, 24px);
  padding-bottom: clamp(40px, 6vw, 72px);
}

body.arss-branded:not(.arss-home):not(.arss-woocommerce) .arss-header {
  position: sticky;
  top: 0;
  z-index: 1000;
}

body.arss-branded:not(.arss-home):not(.arss-woocommerce) .arss-main {
  padding-top: 0;
}

/* WooCommerce pages: fixed navbar — offset first content by --arss-header-h */
body.arss-branded.arss-woocommerce:not(.arss-home) .arss-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 0;
}

body.arss-branded.arss-woocommerce:not(.arss-home) .arss-main {
  padding-top: 0 !important;
}

body.arss-branded {
  scroll-padding-top: var(--arss-header-h);
}

.arss-hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.arss-hero__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(72px);
  opacity: 0.45;
  animation: arss-orb-drift 20s ease-in-out infinite;
}

.arss-hero__orb--1 {
  width: min(420px, 55vw);
  height: min(420px, 55vw);
  top: -12%;
  right: 8%;
  background: rgba(46, 90, 168, 0.35);
}

.arss-hero__orb--2 {
  width: min(300px, 40vw);
  height: min(300px, 40vw);
  bottom: -8%;
  left: 4%;
  background: rgba(95, 166, 196, 0.22);
  animation-delay: -8s;
}

.arss-hero__layout {
  position: relative;
  z-index: 1;
  grid-template-columns: 1fr;
  gap: clamp(32px, 5vw, 64px);
  padding: clamp(32px, 5vw, 64px) 0;
}

@media (min-width: 901px) {
  .arss-hero__layout {
    grid-template-columns: 5fr 7fr;
    align-items: center;
  }

  .arss-hero__copy {
    padding-right: clamp(16px, 3vw, 48px);
  }
}

.arss-hero__visual {
  width: 100%;
  min-width: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.arss-hero__stage {
  --arss-parallax-x: 0px;
  --arss-parallax-y: 0px;
  --arss-scroll-shift: 0px;
  position: relative;
  width: min(100%, 520px);
  aspect-ratio: 1;
  margin-inline: auto;
  transform: translate3d(var(--arss-parallax-x), calc(var(--arss-parallax-y) + var(--arss-scroll-shift)), 0);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.arss-hero__ring {
  position: absolute;
  top: 50%;
  left: 50%;
  border: 1px solid var(--arss-border);
  border-radius: 50%;
  pointer-events: none;
  opacity: 0.55;
}

.arss-hero__ring--outer {
  width: 92%;
  height: 92%;
  animation: arss-orbit-spin 48s linear infinite;
}

.arss-hero__ring--inner {
  width: 68%;
  height: 68%;
  border-style: dashed;
  opacity: 0.35;
  animation: arss-orbit-spin-reverse 32s linear infinite;
}

.arss-hero__photo,
.arss-video__frame {
  border-radius: 0;
  max-width: 100%;
  margin-left: 0;
}

.arss-hero__photo--main {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 58%;
  aspect-ratio: 4 / 5;
  transform: translate(-50%, -50%);
  z-index: 2;
  animation: arss-hero-breathe 7s ease-in-out infinite;
}

.arss-hero__photo-inner {
  width: 100%;
  height: 100%;
  min-height: 280px;
  filter: grayscale(15%) contrast(1.12);
  background:
    linear-gradient(145deg, rgba(6, 17, 43, 0.15), rgba(10, 26, 63, 0.72)),
    radial-gradient(circle at 28% 72%, rgba(95, 166, 196, 0.28), transparent 58%),
    linear-gradient(160deg, var(--arss-twilight), var(--arss-midnight));
  transition: transform 1.2s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.arss-hero__photo-label {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  padding: 8px 10px;
  border: 1px solid var(--arss-border);
  background: rgba(10, 26, 63, 0.55);
  backdrop-filter: blur(8px);
  color: var(--arss-ether);
  font: 600 9px/1.3 var(--arss-font-body);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: center;
}

html[data-arss-theme="light"] .arss-hero__photo-label {
  background: rgba(245, 244, 240, 0.82);
  color: var(--arss-midnight);
}

.arss-hero__artifact {
  position: absolute;
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 88px;
  padding: 12px 14px;
  border: 1px solid var(--arss-border-strong);
  background: rgba(10, 26, 63, 0.72);
  backdrop-filter: blur(10px);
  box-shadow: 0 16px 40px rgba(6, 17, 43, 0.18);
}

html[data-arss-theme="light"] .arss-hero__artifact {
  background: rgba(245, 244, 240, 0.88);
  box-shadow: 0 16px 40px rgba(10, 26, 63, 0.08);
}

.arss-hero__artifact-kicker {
  font: 400 11px/1 var(--arss-font-display);
  color: var(--arss-outline);
}

.arss-hero__artifact-name {
  font: 400 18px/1.1 var(--arss-font-display);
  color: var(--arss-primary);
}

.arss-hero__artifact--1 {
  top: 6%;
  right: 2%;
  animation: arss-float-drift-a 9s ease-in-out infinite;
}

.arss-hero__artifact--2 {
  bottom: 14%;
  left: 0;
  animation: arss-float-drift-b 11s ease-in-out infinite;
  animation-delay: -2s;
}

.arss-hero__artifact--3 {
  top: 38%;
  right: -2%;
  animation: arss-float-drift-c 10s ease-in-out infinite;
  animation-delay: -4s;
}

.arss-hero__pulse {
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--arss-primary);
  opacity: 0.35;
  z-index: 1;
  animation: arss-pulse-glow 4s ease-in-out infinite;
}

.arss-hero__pulse--1 {
  top: 22%;
  left: 18%;
  animation-delay: 0s;
}

.arss-hero__pulse--2 {
  bottom: 28%;
  right: 22%;
  animation-delay: -1.4s;
}

.arss-hero__pulse--3 {
  top: 62%;
  left: 42%;
  animation-delay: -2.8s;
}

.arss-hero__visual:hover .arss-hero__photo-inner {
  transform: scale(1.03);
}

@keyframes arss-orbit-spin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes arss-orbit-spin-reverse {
  from { transform: translate(-50%, -50%) rotate(360deg); }
  to { transform: translate(-50%, -50%) rotate(0deg); }
}

@keyframes arss-hero-breathe {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  50% { transform: translate(-50%, -50%) scale(1.018); }
}

@keyframes arss-orb-drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(18px, -24px) scale(1.06); }
}

@keyframes arss-float-drift-a {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(-8px, -16px); }
}

@keyframes arss-float-drift-b {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(10px, -12px); }
}

@keyframes arss-float-drift-c {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(-6px, 14px); }
}

@keyframes arss-pulse-glow {
  0%, 100% { opacity: 0.2; transform: scale(1); }
  50% { opacity: 0.85; transform: scale(1.35); }
}

@media (prefers-reduced-motion: reduce) {
  .arss-hero__orb,
  .arss-hero__artifact,
  .arss-hero__pulse {
    animation: none !important;
  }

  .arss-hero__ring {
    animation: none !important;
    transform: translate(-50%, -50%);
  }

  .arss-hero__photo--main {
    animation: none !important;
    transform: translate(-50%, -50%);
  }

  .arss-hero__stage {
    transition: none !important;
    transform: none !important;
  }
}

@media (max-width: 900px) {
  .arss-hero__stage {
    width: min(100%, 360px);
  }

  .arss-hero__artifact {
    min-width: 76px;
    padding: 10px 12px;
  }

  .arss-hero__artifact-name {
    font-size: 15px;
  }
}

/* --- Sections (unified dark) --- */
.arss-section {
  padding-block: clamp(72px, 10vw, 120px);
}

.arss-section--midnight,
.arss-section--muted,
.arss-trust,
.arss-quote,
.arss-cta,
.arss-section:not(.arss-section--midnight) {
  background: var(--arss-surface);
  color: var(--arss-on-surface-variant);
}

.arss-section--midnight,
.arss-video.arss-section--midnight {
  background: var(--arss-band-bg);
  color: var(--arss-band-fg-muted);
}

.arss-section--midnight .arss-section__lead,
.arss-section--midnight .arss-section__lead--light {
  color: var(--arss-band-fg-muted);
}

.arss-section--muted {
  background: var(--arss-surface-container-low);
}

.arss-trust {
  border-top: 1px solid var(--arss-border);
  border-bottom: 1px solid var(--arss-border);
}

.arss-trust__row {
  gap: clamp(16px, 3vw, 24px);
}

.arss-trust__icon {
  color: var(--arss-primary);
}

.arss-trust__item strong {
  color: var(--arss-primary);
  font-family: var(--arss-font-display);
  font-weight: 400;
  font-size: 15px;
}

.arss-trust__item span {
  color: var(--arss-on-surface-variant);
  font-size: 13px;
}

/* --- Realm cards --- */
.arss-realm-grid {
  gap: clamp(16px, 2vw, 24px);
}

.arss-realm-card {
  display: flex;
  flex-direction: column;
  border-radius: 0;
  background: var(--arss-surface-container);
  border: 1px solid var(--arss-border);
  min-height: 200px;
  padding: clamp(24px, 3vw, 32px);
  text-decoration: none;
}

.arss-realm-card::before {
  display: none;
}

.arss-realm-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(6, 17, 43, 0.08);
  border-color: var(--arss-border-hover);
}

.arss-realm-card--dark {
  aspect-ratio: auto;
  min-height: 220px;
  background: var(--arss-realm-card-bg);
  border-color: var(--arss-realm-card-border);
}

.arss-realm-card__num {
  color: var(--arss-outline);
}

.arss-section--midnight .arss-realm-card__num,
.arss-realm-card--dark .arss-realm-card__num {
  color: var(--arss-realm-card-num);
}

.arss-realm-card__title {
  color: var(--arss-primary);
  font-family: var(--arss-font-display);
  font-size: clamp(20px, 2.5vw, 24px);
  margin: 0 0 10px;
}

.arss-section--midnight .arss-realm-card__title,
.arss-realm-card--dark .arss-realm-card__title {
  color: var(--arss-realm-card-fg);
}

.arss-realm-card__text {
  color: var(--arss-on-surface-variant);
  margin: 0 0 20px;
  flex: 1;
  font-size: 14px;
  line-height: 1.65;
}

.arss-section--midnight .arss-realm-card__text,
.arss-realm-card--dark .arss-realm-card__text {
  color: var(--arss-realm-card-fg-muted);
}

.arss-realm-card__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  margin-top: auto;
  padding: 10px 16px;
  border: 1px solid var(--arss-btn-outline-border);
  background: transparent;
  font: 600 11px/1.3 var(--arss-font-body);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--arss-btn-outline-fg);
  opacity: 1;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.arss-realm-card:hover .arss-realm-card__link {
  opacity: 1;
  background: var(--arss-btn-outline-hover-bg);
  border-color: var(--arss-btn-outline-border);
}

.arss-section--midnight .arss-realm-card__link,
.arss-realm-card--dark .arss-realm-card__link {
  color: var(--arss-realm-card-btn-fg);
  border-color: var(--arss-realm-card-btn-border);
}

.arss-section--midnight .arss-realm-card:hover .arss-realm-card__link,
.arss-realm-card--dark:hover .arss-realm-card__link {
  background: var(--arss-realm-card-btn-hover-bg);
  border-color: var(--arss-realm-card-btn-fg);
  color: var(--arss-realm-card-btn-fg);
}

/* --- Steps --- */
.arss-steps--light .arss-step--light {
  background: var(--arss-surface-container);
  border: 1px solid var(--arss-border);
  border-radius: 0;
  padding: clamp(24px, 3vw, 36px);
}

.arss-steps--light .arss-step__num {
  color: var(--arss-primary);
}

.arss-steps--light .arss-step__title {
  color: var(--arss-primary);
  font-family: var(--arss-font-display);
}

.arss-steps--light .arss-step__text {
  color: var(--arss-on-surface-variant);
}

/* --- Category + product cards --- */
.arss-cat-card,
.arss-step,
.arss-cta__panel {
  border-radius: 0;
}

.arss-cat-card {
  background: var(--arss-surface-container);
  border: 1px solid var(--arss-border);
  text-decoration: none;
}

.arss-cat-card:hover {
  transform: none;
  box-shadow: none;
  border-color: var(--arss-border-hover);
}

.arss-cat-card__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px;
}

.arss-cat-card__title {
  color: var(--arss-primary);
  font-family: var(--arss-font-display);
  margin: 0;
}

.arss-cat-card__cta {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border: 1px solid var(--arss-btn-outline-border);
  background: transparent;
  color: var(--arss-btn-outline-fg);
  font: 600 10px/1.3 var(--arss-font-body);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.arss-cat-card:hover .arss-cat-card__cta {
  background: var(--arss-btn-outline-hover-bg);
  border-color: var(--arss-btn-outline-border);
  color: var(--arss-btn-outline-fg);
}

.woocommerce ul.products li.product {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  height: 100% !important;
  background: var(--arss-surface-container) !important;
  border: 1px solid var(--arss-border) !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}

.woocommerce ul.products li.product:hover {
  transform: none !important;
  box-shadow: none !important;
  border-color: var(--arss-border-hover) !important;
}

.woocommerce ul.products li.product > a.woocommerce-loop-product__link,
.woocommerce ul.products li.product > a:first-child:not(.button):not(.added_to_cart) {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  text-decoration: none !important;
}

.woocommerce ul.products li.product a img {
  width: 100% !important;
  aspect-ratio: 1 !important;
  object-fit: cover !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--arss-primary) !important;
  font-family: var(--arss-font-display) !important;
  font-size: clamp(16px, 1.6vw, 20px) !important;
  line-height: 1.3 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden !important;
  white-space: normal !important;
  padding: 14px 16px 8px !important;
  margin: 0 !important;
  flex: 1 1 auto !important;
}

.woocommerce ul.products li.product .price {
  display: block !important;
  color: var(--arss-on-surface-variant) !important;
  padding: 0 16px 12px !important;
  margin: 0 !important;
  font-size: 14px !important;
  margin-top: auto !important;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product .added_to_cart {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: calc(100% - 24px) !important;
  margin: 0 12px 12px !important;
  padding: 12px 16px !important;
  box-sizing: border-box !important;
  text-align: center !important;
  border-radius: 0 !important;
  border: 1px solid var(--arss-btn-outline-border) !important;
  background: transparent !important;
  color: var(--arss-btn-outline-fg) !important;
  font: 600 11px/1.3 var(--arss-font-body) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  white-space: normal !important;
  flex-shrink: 0 !important;
  text-decoration: none !important;
  min-height: 44px;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease !important;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button:hover,
.woocommerce ul.products li.product .added_to_cart:hover {
  background: var(--arss-btn-outline-hover-bg) !important;
  color: var(--arss-btn-outline-fg) !important;
  border-color: var(--arss-btn-outline-border) !important;
}

.arss-products .woocommerce ul.products,
.arss-shop .woocommerce ul.products {
  align-items: stretch !important;
}

/* --- Quote + CTA --- */
.arss-quote {
  background: var(--arss-surface-container-lowest);
}

.arss-quote p {
  color: var(--arss-primary);
  max-width: 22ch;
  font-style: italic;
}

.arss-quote cite {
  color: var(--arss-outline);
}

.arss-cta__panel {
  background: var(--arss-surface-container);
  border: 1px solid var(--arss-border);
  box-shadow: none;
}

.arss-cta__title {
  color: var(--arss-primary);
}

.arss-cta__text {
  color: var(--arss-on-surface-variant);
}

/* --- Footer --- */
.arss-footer {
  background: var(--arss-surface-container-lowest);
  border-top: 1px solid var(--arss-border-subtle);
  color: var(--arss-on-surface-variant);
}

.arss-footer__brand .arss-brand__name,
.arss-brand--light .arss-brand__name {
  color: var(--arss-primary) !important;
}

.arss-footer__tagline {
  color: var(--arss-tertiary);
  font-style: italic;
}

.arss-footer__desc {
  color: var(--arss-on-surface-variant);
}

.arss-footer__title {
  color: var(--arss-on-surface);
}

.arss-footer__links a {
  color: var(--arss-on-surface-variant);
}

.arss-footer__links a:hover {
  color: var(--arss-primary);
}

.arss-footer__bar {
  border-top-color: var(--arss-border);
  color: var(--arss-outline);
}

/* --- WooCommerce pages --- */
body.arss-woocommerce .arss-shop,
body.arss-woocommerce .woocommerce,
body.arss-woocommerce .woocommerce-breadcrumb {
  color: var(--arss-on-surface-variant);
}

body.arss-woocommerce.single-product .summary,
body.arss-woocommerce.single-product .product_title {
  color: var(--arss-primary);
}

.arss-intent {
  background: var(--arss-surface-container);
  border: 1px solid var(--arss-border-strong);
  border-radius: 0;
}

.arss-intent__label,
.arss-label,
.arss-intent__option-title {
  color: var(--arss-primary);
}

.arss-intent__option {
  border-radius: 0;
  background: var(--arss-surface-container-low);
  border: 1px solid var(--arss-btn-outline-border);
}

.arss-intent__option.is-active {
  border-color: var(--arss-btn-outline-fg);
  background: var(--arss-accent-surface);
}

.arss-field input,
.arss-field textarea {
  border-radius: 0;
  background: var(--arss-surface-container-lowest);
  border-color: var(--arss-border-strong);
  color: var(--arss-on-surface);
}

.arss-breadcrumb__item a {
  color: var(--arss-primary);
}

/* --- Shop archive --- */
.arss-shop-hero {
  --arss-shop-hero-pad: clamp(20px, 3vw, 28px);
  box-sizing: border-box;
  width: 100%;
  background: var(--arss-surface);
  border-bottom: 1px solid var(--arss-border);
  padding-top: calc(var(--arss-header-h) + var(--arss-shop-hero-pad));
  padding-bottom: var(--arss-shop-hero-pad);
}

.arss-shop-hero--archive {
  --arss-shop-hero-pad: clamp(20px, 3vw, 28px);
  padding-top: var(--arss-header-h);
  padding-bottom: 0;
}

.arss-shop-hero--archive .arss-shop-hero__inner {
  padding-block: var(--arss-shop-hero-pad);
}

.arss-shop-hero--shop {
  --arss-shop-hero-pad: clamp(24px, 3.5vw, 36px);
}

.arss-shop-hero__inner {
  width: min(var(--arss-max), calc(100% - var(--arss-gutter) * 2));
  margin-inline: auto;
}

body.arss-branded.arss-woocommerce .arss-main .has-global-padding,
body.arss-branded.arss-woocommerce .arss-main .wp-site-blocks > main {
  padding-top: 0 !important;
  padding-block-start: 0 !important;
}

body.arss-branded.arss-woocommerce .arss-main > .wp-site-blocks {
  width: min(var(--arss-max), calc(100% - var(--arss-gutter) * 2));
  margin-inline: auto;
}

body.arss-branded.arss-woocommerce .wc-block-breadcrumbs,
body.arss-branded.arss-woocommerce .wc-block-product-results-count,
body.arss-branded.arss-woocommerce .wp-block-woocommerce-product-results-count {
  display: none !important;
}

body.arss-branded.arss-woocommerce:not(.single-product) .wc-block-store-notices,
body.arss-branded.arss-woocommerce:not(.single-product) .wc-block-components-notices {
  display: none !important;
}

.arss-shop-hero__title {
  color: var(--arss-primary);
  margin: 0;
  font-family: var(--arss-font-display);
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 400;
  line-height: 1.15;
}

.arss-shop-hero__desc {
  margin: 10px 0 0;
  max-width: 52ch;
  color: var(--arss-on-surface-variant);
  font-size: 16px;
  line-height: 1.6;
}

body.arss-branded.arss-woocommerce .wp-block-woocommerce-product-collection-no-results {
  padding: clamp(32px, 5vw, 48px) 0 clamp(48px, 6vw, 72px);
  min-height: 0;
}

body.arss-branded.arss-woocommerce .wp-block-woocommerce-product-collection-no-results .wp-block-heading {
  font-family: var(--arss-font-display);
  color: var(--arss-primary);
}

body.arss-woocommerce .arss-shop {
  background: var(--arss-surface);
  padding-bottom: clamp(48px, 8vw, 96px);
}

body.arss-woocommerce .woocommerce-result-count,
body.arss-woocommerce .woocommerce-ordering select {
  color: var(--arss-on-surface-variant);
}

body.arss-woocommerce .woocommerce-ordering select {
  background: var(--arss-surface-container);
  border: 1px solid var(--arss-border-strong);
  border-radius: 0;
}

/* --- Single product page (PDP) --- */
.arss-pdp {
  display: contents;
}

body.arss-woocommerce.single-product .arss-main {
  background: var(--arss-surface);
}

body.arss-woocommerce.single-product div.product {
  display: grid !important;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr) !important;
  gap: clamp(32px, 5vw, 64px) !important;
  align-items: start !important;
  padding: calc(var(--arss-header-h) + clamp(16px, 2.5vw, 24px)) 0 clamp(64px, 8vw, 96px) !important;
  width: min(var(--arss-max), calc(100% - var(--arss-gutter) * 2)) !important;
  margin-inline: auto !important;
}

body.arss-woocommerce.single-product div.product .woocommerce-product-gallery {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
  border-radius: 0 !important;
  overflow: hidden;
  background: var(--arss-surface-container-lowest);
  border: 1px solid var(--arss-border);
  box-shadow: none !important;
}

body.arss-woocommerce.single-product div.product .woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  display: block;
}

body.arss-woocommerce.single-product div.product .summary {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: clamp(8px, 2vw, 24px);
}

body.arss-woocommerce.single-product div.product .woocommerce-tabs,
body.arss-woocommerce.single-product div.product .related.products,
body.arss-woocommerce.single-product div.product > .up-sells,
body.arss-woocommerce.single-product div.product > .cart {
  grid-column: 1 / -1;
}

body.arss-woocommerce.single-product .product_title {
  font: 400 clamp(28px, 4vw, 44px)/1.15 var(--arss-font-display) !important;
  color: var(--arss-primary) !important;
  margin: 0 0 12px !important;
  overflow-wrap: break-word;
}

body.arss-woocommerce.single-product p.price,
body.arss-woocommerce.single-product span.price {
  font: 300 clamp(18px, 2.5vw, 22px)/1.4 var(--arss-font-body) !important;
  color: var(--arss-secondary) !important;
  margin: 0 0 24px !important;
}

body.arss-woocommerce.single-product p.price del {
  opacity: 0.55;
}

body.arss-woocommerce.single-product .woocommerce-product-details__short-description {
  color: var(--arss-on-surface-variant);
  font-size: 16px;
  line-height: 1.65;
  margin-bottom: 28px;
  max-width: 42ch;
}

body.arss-woocommerce.single-product .woocommerce-product-details__short-description p {
  margin: 0 0 12px;
}

body.arss-woocommerce.single-product .summary > .arss-intent {
  order: 10;
  margin: 0 0 24px;
}

body.arss-woocommerce.single-product .summary .arss-customize-btn {
  order: 20;
  width: 100%;
  margin: 0 0 16px !important;
  justify-content: center;
}

body.arss-woocommerce.single-product form.cart,
body.arss-woocommerce.single-product form.variations_form.cart {
  order: 30;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch !important;
  gap: 12px !important;
  width: 100% !important;
  margin: 0 0 16px !important;
  padding-top: 24px !important;
  border-top: 1px solid var(--arss-border) !important;
}

body.arss-woocommerce.single-product form.variations_form .variations {
  width: 100%;
  margin-bottom: 12px;
}

body.arss-woocommerce.single-product form.variations_form .variations td,
body.arss-woocommerce.single-product form.variations_form .variations th {
  color: var(--arss-on-surface-variant);
  padding: 8px 0;
}

body.arss-woocommerce.single-product form.variations_form .variations select {
  width: 100%;
  background: var(--arss-surface-container-lowest);
  border: 1px solid var(--arss-border-strong);
  border-radius: 0;
  color: var(--arss-on-surface);
  padding: 10px 12px;
}

body.arss-woocommerce.single-product form.cart .quantity {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: stretch;
  margin: 0 !important;
  border: 1px solid var(--arss-border-strong);
  background: var(--arss-surface-container-lowest);
}

body.arss-woocommerce.single-product form.cart .quantity .qty {
  width: 56px;
  min-height: 48px;
  padding: 8px 4px;
  margin: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  color: var(--arss-on-surface);
  font: 600 15px/1 var(--arss-font-body);
  text-align: center;
  -moz-appearance: textfield;
  appearance: textfield;
}

body.arss-woocommerce.single-product form.cart .quantity .qty::-webkit-outer-spin-button,
body.arss-woocommerce.single-product form.cart .quantity .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

body.arss-woocommerce.single-product form.cart .quantity .plus,
body.arss-woocommerce.single-product form.cart .quantity .minus {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  min-height: 48px;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  color: var(--arss-primary);
  font: 400 20px/1 var(--arss-font-body);
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease;
}

body.arss-woocommerce.single-product form.cart .quantity .minus {
  border-right: 1px solid var(--arss-border);
}

body.arss-woocommerce.single-product form.cart .quantity .plus {
  border-left: 1px solid var(--arss-border);
}

body.arss-woocommerce.single-product form.cart .quantity .plus:hover,
body.arss-woocommerce.single-product form.cart .quantity .minus:hover {
  background: var(--arss-hover-surface);
  color: var(--arss-primary);
}

.woocommerce-cart .quantity,
.woocommerce-checkout-review-order-table .quantity {
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--arss-border-strong);
  background: var(--arss-surface-container-lowest);
}

.woocommerce-cart .quantity .qty,
.woocommerce-checkout-review-order-table .quantity .qty {
  width: 48px;
  min-height: 40px;
  padding: 8px 4px;
  margin: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  color: var(--arss-on-surface);
  font: 600 14px/1 var(--arss-font-body);
  text-align: center;
  -moz-appearance: textfield;
  appearance: textfield;
}

.woocommerce-cart .quantity .qty::-webkit-outer-spin-button,
.woocommerce-cart .quantity .qty::-webkit-inner-spin-button,
.woocommerce-checkout-review-order-table .quantity .qty::-webkit-outer-spin-button,
.woocommerce-checkout-review-order-table .quantity .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

body.arss-woocommerce.single-product form.cart .single_add_to_cart_button,
body.arss-woocommerce.single-product form.cart button[type="submit"] {
  flex: 1 1 180px !important;
  min-height: 48px !important;
  margin: 0 !important;
  width: auto !important;
}

body.arss-woocommerce.single-product .product_meta {
  order: 40;
  margin-top: 8px;
  padding-top: 20px;
  border-top: 1px solid var(--arss-border-subtle);
  font-size: 13px;
  color: var(--arss-outline);
}

body.arss-woocommerce.single-product .product_meta a {
  color: var(--arss-primary);
}

body.arss-woocommerce.single-product .woocommerce-tabs {
  margin-top: clamp(32px, 5vw, 64px);
  padding-top: clamp(32px, 5vw, 48px);
  border-top: 1px solid var(--arss-border);
}

body.arss-woocommerce.single-product .woocommerce-tabs ul.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin: 0 0 24px !important;
  padding: 0 !important;
  list-style: none !important;
  border-bottom: 1px solid var(--arss-border) !important;
}

body.arss-woocommerce.single-product .woocommerce-tabs ul.tabs li {
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}

body.arss-woocommerce.single-product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 12px 20px;
  font: 600 11px/1 var(--arss-font-body);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--arss-on-surface-variant) !important;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}

body.arss-woocommerce.single-product .woocommerce-tabs ul.tabs li.active a {
  color: var(--arss-primary) !important;
  border-bottom-color: var(--arss-primary);
}

body.arss-woocommerce.single-product .woocommerce-Tabs-panel {
  color: var(--arss-on-surface-variant);
  line-height: 1.65;
}

body.arss-woocommerce.single-product .related.products,
body.arss-woocommerce.single-product .up-sells {
  margin-top: clamp(48px, 6vw, 80px);
  padding-top: clamp(32px, 4vw, 48px);
  border-top: 1px solid var(--arss-border);
}

body.arss-woocommerce.single-product .related.products > h2,
body.arss-woocommerce.single-product .up-sells > h2 {
  font: 400 clamp(24px, 3vw, 32px)/1.2 var(--arss-font-display);
  color: var(--arss-primary);
  margin-bottom: 32px;
}

body.arss-woocommerce.single-product .arss-breadcrumb {
  width: 100%;
  margin: 0;
  padding: 0 0 clamp(10px, 1.5vw, 14px);
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product > .arss-breadcrumb {
  display: none;
}

/* Unified product shell — breadcrumb + gallery/details share one aligned column */
body.arss-woocommerce.single-product .arss-pdp-shell {
  box-sizing: border-box;
  width: min(var(--arss-max), calc(100% - var(--arss-gutter) * 2));
  margin-inline: auto;
  min-width: 0;
  padding-top: calc(var(--arss-header-h) + clamp(12px, 2vw, 20px));
  padding-bottom: clamp(64px, 8vw, 96px);
  overflow-x: clip;
}

body.arss-woocommerce.single-product .arss-pdp-shell > .wp-site-blocks {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Block theme single product (WooCommerce block template) */
body.arss-woocommerce.single-product .wp-block-group.woocommerce.product {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.arss-woocommerce.single-product .woocommerce.product {
  padding-bottom: 0 !important;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product > main,
body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .has-global-padding,
body.arss-woocommerce.single-product .is-layout-constrained {
  padding: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  width: 100% !important;
}

body.arss-woocommerce.single-product .is-layout-constrained > *,
body.arss-woocommerce.single-product .is-layout-constrained > .alignwide {
  max-width: none !important;
  width: 100% !important;
  margin-block-start: 0 !important;
  margin-top: 0 !important;
  margin-inline: 0 !important;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .alignwide {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-inline: 0 !important;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .wp-block-columns,
body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .wp-block-columns.alignwide {
  display: grid !important;
  flex-wrap: unset !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr) !important;
  gap: clamp(28px, 4vw, 56px) !important;
  align-items: start !important;
  justify-content: stretch !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .wp-block-column {
  flex-basis: auto !important;
  flex-grow: unset !important;
  width: auto !important;
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery {
  clear: none !important;
  max-width: none !important;
  width: 100%;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery {
  min-width: 0;
  width: 100%;
  aspect-ratio: 1;
  opacity: 1 !important;
  border-radius: 0 !important;
  overflow: hidden;
  background: var(--arss-surface-container-lowest);
  border: 1px solid var(--arss-border);
  box-shadow: none !important;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery__wrapper,
body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery__image,
body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery__image--placeholder {
  height: 100%;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery__image img,
body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery__image--placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .wp-block-columns > .wp-block-column:last-child {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: clamp(4px, 1vw, 12px);
  min-width: 0;
}

body.arss-woocommerce.single-product .wp-block-post-title {
  display: block !important;
  font: 400 clamp(28px, 4vw, 44px)/1.15 var(--arss-font-display) !important;
  color: var(--arss-primary) !important;
  margin: 0 0 12px !important;
  overflow-wrap: break-word;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-price {
  margin: 0 0 24px !important;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-price .woocommerce-Price-amount {
  font: 300 clamp(18px, 2.5vw, 22px)/1.4 var(--arss-font-body) !important;
  color: var(--arss-secondary) !important;
}

body.arss-woocommerce.single-product .wp-block-post-excerpt {
  color: var(--arss-on-surface-variant);
  font-size: 16px;
  line-height: 1.65;
  margin: 0 0 24px;
  max-width: 100%;
}

body.arss-woocommerce.single-product .wp-block-post-excerpt__excerpt {
  margin: 0;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .arss-intent {
  order: 10;
  margin: 0 0 20px;
  min-width: 0;
  max-width: 100%;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .arss-intent__toggle {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .arss-customize-btn {
  order: 20;
  width: 100%;
  max-width: 100%;
  margin: 0 0 16px !important;
  justify-content: center;
  box-sizing: border-box;
}

body.arss-woocommerce.single-product .wp-block-add-to-cart-form,
body.arss-woocommerce.single-product .wp-block-woocommerce-add-to-cart-form {
  order: 30;
  width: 100%;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-add-to-cart-form form.cart {
  display: flex !important;
  flex-wrap: wrap !important;
  grid-auto-flow: unset !important;
  grid-template-columns: unset !important;
  align-items: stretch !important;
  gap: 12px !important;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-add-to-cart-form form.cart > * {
  grid-column: unset !important;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-add-to-cart-form form.cart .single_add_to_cart_button {
  flex: 1 1 180px !important;
  justify-self: unset !important;
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-meta {
  order: 40;
  margin-top: 8px;
  padding-top: 20px;
  border-top: 1px solid var(--arss-border-subtle);
  font-size: 13px;
  color: var(--arss-outline);
}

body.arss-woocommerce.single-product .wp-block-woocommerce-product-details.alignwide {
  width: 100% !important;
  max-width: none !important;
  margin-top: clamp(32px, 5vw, 64px);
}

body.arss-woocommerce.single-product .wc-block-store-notices {
  width: 100%;
  margin: 0 0 12px !important;
}

body.arss-woocommerce.single-product .wc-block-store-notices:has(.woocommerce-notices-wrapper:empty) {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  min-height: 0 !important;
}

body.arss-woocommerce.single-product .arss-breadcrumb__item a {
  color: var(--arss-on-surface-variant);
  font: 600 11px/1 var(--arss-font-body);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.arss-woocommerce.single-product .arss-breadcrumb__item a:hover,
body.arss-woocommerce.single-product .arss-breadcrumb__item.is-current {
  color: var(--arss-primary);
}

@media (max-width: 900px) {
  body.arss-woocommerce.single-product div.product {
    grid-template-columns: 1fr !important;
  }

  body.arss-woocommerce.single-product div.product .woocommerce-product-gallery,
  body.arss-woocommerce.single-product div.product .summary {
    grid-column: 1;
  }

  body.arss-woocommerce.single-product div.product .summary {
    padding-top: 0;
  }

  body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .wp-block-columns,
  body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .wp-block-columns.alignwide {
    grid-template-columns: 1fr !important;
    gap: clamp(20px, 4vw, 32px) !important;
  }

  body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .wp-block-columns > .wp-block-column:last-child {
    padding-top: 0;
  }

  body.arss-woocommerce.single-product .wp-block-group.woocommerce.product .arss-intent__toggle {
    grid-template-columns: 1fr;
  }

  body.arss-woocommerce.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery {
    aspect-ratio: 4 / 3;
  }

  body.arss-woocommerce.single-product form.cart .single_add_to_cart_button,
  body.arss-woocommerce.single-product form.cart button[type="submit"] {
    flex: 1 1 100% !important;
    width: 100% !important;
  }
}

/* --- Brackets --- */
.arss-brackets::before,
.arss-brackets::after {
  opacity: 0;
  transition: opacity 0.8s ease;
  border-color: var(--arss-secondary);
}

.arss-brackets:hover::before,
.arss-brackets:hover::after {
  opacity: 1;
}

/* --- Responsive --- */
@media (max-width: 1200px) {
  .arss-header-search--desktop {
    width: min(240px, 24vw);
    min-width: 168px;
  }
}

@media (max-width: 1024px) {
  .arss-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .arss-header__brand {
    position: static;
    transform: none;
    flex: 1;
    justify-self: center;
    max-width: none;
    pointer-events: auto;
    text-align: center;
  }

  .arss-header__nav {
    position: fixed;
    top: var(--arss-header-h);
    left: 0;
    right: 0;
    flex: none;
    max-width: none;
    z-index: 1001;
    border-radius: 0;
    background: var(--arss-overlay-bg);
    border: none;
    border-bottom: 1px solid var(--arss-border);
    box-shadow: none;
    padding: 16px var(--arss-gutter);
    max-height: calc(100dvh - var(--arss-header-h));
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s ease, visibility 0.3s ease;
  }

  .arss-nav.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .arss-nav__list {
    flex-direction: column;
    align-items: stretch;
    overflow: visible;
    gap: 0;
  }

  .arss-nav__list a,
  .arss-nav__realms-btn {
    padding: 12px 0;
    font-size: 12px;
    white-space: normal;
    color: var(--arss-on-surface);
  }

  .arss-nav__list a:hover,
  .arss-nav__list a.is-active,
  .arss-nav__realms-btn:hover,
  .arss-nav__realms-btn[aria-expanded="true"] {
    color: var(--arss-primary);
  }

  .arss-header .arss-brand__name {
    font-size: 17px;
  }

  .arss-menu-btn {
    display: flex !important;
    color: var(--arss-header-fg);
  }

  .arss-menu-btn span {
    background: currentColor;
  }

  .arss-header__actions {
    flex: 0 0 auto;
    gap: 4px;
  }

  .arss-header-search--desktop {
    display: none;
  }

  .arss-nav__item--mobile-only {
    display: list-item;
  }

  .arss-hero__title {
    max-width: none;
  }

  .arss-trust__row {
    grid-template-columns: repeat(2, 1fr);
  }

  .arss-realm-grid,
  .arss-cat-grid,
  .arss-products .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .arss-steps--light {
    grid-template-columns: 1fr;
  }

  .arss-section__head--split {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (min-width: 1025px) {
  .arss-nav {
    position: static;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .arss-menu-btn {
    display: none !important;
  }
}

@media (max-width: 600px) {
  .arss-trust__row {
    grid-template-columns: 1fr;
  }

  .arss-realm-grid,
  .arss-cat-grid,
  .arss-products .woocommerce ul.products {
    grid-template-columns: 1fr !important;
  }

  .arss-hero__visual {
    order: -1;
  }
}

@media (min-width: 1101px) and (max-width: 1280px) {
  .arss-nav__list a,
  .arss-nav__realms-btn {
    font-size: 10px;
    letter-spacing: 0.06em;
  }

  .arss-header__brand .arss-brand__name {
    font-size: 20px;
  }
}

/* --- Overlay, panel & misc outlined controls --- */
.arss-preview-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.arss-preview-tabs__btn {
  padding: 10px 16px;
  border: 1px solid var(--arss-btn-outline-border);
  border-radius: 0;
  background: transparent;
  font: 600 10px/1 var(--arss-font-body);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--arss-on-surface-variant);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.arss-preview-tabs__btn.is-active,
.arss-preview-tabs__btn:hover {
  background: var(--arss-btn-outline-hover-bg);
  color: var(--arss-btn-outline-fg);
  border-color: var(--arss-btn-outline-border);
}

.arss-overlay__close,
.arss-panel__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--arss-btn-outline-border);
  background: transparent;
  color: var(--arss-btn-outline-fg);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.arss-overlay__close:hover,
.arss-panel__close:hover {
  background: var(--arss-btn-outline-hover-bg);
  border-color: var(--arss-btn-outline-border);
  color: var(--arss-btn-outline-fg);
}

.arss-dropzone,
#arss-dropzone {
  border: 1px dashed var(--arss-btn-outline-border) !important;
  background: var(--arss-surface-container-low) !important;
  color: var(--arss-on-surface-variant) !important;
}

.arss-dropzone.is-dragover,
#arss-dropzone.is-dragover {
  border-color: var(--arss-btn-outline-fg) !important;
  background: var(--arss-accent-surface) !important;
}

body.arss-branded .woocommerce nav.woocommerce-pagination ul li a,
body.arss-branded .woocommerce nav.woocommerce-pagination ul li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  min-height: 40px;
  padding: 8px 12px;
  border: 1px solid var(--arss-btn-outline-border) !important;
  background: transparent !important;
  color: var(--arss-btn-outline-fg) !important;
  border-radius: 0 !important;
}

body.arss-branded .woocommerce nav.woocommerce-pagination ul li span.current,
body.arss-branded .woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--arss-btn-outline-hover-bg) !important;
  border-color: var(--arss-btn-outline-border) !important;
  color: var(--arss-btn-outline-fg) !important;
}

body.arss-branded .woocommerce .coupon .button,
body.arss-branded .woocommerce .actions .button,
body.arss-branded .woocommerce .woocommerce-Button,
body.arss-branded .woocommerce a.button.wc-backward,
body.arss-branded .woocommerce a.button.wc-forward {
  border: 1px solid var(--arss-btn-outline-border) !important;
  background: transparent !important;
  color: var(--arss-btn-outline-fg) !important;
}

body.arss-branded .woocommerce .coupon .button:hover,
body.arss-branded .woocommerce .actions .button:hover,
body.arss-branded .woocommerce .woocommerce-Button:hover,
body.arss-branded .woocommerce a.button.wc-backward:hover,
body.arss-branded .woocommerce a.button.wc-forward:hover {
  background: var(--arss-btn-outline-hover-bg) !important;
  color: var(--arss-btn-outline-fg) !important;
}

/* --- Proceed to checkout (classic + block cart) --- */
body.arss-branded .wc-proceed-to-checkout,
body.arss-branded .wc-block-cart__submit-container,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block {
  margin-top: 16px;
  width: 100%;
}

body.arss-branded .wc-proceed-to-checkout a,
body.arss-branded .wc-block-cart__submit-container a,
body.arss-branded .wc-block-cart__submit-button,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block a,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block .wp-block-button__link,
body.arss-branded .wc-block-cart .wc-block-components-button:not(.is-link),
body.arss-branded .wc-block-components-checkout-place-order-button,
body.arss-branded .wp-block-woocommerce-cart .wc-block-components-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 14px 24px !important;
  min-height: 48px !important;
  border: 1px solid var(--arss-btn-outline-border) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--arss-btn-outline-fg) !important;
  font: 600 12px/1.3 var(--arss-font-body) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  text-underline-offset: unset !important;
  box-shadow: none !important;
  cursor: pointer !important;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
}

body.arss-branded .wc-proceed-to-checkout a:hover,
body.arss-branded .wc-block-cart__submit-container a:hover,
body.arss-branded .wc-block-cart__submit-button:hover,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block a:hover,
body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block .wp-block-button__link:hover,
body.arss-branded .wc-block-cart .wc-block-components-button:not(.is-link):hover,
body.arss-branded .wc-block-components-checkout-place-order-button:hover,
body.arss-branded .wp-block-woocommerce-cart .wc-block-components-button:hover {
  background: var(--arss-btn-outline-hover-bg) !important;
  color: var(--arss-btn-outline-fg) !important;
  border-color: var(--arss-btn-outline-border) !important;
  text-decoration: none !important;
}

body.arss-branded .wp-block-woocommerce-proceed-to-checkout-block .wp-block-button,
body.arss-branded .wc-block-cart__submit.wp-block-button {
  width: 100%;
}

body.arss-branded .woocommerce-orders-table__cell-order-actions a.button {
  padding: 8px 14px !important;
  min-height: auto !important;
  font-size: 10px !important;
}

/* --- Cart / checkout / account page gutters --- */
body.arss-branded.woocommerce-cart .arss-main,
body.arss-branded.woocommerce-checkout .arss-main,
body.arss-branded.woocommerce-account .arss-main {
  width: 100%;
  max-width: none;
  padding-top: var(--arss-header-h);
  padding-inline: var(--arss-gutter);
  padding-bottom: clamp(48px, 8vw, 96px);
  box-sizing: border-box;
}

body.arss-branded.woocommerce-cart .arss-main > .wp-block-post-content,
body.arss-branded.woocommerce-cart .arss-main > .entry-content,
body.arss-branded.woocommerce-checkout .arss-main > .wp-block-post-content,
body.arss-branded.woocommerce-checkout .arss-main > .entry-content,
body.arss-branded.woocommerce-account .arss-main > .wp-block-post-content,
body.arss-branded.woocommerce-account .arss-main > .entry-content,
body.arss-branded.woocommerce-cart .woocommerce,
body.arss-branded.woocommerce-checkout .woocommerce,
body.arss-branded.woocommerce-account .woocommerce {
  width: min(var(--arss-max), 100%);
  max-width: var(--arss-max);
  margin-inline: auto;
  padding-inline: 0;
}

/* Block cart/checkout uses alignfull — cancel full-bleed breakout */
body.arss-branded.woocommerce-cart .alignfull,
body.arss-branded.woocommerce-checkout .alignfull,
body.arss-branded.woocommerce-account .alignfull,
body.arss-branded.woocommerce-cart .wp-block-woocommerce-cart,
body.arss-branded.woocommerce-checkout .wp-block-woocommerce-checkout,
body.arss-branded.woocommerce-cart .wc-block-cart,
body.arss-branded.woocommerce-checkout .wc-block-checkout {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

body.arss-branded.woocommerce-cart .wp-block-post-title,
body.arss-branded.woocommerce-checkout .wp-block-post-title {
  width: min(var(--arss-max), 100%);
  max-width: var(--arss-max);
  margin-inline: auto;
  padding-top: clamp(24px, 4vw, 48px);
}

body.arss-branded.woocommerce-cart .wc-block-cart,
body.arss-branded.woocommerce-checkout .wc-block-checkout {
  padding-top: clamp(16px, 3vw, 32px);
}

body.arss-branded.woocommerce-cart .woocommerce-cart-form,
body.arss-branded.woocommerce-cart .cart-collaterals {
  width: 100%;
}

/* ==========================================================================
   Site-wide motion
   ========================================================================== */

@keyframes arss-fade-up {
  from {
    opacity: 0;
    transform: translateY(28px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes arss-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes arss-slide-up {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes arss-menu-drop {
  from {
    opacity: 0;
    transform: translateY(-10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes arss-trust-pop {
  from {
    opacity: 0;
    transform: scale(0.85);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

/* Page load — hero entrance */
body.arss-branded.arss-ready .arss-hero__copy {
  animation: arss-fade-up 1s cubic-bezier(0.22, 1, 0.36, 1) both;
}

body.arss-branded.arss-ready .arss-hero__visual {
  animation: arss-fade-up 1s cubic-bezier(0.22, 1, 0.36, 1) 0.12s both;
}

body.arss-branded.arss-ready .arss-hero__actions {
  animation: arss-fade-up 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.28s both;
}

/* Shop hero entrance */
body.arss-branded.arss-ready .arss-shop-hero__inner > * {
  animation: arss-fade-up 0.85s cubic-bezier(0.22, 1, 0.36, 1) both;
}

body.arss-branded.arss-ready .arss-shop-hero__inner > *:nth-child(2) {
  animation-delay: 0.1s;
}

body.arss-branded.arss-ready .arss-shop-hero__inner > *:nth-child(3) {
  animation-delay: 0.2s;
}

/* Scroll reveal */
.arss-reveal {
  --arss-reveal-delay: 0ms;
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--arss-reveal-delay);
}

.arss-reveal.is-visible {
  opacity: 1;
  transform: none;
}

.arss-quote.is-visible blockquote {
  animation: arss-fade-up 0.9s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.arss-trust__item.is-visible .arss-trust__icon {
  animation: arss-trust-pop 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
  animation-delay: var(--arss-reveal-delay, 0ms);
}

/* Card hover lift */
.arss-realm-card,
.arss-cat-card,
.arss-products .woocommerce ul.products li.product {
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.45s ease,
    border-color 0.35s ease,
    background 0.35s ease;
}

.arss-cat-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(6, 17, 43, 0.08);
}

.arss-products .woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
}

.arss-cat-card__media {
  overflow: hidden;
  transition: transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

.arss-cat-card:hover .arss-cat-card__media {
  transform: scale(1.06);
}

/* Buttons */
.arss-btn {
  transition:
    background 0.25s ease,
    color 0.25s ease,
    border-color 0.25s ease,
    transform 0.25s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.25s ease;
}

.arss-btn:hover {
  transform: translateY(-2px);
}

.arss-btn:active {
  transform: translateY(0) scale(0.98);
}

/* Nav underline (desktop) */
@media (min-width: 1025px) {
  .arss-nav__list a {
    position: relative;
  }

  .arss-nav__list a::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    height: 1px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .arss-nav__list a:hover::after,
  .arss-nav__list a.is-active::after {
    transform: scaleX(1);
  }
}

/* Realms dropdown */
.arss-realms-menu:not([hidden]) {
  animation: arss-menu-drop 0.28s cubic-bezier(0.22, 1, 0.36, 1) both;
  transform-origin: top center;
}

/* Customization panel (redesign) */
.arss-custom-panel {
  position: fixed;
  inset: 0;
  z-index: 100001;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(12px, 3vw, 24px);
  box-sizing: border-box;
}

.arss-custom-panel[hidden] {
  display: none !important;
}

.arss-custom-panel__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 26, 63, 0.55);
  backdrop-filter: blur(6px);
}

.arss-custom-panel__dialog {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  width: min(960px, 100%);
  max-height: min(92dvh, 860px);
  background: var(--arss-surface);
  border: 1px solid var(--arss-border);
  box-shadow: 0 24px 64px rgba(10, 26, 63, 0.18);
  overflow: hidden;
  min-width: 0;
}

.arss-custom-panel__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: clamp(20px, 3vw, 28px) clamp(20px, 3vw, 28px) 0;
}

.arss-custom-panel__intro {
  min-width: 0;
}

.arss-custom-panel__title {
  margin: 6px 0 8px;
  font: 400 clamp(24px, 3.5vw, 34px)/1.15 var(--arss-font-display);
  color: var(--arss-primary);
  overflow-wrap: anywhere;
}

.arss-custom-panel__lead {
  margin: 0;
  max-width: 52ch;
  font-size: 15px;
  line-height: 1.6;
  color: var(--arss-on-surface-variant);
}

.arss-custom-panel__close {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--arss-border-strong);
  background: var(--arss-surface-container-low);
  color: var(--arss-primary);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.arss-custom-panel__close:hover {
  background: var(--arss-hover-surface);
}

.arss-custom-panel__steps {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  margin: clamp(16px, 2.5vw, 20px) clamp(20px, 3vw, 28px) 0;
  padding: 0;
}

.arss-custom-panel__step {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid var(--arss-border);
  background: var(--arss-surface-container-low);
  font: 600 10px/1 var(--arss-font-body);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--arss-outline);
}

.arss-custom-panel__step.is-active {
  border-color: var(--arss-primary);
  color: var(--arss-primary);
  background: var(--arss-accent-surface);
}

.arss-custom-panel__step.is-done {
  color: var(--arss-on-surface-variant);
}

.arss-custom-panel__step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border: 1px solid currentColor;
  font-size: 10px;
}

.arss-custom-panel__body {
  overflow: auto;
  padding: clamp(16px, 2.5vw, 24px) clamp(20px, 3vw, 28px);
  min-height: 0;
}

.arss-custom-panel__layout {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: clamp(20px, 3vw, 32px);
  align-items: start;
}

.arss-custom-panel__col-title {
  margin: 0 0 12px;
  font: 600 11px/1 var(--arss-font-body);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--arss-outline);
}

.arss-custom-panel__dropzone {
  position: relative;
  display: grid;
  place-items: center;
  gap: 8px;
  min-height: 200px;
  padding: 28px 20px;
  border: 1px dashed var(--arss-border-strong);
  background: var(--arss-surface-container-lowest);
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease;
}

.arss-custom-panel__dropzone:hover,
.arss-custom-panel__dropzone.is-dragover {
  border-color: var(--arss-primary);
  background: var(--arss-accent-surface);
}

.arss-custom-panel__dropzone.is-busy {
  pointer-events: none;
  opacity: 0.65;
}

.arss-custom-panel__dropzone.has-file {
  border-style: solid;
  border-color: var(--arss-primary);
}

.arss-custom-panel__dropzone input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.arss-custom-panel__dropzone-icon {
  color: var(--arss-primary);
  opacity: 0.85;
}

.arss-custom-panel__dropzone-title {
  font: 500 17px/1.35 var(--arss-font-display);
  color: var(--arss-primary);
}

.arss-custom-panel__dropzone-hint {
  font-size: 13px;
  line-height: 1.5;
  color: var(--arss-on-surface-variant);
  max-width: 28ch;
}

.arss-custom-panel__tips {
  margin: 14px 0 0;
  padding: 0 0 0 18px;
  font-size: 13px;
  line-height: 1.55;
  color: var(--arss-on-surface-variant);
}

.arss-custom-panel__tips li + li {
  margin-top: 6px;
}

.arss-custom-panel__preview-col {
  position: relative;
  min-height: 280px;
}

.arss-custom-panel__preview-empty {
  display: grid;
  place-items: center;
  min-height: 280px;
  padding: 24px;
  border: 1px solid var(--arss-border);
  background: var(--arss-surface-container-low);
  text-align: center;
}

.arss-custom-panel__preview-empty p {
  margin: 0;
  max-width: 26ch;
  font-size: 14px;
  line-height: 1.6;
  color: var(--arss-on-surface-variant);
}

.arss-custom-panel__preview-ready[hidden],
.arss-custom-panel__preview-empty[hidden] {
  display: none !important;
}

.arss-custom-panel__tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.arss-custom-panel__tab {
  padding: 9px 14px;
  border: 1px solid var(--arss-border-strong);
  background: transparent;
  font: 600 10px/1 var(--arss-font-body);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--arss-on-surface-variant);
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.arss-custom-panel__tab.is-active,
.arss-custom-panel__tab:hover {
  background: var(--arss-primary);
  border-color: var(--arss-primary);
  color: var(--arss-on-primary, #fff);
}

.arss-custom-panel__stage {
  min-height: 280px;
  padding: 16px;
  border: 1px solid var(--arss-border);
  background: var(--arss-surface-container-lowest);
  display: grid;
  place-items: center;
}

.arss-custom-panel__preview-img {
  display: none;
  width: 100%;
  max-height: min(42vh, 380px);
  object-fit: contain;
}

.arss-custom-panel__preview-img.is-active {
  display: block;
}

.arss-custom-panel__loading {
  position: absolute;
  inset: 28px 0 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  background: color-mix(in srgb, var(--arss-surface) 88%, transparent);
  font-size: 14px;
  color: var(--arss-on-surface-variant);
  z-index: 2;
}

.arss-custom-panel__loading[hidden] {
  display: none !important;
}

.arss-custom-panel__spinner {
  width: 28px;
  height: 28px;
  border: 2px solid var(--arss-border);
  border-top-color: var(--arss-primary);
  border-radius: 50%;
  animation: arss-spin 0.8s linear infinite;
}

@keyframes arss-spin {
  to { transform: rotate(360deg); }
}

.arss-custom-panel__error {
  margin: 12px 0 0;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, #c0392b 40%, var(--arss-border));
  background: color-mix(in srgb, #c0392b 8%, var(--arss-surface));
  color: #922b21;
  font-size: 13px;
  line-height: 1.5;
}

.arss-custom-panel__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px clamp(20px, 3vw, 28px) calc(16px + env(safe-area-inset-bottom));
  border-top: 1px solid var(--arss-border);
  background: var(--arss-surface-container-low);
}

.arss-custom-panel__form {
  flex: 1 1 220px;
  display: flex;
  justify-content: flex-end;
  margin: 0;
}

.arss-custom-panel__confirm {
  width: 100%;
  max-width: 360px;
  min-height: 48px;
}

.arss-custom-panel__confirm:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

body.arss-custom-panel-open .arss-header {
  z-index: 1000;
}

.arss-custom-panel.is-active .arss-custom-panel__backdrop {
  animation: arss-fade-in 0.3s ease both;
}

.arss-custom-panel.is-active .arss-custom-panel__dialog {
  animation: arss-panel-in 0.38s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes arss-panel-in {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 768px) {
  .arss-custom-panel {
    padding: 0;
    align-items: stretch;
  }

  .arss-custom-panel__dialog {
    width: 100%;
    max-height: 100dvh;
    border: none;
  }

  .arss-custom-panel__layout {
    grid-template-columns: 1fr;
  }

  .arss-custom-panel__preview-col {
    min-height: 220px;
  }

  .arss-custom-panel__preview-empty,
  .arss-custom-panel__stage {
    min-height: 220px;
  }

  .arss-custom-panel__footer {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .arss-custom-panel__form,
  .arss-custom-panel__confirm {
    max-width: none;
    width: 100%;
  }

  .arss-custom-panel__cancel {
    width: 100%;
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .arss-custom-panel.is-active .arss-custom-panel__backdrop,
  .arss-custom-panel.is-active .arss-custom-panel__dialog,
  .arss-custom-panel__spinner {
    animation: none !important;
  }
}


/* Brackets fade in on reveal */
.arss-reveal.is-visible.arss-brackets::before,
.arss-reveal.is-visible.arss-brackets::after {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  body.arss-branded.arss-ready .arss-hero__copy,
  body.arss-branded.arss-ready .arss-hero__visual,
  body.arss-branded.arss-ready .arss-hero__actions,
  body.arss-branded.arss-ready .arss-shop-hero__inner > *,
  .arss-quote.is-visible blockquote,
  .arss-trust__item.is-visible .arss-trust__icon,
  .arss-realms-menu:not([hidden]),
  .arss-custom-panel.is-active .arss-custom-panel__backdrop,
  .arss-custom-panel.is-active .arss-custom-panel__dialog {
    animation: none !important;
  }

  .arss-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .arss-realm-card:hover,
  .arss-cat-card:hover,
  .arss-products .woocommerce ul.products li.product:hover,
  .arss-btn:hover,
  .arss-btn:active {
    transform: none;
  }

  .arss-cat-card:hover .arss-cat-card__media {
    transform: none;
  }
}
