/* Full-bleed on the home template: hero/bands span the full viewport.
   .si-home lives inside Astra's .ast-container (max-width 1200px), which
   would otherwise leave a gap on the right vs. the rest of the page.
   Break .si-home out of its container with viewport-relative width.
   The header's .ast-container is a separate element — keep it constrained. */
.page-template-template-home-php .si-home{
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  position:relative;
}
.page-template-template-home-php #primary,
.page-template-template-home-php .site-main,
.page-template-template-home-php .entry-content{
  width:100%;max-width:100%;margin:0;padding:0;display:block;grid-template-columns:none
}

.si-home{--gap:clamp(64px,9vw,128px);background:var(--si-warm-white)}
.si-wrap{max-width:var(--si-wrap);margin:0 auto;padding:0 24px}
.si-section{padding:var(--gap) 0;position:relative}
.si-section--paper{background:var(--si-paper)}
.si-section--ink{background:var(--si-near-black);color:#e7e0d8;position:relative;overflow:hidden}
.si-section--ink::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px) 0 0/56px 56px,
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px) 0 0/56px 56px;
  mask:linear-gradient(180deg,transparent,black 30%,black 70%,transparent);
}
.si-section--ink .si-section__title{color:#fff}
.si-section__title{
  font-size:clamp(2rem,4vw,3rem);text-align:center;margin:0 auto clamp(28px,4vw,56px);
  max-width:22ch;position:relative;
}
.si-section__title .si-accent{color:var(--si-orange)}
.si-accent{color:var(--si-orange)}
.si-section__head{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:clamp(28px,4vw,56px);text-align:center}
.si-section__head .si-eyebrow{margin:0}

/* ============================================================
   HERO
   ============================================================ */
.si-hero{
  position:relative;background:var(--si-near-black);color:#fff;overflow:hidden;
  padding:clamp(80px,11vw,140px) 0 clamp(80px,11vw,140px);
  isolation:isolate;
}
.si-hero__bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(50% 70% at 88% 8%,rgba(228,121,22,.45),transparent 60%),
    radial-gradient(35% 50% at 12% 92%,rgba(228,121,22,.18),transparent 60%),
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px) 0 0/56px 56px,
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px) 0 0/56px 56px;
  z-index:-1;
}
.si-hero::after{
  content:"";position:absolute;right:-8%;top:50%;width:520px;height:520px;
  transform:translateY(-50%);
  background:radial-gradient(closest-side,rgba(228,121,22,.22),transparent 70%);
  pointer-events:none;z-index:-1;
}
.si-hero__in{position:relative;max-width:1200px;margin:0 auto;padding:0 24px}
.si-hero h1{color:#fff;font-size:clamp(2.8rem,6.4vw,4.8rem);margin:.4em 0 .4em;max-width:16ch;line-height:1.02;letter-spacing:-.032em}
.si-hero h1 .si-accent{
  position:relative;display:inline-block;
  background:linear-gradient(180deg,transparent 62%,rgba(228,121,22,.35) 62%,rgba(228,121,22,.35) 88%,transparent 88%);
  padding:0 .12em;
}
.si-hero__lede{color:#cfc9c1;font-size:clamp(1.05rem,1.5vw,1.22rem);max-width:58ch;margin:0 0 12px}
.si-hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin:32px 0 28px}
.si-hero .si-btn--ghost{color:#fff;border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.04);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.si-hero .si-btn--ghost:hover{background:#fff;color:var(--si-ink);border-color:#fff}
.si-hero__trust{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:6px}
/* FENSA badge is a white certification card (maroon "APPROVED" bar). Do NOT
   invert it — brightness(0)+invert(1) turned the whole card solid white (blank
   box). It reads clean as-is on the dark hero. */
.si-hero-fensa{height:46px;width:auto;border-radius:8px;box-shadow:0 2px 10px -2px rgba(0,0,0,.4);display:block}
.si-hero__metric{
  display:flex;align-items:baseline;gap:8px;font-family:var(--si-font-display);
}
.si-hero__metric b{font-size:1.6rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.si-hero__metric span{font-size:.78rem;color:#8e8880;letter-spacing:.16em;text-transform:uppercase}
.si-hero__divider{width:1px;height:36px;background:rgba(255,255,255,.12)}

/* ============================================================
   NICHES — asymmetric grid
   ============================================================ */
.si-niche-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:18px;min-height:520px;
}
.si-niche-card{
  position:relative;display:flex;flex-direction:column;justify-content:flex-end;
  border-radius:var(--si-radius-lg);background:var(--si-ink) center/cover no-repeat;
  color:#fff;padding:26px;overflow:hidden;box-shadow:var(--si-shadow-sm);
  transition:transform var(--si-dur) var(--si-ease),box-shadow var(--si-dur) var(--si-ease);
  isolation:isolate;min-height:240px;min-width:0;
}
.si-niche-card::before{
  content:"";position:absolute;inset:-2px;z-index:0;
  background-image:inherit;background-size:cover;background-position:center;
  transform:scale(1.04);transition:transform .8s var(--si-ease-out);
}
.si-niche-card::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(14,14,14,0) 30%,rgba(14,14,14,.85));
}
.si-niche-card>*{position:relative;z-index:2}
.si-niche-card:hover{transform:translateY(-4px);box-shadow:var(--si-shadow-lg)}
.si-niche-card:hover::before{transform:scale(1.12)}
.si-niche-card__n{font-family:var(--si-font-mono);font-size:.72rem;letter-spacing:.18em;color:var(--si-orange);font-weight:600;margin-bottom:10px}
.si-niche-card__label{font-family:var(--si-font-display);font-weight:700;font-size:clamp(1.4rem,2vw,1.8rem);color:#fff;letter-spacing:-.018em;line-height:1.1;margin-bottom:6px;overflow-wrap:anywhere}
.si-niche-card__go{color:#fdf3ea;font-weight:600;font-size:.85rem;display:inline-flex;align-items:center;gap:6px}
.si-niche-card__go::after{content:"→";transition:transform var(--si-dur) var(--si-ease)}
.si-niche-card:hover .si-niche-card__go::after{transform:translateX(4px)}
/* Asymmetric placement: first card spans both rows */
.si-niche-card:first-child{grid-row:span 2;min-height:520px;padding:32px}
.si-niche-card:first-child .si-niche-card__label{font-size:clamp(1.8rem,2.6vw,2.4rem)}

/* ============================================================
   STEPS — connected timeline
   ============================================================ */
.si-step-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  position:relative;
}
.si-step-grid::before{
  content:"";position:absolute;left:8%;right:8%;top:34px;height:1px;
  background:repeating-linear-gradient(90deg,var(--si-border-strong) 0 6px,transparent 6px 12px);
  z-index:0;
}
.si-step{
  position:relative;background:transparent;border:0;border-radius:0;padding:0 24px 0;text-align:left;
  z-index:1;
}
.si-step__n{
  display:inline-grid;place-items:center;width:68px;height:68px;border-radius:50%;
  background:var(--si-warm-white);color:var(--si-ink);
  font-family:var(--si-font-display);font-weight:800;font-size:1.6rem;letter-spacing:-.04em;
  margin-bottom:18px;position:relative;
  box-shadow:0 0 0 1px var(--si-border-strong),0 0 0 6px var(--si-warm-white);
  transition:background var(--si-dur) var(--si-ease),color var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease);
}
.si-step__n::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  border:1.5px solid var(--si-orange);opacity:0;transform:scale(.85);
  transition:opacity var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease);
}
.si-step:hover .si-step__n{background:var(--si-orange);color:#fff;transform:translateY(-2px)}
.si-step:hover .si-step__n::after{opacity:1;transform:scale(1)}
.si-step h3{margin:0 0 8px;font-size:1.18rem;letter-spacing:-.012em}
.si-step p{margin:0;color:var(--si-grey-700);max-width:34ch}

/* ============================================================
   FEATURED PRODUCT CARDS
   ============================================================ */
.si-product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.si-pcard{
  position:relative;display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--si-border);border-radius:var(--si-radius-lg);overflow:hidden;
  transition:transform var(--si-dur) var(--si-ease),box-shadow var(--si-dur) var(--si-ease),border-color var(--si-dur) var(--si-ease);
}
.si-pcard:hover{transform:translateY(-5px);box-shadow:var(--si-shadow);border-color:var(--si-border-strong)}
.si-pcard__img{position:relative;overflow:hidden;background:var(--si-paper);aspect-ratio:1/1;display:block}
.si-pcard__img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--si-ease-out)}
.si-pcard:hover .si-pcard__img img{transform:scale(1.05)}
.si-pcard__img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,14,14,0) 60%,rgba(14,14,14,.08));
  pointer-events:none;
}
.si-pcard__eyebrow{
  position:absolute;top:14px;left:14px;z-index:2;
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  border-radius:var(--si-radius-pill);padding:.3em .8em;
  font-family:var(--si-font-display);font-weight:600;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--si-ink);
}
.si-pcard__eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--si-orange)}
.si-pcard__body{display:flex;flex-direction:column;gap:8px;padding:20px 22px 22px;flex:1}
.si-pcard__title{font-family:var(--si-font-display);font-weight:600;color:var(--si-ink);font-size:1.05rem;letter-spacing:-.01em;overflow-wrap:anywhere}
.si-pcard__price{color:var(--si-grey-700);font-size:.92rem;display:flex;align-items:baseline;gap:4px;flex-wrap:wrap}
.si-pcard__price .si-amount{color:var(--si-orange-dark);font-weight:700;font-size:1.05rem}
.si-pcard__price .si-from{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--si-grey-500);font-weight:600}
.si-pcard__btn{
  margin-top:14px;align-self:flex-start;
  background:transparent;color:var(--si-ink);border:0;padding:0;
  font-family:var(--si-font-display);font-weight:600;font-size:.9rem;
  display:inline-flex;align-items:center;gap:8px;
  border-bottom:1.5px solid currentColor;padding-bottom:3px;border-radius:0;
  transition:color var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease);
}
.si-pcard__btn:hover{color:var(--si-orange-dark);transform:translateX(3px);box-shadow:none;background:transparent}
.si-pcard__btn::after{content:"→";transition:transform var(--si-dur) var(--si-ease);display:inline}
.si-pcard:hover .si-pcard__btn::after{transform:translateX(3px)}

/* ============================================================
   TRUST STRIP — refined ink section
   ============================================================ */
.si-trust-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;
  text-align:left;position:relative;z-index:1;
}
.si-trust__item{
  padding:8px 0 8px 22px;position:relative;border-left:1px solid rgba(255,255,255,.12);
}
.si-trust__item::before{
  content:"";position:absolute;left:-1px;top:14px;width:1px;height:18px;background:var(--si-orange);
}
.si-trust__item b{
  display:flex;align-items:baseline;gap:6px;
  font-family:var(--si-font-display);font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:-.012em;
  margin-bottom:6px;
}
.si-trust__item b::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--si-orange);margin-left:2px}
.si-trust__item span{color:#8e8880;font-size:.88rem;line-height:1.5;display:block}

/* ============================================================
   CTA BAND
   ============================================================ */
.si-cta-band{
  position:relative;background:var(--si-orange);color:#fff;text-align:center;
  padding:clamp(48px,7vw,80px) 0;overflow:hidden;
}
.si-cta-band::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(50% 70% at 15% 50%,rgba(255,255,255,.18),transparent 60%),
    radial-gradient(40% 60% at 90% 50%,rgba(0,0,0,.18),transparent 60%);
}
.si-cta-band>*{position:relative}
.si-cta-band h2{color:#fff;margin:0 0 8px;font-size:clamp(1.8rem,3.4vw,2.6rem)}
.si-cta-band p{margin:0 auto 24px;max-width:48ch;opacity:.95}
.si-cta-band .si-btn--dark{background:#0e0e0e;color:#fff}
.si-cta-band .si-btn--dark:hover{background:#000;box-shadow:0 10px 30px -10px rgba(0,0,0,.5)}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
@media(prefers-reduced-motion:no-preference){
  .si-section{--reveal-y:18px}
  .si-section>*,.si-section .si-section__head,.si-section .si-section__title,.si-section .si-niche-grid,.si-section .si-step-grid,.si-section .si-product-grid,.si-section .si-trust-grid{
    animation:si-rise .7s var(--si-ease-out) both
  }
  .si-hero__in>*{animation:si-rise .8s var(--si-ease-out) both}
  .si-hero__in>*:nth-child(1){animation-delay:.05s}
  .si-hero__in>*:nth-child(2){animation-delay:.14s}
  .si-hero__in>*:nth-child(3){animation-delay:.22s}
  .si-hero__in>*:nth-child(4){animation-delay:.32s}
  .si-hero__in>*:nth-child(5){animation-delay:.42s}
  .si-niche-grid>*{animation:si-rise .7s var(--si-ease-out) both}
  .si-niche-grid>*:nth-child(1){animation-delay:.05s}
  .si-niche-grid>*:nth-child(2){animation-delay:.15s}
  .si-niche-grid>*:nth-child(3){animation-delay:.25s}
  .si-niche-grid>*:nth-child(4){animation-delay:.35s}
  .si-step-grid>*{animation:si-rise .7s var(--si-ease-out) both}
  .si-step-grid>*:nth-child(2){animation-delay:.12s}
  .si-step-grid>*:nth-child(3){animation-delay:.22s}
  .si-product-grid>*{animation:si-rise .7s var(--si-ease-out) both}
  .si-product-grid>*:nth-child(1){animation-delay:.05s}
  .si-product-grid>*:nth-child(2){animation-delay:.12s}
  .si-product-grid>*:nth-child(3){animation-delay:.19s}
  .si-product-grid>*:nth-child(4){animation-delay:.26s}
  .si-trust-grid>*{animation:si-rise .7s var(--si-ease-out) both}
  .si-trust-grid>*:nth-child(2){animation-delay:.1s}
  .si-trust-grid>*:nth-child(3){animation-delay:.2s}
  .si-trust-grid>*:nth-child(4){animation-delay:.3s}
  @keyframes si-rise{
    from{opacity:0;transform:translateY(18px)}
    to{opacity:1;transform:none}
  }
}

/* ============================================================
   MOBILE
   ============================================================ */
@media(max-width:860px){
  .si-niche-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;min-height:0}
  .si-niche-card:first-child{grid-column:span 2;grid-row:auto;min-height:280px}
  .si-step-grid{grid-template-columns:1fr;gap:32px}
  .si-step-grid::before{display:none}
  .si-step{padding-left:0;text-align:center}
  .si-step__n{margin-left:auto;margin-right:auto;display:grid}
  .si-step p{margin-left:auto;margin-right:auto}
}
@media(max-width:540px){
  .si-niche-grid{grid-template-columns:1fr}
  .si-niche-card,.si-niche-card:first-child{min-height:200px;padding:22px}
  .si-product-grid{grid-template-columns:1fr 1fr;gap:14px}
  .si-pcard__body{padding:16px}
  .si-pcard__title{font-size:.96rem}
}

/* ===== Homepage hero slider ===== */
.si-hero-slider{position:relative;overflow:hidden;background:var(--si-ink,#232323)}
.si-hero-slider__track{position:relative;display:grid}
/* Slides stack in one grid cell and crossfade. Visibility is delayed off so the
   outgoing slide stays painted through the fade (true crossfade, not fade-to-dark). */
.si-hero-slide{grid-area:1/1;position:relative;min-height:clamp(440px,62vh,640px);
  display:flex;align-items:center;overflow:hidden;z-index:0;
  opacity:0;visibility:hidden;
  transition:opacity .8s var(--si-ease,ease),visibility 0s linear .8s}
.si-hero-slide.is-active{opacity:1;visibility:visible;z-index:1;
  transition:opacity .8s var(--si-ease,ease),visibility 0s linear 0s}
@media (prefers-reduced-motion: reduce){.si-hero-slide{transition:opacity .2s linear}}
/* Background lives on a ::before layer so Ken Burns scales the image, never the text. */
.si-hero-slide::before{content:"";position:absolute;inset:0;z-index:0;
  background-image:var(--si-slide-bg,none);background-size:cover;background-position:center;
  transform:scale(1.001);transform-origin:50% 50%;will-change:transform}
.si-hero-slide__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(18,18,18,.9) 0%,rgba(18,18,18,.7) 42%,rgba(18,18,18,.36) 100%)}
.si-hero-slide__in{position:relative;z-index:2;max-width:1200px;width:100%;margin:0 auto;padding:0 24px;color:#fff}
.si-hero-slide__title{color:#fff;font-size:clamp(2.4rem,5.6vw,4.4rem);line-height:1.03;letter-spacing:-.03em;margin:.3em 0;max-width:18ch}
.si-hero-slide__title .si-accent{color:var(--si-orange)}
.si-hero-slide__price{display:flex;align-items:baseline;gap:8px;color:#fff;font-weight:700;font-size:1.5rem;margin:0 0 18px}
.si-hero-slide__price span{font-size:.8rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#cfc9c1}

/* Motion — Ken Burns zoom + staggered content reveal. Keyed on .is-active so each
   slide re-animates every time it becomes active. All disabled under reduced-motion. */
@media (prefers-reduced-motion: no-preference){
  .si-hero-slide.is-active::before{animation:si-kenburns 9s var(--si-ease-out,ease-out) forwards}
  .si-hero-slide.is-active .si-hero-slide__in > *{animation:si-rise .62s var(--si-ease-out,ease-out) both}
  .si-hero-slide.is-active .si-hero-slide__in > *:nth-child(1){animation-delay:.12s}
  .si-hero-slide.is-active .si-hero-slide__in > *:nth-child(2){animation-delay:.2s}
  .si-hero-slide.is-active .si-hero-slide__in > *:nth-child(3){animation-delay:.28s}
  .si-hero-slide.is-active .si-hero-slide__in > *:nth-child(4){animation-delay:.36s}
  .si-hero-slide.is-active .si-hero-slide__in > *:nth-child(5){animation-delay:.44s}
}
@keyframes si-kenburns{from{transform:scale(1.001)}to{transform:scale(1.08)}}
@keyframes si-rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* arrows — glass circles. Reset button chrome so Astra's button padding can't inflate them. */
.si-hero-slider__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;
  -webkit-appearance:none;appearance:none;padding:0;margin:0;box-shadow:none;
  width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.32);
  background:rgba(18,18,18,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  color:#fff;display:grid;place-items:center;cursor:pointer;
  transition:background .25s var(--si-ease,ease),border-color .25s,transform .25s}
.si-hero-slider__arrow:hover{background:var(--si-orange);border-color:var(--si-orange);transform:translateY(-50%) scale(1.07)}
.si-hero-slider__arrow:active{transform:translateY(-50%) scale(.95)}
.si-hero-slider__arrow svg{width:22px;height:22px}
.si-hero-slider__arrow.is-prev{left:22px}
.si-hero-slider__arrow.is-next{right:22px}
.si-hero-slider__arrow:focus-visible{outline:2px solid #fff;outline-offset:2px}

/* dots — 10px circles that expand into a progress pill when active. The button-chrome
   reset (padding/appearance) is what fixes the giant-oval bug: Astra's global
   button{padding:15px 30px} was inflating the 10px dots to 60×30 ellipses. */
.si-hero-slider__dots{position:absolute;left:0;right:0;bottom:22px;z-index:6;
  display:flex;justify-content:center;align-items:center;gap:9px}
.si-hero-slider__dot{
  -webkit-appearance:none;appearance:none;margin:0;padding:0;box-shadow:none;line-height:0;
  position:relative;overflow:hidden;
  width:10px;height:10px;border-radius:999px;border:0;cursor:pointer;
  background:rgba(255,255,255,.42);
  transition:width .45s var(--si-ease-out,ease-out),background .3s}
.si-hero-slider__dot:hover{background:rgba(255,255,255,.72)}
.si-hero-slider__dot.is-active{width:34px;background:rgba(255,255,255,.3)}
/* fill = autoplay progress; solid when not autoplaying or under reduced-motion */
.si-hero-slider__dot::after{content:"";position:absolute;inset:0;border-radius:inherit;
  background:var(--si-orange);transform:scaleX(0);transform-origin:left center}
.si-hero-slider__dot.is-active::after{transform:scaleX(1)}
@media (prefers-reduced-motion: no-preference){
  .si-hero-slider.is-autoplay .si-hero-slider__dot.is-active::after{
    transform:scaleX(0);animation:si-dotfill var(--si-interval,6000ms) linear forwards}
  .si-hero-slider.is-autoplay.is-paused .si-hero-slider__dot.is-active::after{animation-play-state:paused}
}
@keyframes si-dotfill{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.si-hero-slider__dot:focus-visible{outline:2px solid #fff;outline-offset:3px}

/* trust bar under the slider */
.si-hero-trust-bar{background:var(--si-ink,#232323);border-top:1px solid rgba(255,255,255,.08)}
.si-hero-trust-bar__in{max-width:1200px;margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap}
@media (max-width:700px){
  .si-hero-slide__scrim{background:linear-gradient(180deg,rgba(18,18,18,.46),rgba(18,18,18,.84))}
  .si-hero-slider__arrow{display:none}
  .si-hero-slide__title{font-size:clamp(2rem,8vw,2.8rem)}
}
