/* ============================================================
   Humlelunda - sektioner, kort och WooCommerce
   ============================================================ */

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; }
.hero__blob1 { position: absolute; left: -10rem; top: 2.5rem; width: 34rem; height: 34rem; border-radius: 99px; filter: blur(60px); opacity: 0.6;
  background: radial-gradient(circle, color-mix(in oklab, var(--honey) 26%, transparent), transparent 70%); }
.hero__blob2 { position: absolute; right: -8rem; bottom: 0; width: 30rem; height: 30rem; border-radius: 99px; filter: blur(60px); opacity: 0.5;
  background: radial-gradient(circle, color-mix(in oklab, var(--sage) 40%, transparent), transparent 70%); }
.hero__inner { position: relative; z-index: 2; display: grid; gap: 2.5rem; align-items: center; min-height: 92vh; padding-top: calc(var(--header-h) + 2rem); padding-bottom: 4rem; }
@media (min-width: 1024px) { .hero__inner { grid-template-columns: 1.05fr 0.95fr; gap: 1.5rem; } }
.hero h1 { font-size: clamp(2.6rem, 6vw, 4.7rem); line-height: 0.98; color: var(--soil); }
.hero h1 .accent { display: block; font-style: italic; color: var(--terracotta); }
.hero__text p { margin-top: 1.5rem; max-width: 28rem; font-size: 1.125rem; color: var(--clay-deep); }
.hero__cta { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: 0.75rem; }
.hero__trust { margin-top: 2.5rem; display: flex; align-items: center; gap: 1.5rem; font-size: 0.9rem; color: var(--clay-deep); }
.hero__trust .stars { color: var(--honey); }
.hero__media { position: relative; height: 26rem; }
@media (min-width: 640px) { .hero__media { height: 34rem; } }
@media (min-width: 1024px) { .hero__media { height: 42rem; } }
.hero__img-main { position: absolute; right: 0; top: 1.5rem; width: 82%; height: 78%; overflow: hidden; box-shadow: var(--shadow-lift);
  border-radius: 58% 42% 47% 53% / 45% 52% 48% 55%; }
.hero__img-main img { width: 100%; height: 100%; object-fit: cover; }
.hero__img-small { position: absolute; left: 0; bottom: 0.5rem; width: 52%; height: 42%; overflow: hidden; border-radius: 2rem; box-shadow: var(--shadow-lift); border: 4px solid var(--cream); }
.hero__img-small img { width: 100%; height: 100%; object-fit: cover; }
.hero__logo { position: absolute; left: 0.5rem; top: 0.5rem; width: 92px; }
@media (min-width: 1024px) { .hero__logo { left: 2rem; } }
.hero__bee { position: absolute; width: 2.5rem; }
.hero__bee--a { right: 1.5rem; top: 0.5rem; }
.hero__bee--b { right: 2.5rem; bottom: 4rem; width: 1.75rem; }
.scroll-cue { position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%); display: none; flex-direction: column; align-items: center; gap: 0.5rem; color: var(--clay-deep); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.2em; }
@media (min-width: 1024px) { .scroll-cue { display: flex; } }

/* ---------- Section heading ---------- */
.sec-head { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 3rem; }
.sec-head.center { align-items: center; text-align: center; max-width: 42rem; margin-inline: auto; }
.sec-head h2 { font-size: clamp(2rem, 4vw, 3rem); color: inherit; }
.sec-head__row { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 1.5rem; margin-bottom: 3rem; }

/* ---------- Story ---------- */
.story { display: grid; gap: 3rem; align-items: center; }
@media (min-width: 1024px) { .story { grid-template-columns: 1fr 1fr; gap: 4rem; } }
.story__media { position: relative; }
.story__media .frame { position: relative; aspect-ratio: 4/5; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lift); }
.story__media .frame img { width: 100%; height: 100%; object-fit: cover; }
.story__badge { position: absolute; bottom: -1.5rem; right: -0.75rem; padding: 1rem 1.5rem; border-radius: var(--radius); background: color-mix(in oklab, var(--paper) 80%, transparent); backdrop-filter: blur(14px); box-shadow: var(--shadow-soft); }
.story__badge strong { display: block; font-family: var(--font-display); font-size: 1.85rem; color: var(--terracotta-deep); }
.story__badge span { font-size: 0.85rem; color: var(--clay-deep); }
.stat-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; border-block: 1px solid color-mix(in oklab, var(--soil) 10%, transparent); padding-block: 1.5rem; margin-block: 2rem; }
.stat-row .v { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2rem); color: var(--terracotta-deep); line-height: 1; }
.stat-row .l { margin-top: 0.5rem; font-size: 0.85rem; color: var(--clay-deep); }

/* ---------- Kategori-rutnat ---------- */
.cat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
@media (min-width: 768px) { .cat-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .cat-grid { grid-template-columns: repeat(4, 1fr); } }
.cat-card { position: relative; aspect-ratio: 4/5; border-radius: var(--radius); overflow: hidden; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); display: block; }
.cat-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease); }
.cat-card:hover img { transform: scale(1.1); }
.cat-card .veil { position: absolute; inset: 0; background: linear-gradient(to top, color-mix(in oklab, var(--soil) 90%, transparent), transparent 70%); }
.cat-card .label { position: absolute; inset-inline: 0; bottom: 0; padding: 1.25rem; color: var(--cream); }
.cat-card .label .tag { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.2em; color: var(--honey-soft); }
.cat-card .label h3 { font-size: 1.5rem; display: flex; align-items: center; gap: 0.5rem; }
.cat-card .label .arrow { transition: transform 0.5s var(--ease); }
.cat-card:hover .label .arrow { transform: translateX(4px); }
.cat-card--cta { background: var(--soil); color: var(--cream); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.75rem; text-align: center; padding: 1.5rem; }
.cat-card--cta:hover { background: var(--soil-deep); }
.cat-card--cta .ring { display: grid; place-items: center; width: 3rem; height: 3rem; border-radius: 99px; border: 1px solid color-mix(in oklab, var(--cream) 30%, transparent); }

/* ---------- Produktkort ---------- */
.prod-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
@media (min-width: 1024px) { .prod-grid { grid-template-columns: repeat(4, 1fr); } }
.prod-grid.cols-3 { grid-template-columns: repeat(2, 1fr); }
@media (min-width: 1024px) { .prod-grid.cols-3 { grid-template-columns: repeat(3, 1fr); } }
.pcard { position: relative; display: flex; flex-direction: column; overflow: hidden; border-radius: var(--radius); background: var(--paper); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 8%, transparent); transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease); }
.pcard:hover { transform: translateY(-6px); box-shadow: var(--shadow-lift); }
.pcard__media { position: relative; aspect-ratio: 1; overflow: hidden; }
.pcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease); }
.pcard:hover .pcard__media img { transform: scale(1.05); }
.pcard__art { position: absolute; inset: 0; display: grid; place-items: center; padding: 2rem; }
.pcard__art svg { width: 68%; height: 68%; transition: transform 0.7s var(--ease); }
.pcard:hover .pcard__art svg { transform: scale(1.1) rotate(-3deg); }
.pcard__badge { position: absolute; left: 0.75rem; top: 0.75rem; padding: 0.25rem 0.75rem; border-radius: 99px; background: color-mix(in oklab, var(--soil) 90%, transparent); color: var(--cream); font-size: 0.72rem; font-weight: 600; }
.pcard__add { position: absolute; right: 0.75rem; bottom: 0.75rem; z-index: 3; display: grid; place-items: center; width: 2.75rem; height: 2.75rem; border-radius: 99px; background: var(--terracotta); color: var(--cream); border: 0; box-shadow: var(--shadow-soft); transition: 0.3s; }
.pcard__add:hover { background: var(--terracotta-deep); transform: scale(1.1); }
.pcard__body { display: flex; flex-direction: column; flex: 1; padding: 1.25rem; }
.pcard__cat { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em; color: var(--clay-deep); margin-bottom: 0.4rem; }
.pcard__title { font-family: var(--font-display); font-size: 1.25rem; color: var(--soil); line-height: 1.15; }
.pcard__blurb { margin-top: 0.25rem; font-size: 0.875rem; color: var(--clay-deep); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pcard__price { margin-top: 0.75rem; display: flex; align-items: baseline; gap: 0.4rem; }
.pcard__price .amt { font-family: var(--font-display); font-size: 1.15rem; color: var(--terracotta-deep); }
.pcard__price .unit { font-size: 0.85rem; color: var(--clay); }
.pcard__link { position: absolute; inset: 0; z-index: 1; }

/* ---------- Filosofi ---------- */
.principles { display: grid; gap: 1.5rem; margin-top: 2.5rem; }
.principle { display: flex; gap: 1.25rem; border-bottom: 1px solid color-mix(in oklab, var(--cream) 12%, transparent); padding-bottom: 1.5rem; }
.principle .num { font-family: var(--font-display); font-size: 1.5rem; color: var(--honey); }
.principle h3 { font-size: 1.25rem; color: var(--cream); }
.principle p { color: color-mix(in oklab, var(--cream) 65%, transparent); margin-top: 0.25rem; }
.philo-quote { position: absolute; left: -0.75rem; bottom: 2rem; max-width: 15rem; padding: 1.25rem 1.5rem; border-radius: var(--radius); background: color-mix(in oklab, var(--paper) 90%, transparent); color: var(--soil); box-shadow: var(--shadow-lift); }
.philo-quote p { font-family: var(--font-display); font-size: 1.1rem; line-height: 1.3; }

/* ---------- Nyhetsbrev-CTA ---------- */
.nl-cta { position: relative; overflow: hidden; border-radius: var(--radius-lg); background: var(--soil); color: var(--cream); }
.nl-cta .glow { position: absolute; right: -5rem; top: -5rem; width: 20rem; height: 20rem; border-radius: 99px; filter: blur(60px); opacity: 0.5; background: radial-gradient(circle, color-mix(in oklab, var(--honey) 50%, transparent), transparent 70%); }
.nl-cta__grid { position: relative; z-index: 2; display: grid; gap: 2rem; align-items: center; }
@media (min-width: 1024px) { .nl-cta__grid { grid-template-columns: 1fr 1fr; } }
.nl-cta__body { padding: 2rem; }
@media (min-width: 768px) { .nl-cta__body { padding: 3.5rem; } }
.nl-cta__perks { display: flex; flex-wrap: wrap; gap: 0.5rem 1.5rem; margin-top: 1.5rem; font-size: 0.9rem; color: color-mix(in oklab, var(--cream) 70%, transparent); list-style: none; padding: 0; }
.nl-cta__perks .check { color: var(--honey); margin-right: 0.4rem; }
.nl-cta__media { position: relative; height: 14rem; }
@media (min-width: 1024px) { .nl-cta__media { height: 100%; min-height: 26rem; } }
.nl-cta__media img { width: 100%; height: 100%; object-fit: cover; }
.nl-cta__media .fade { position: absolute; inset: 0; background: linear-gradient(to right, var(--soil), transparent); }

/* ---------- Blogg ---------- */
.blog-grid { display: grid; gap: 2rem; }
@media (min-width: 768px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }
.bcard { display: block; }
.bcard__media { position: relative; aspect-ratio: 16/11; border-radius: var(--radius); overflow: hidden; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); }
.bcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease); }
.bcard:hover .bcard__media img { transform: scale(1.05); }
.bcard__cat { position: absolute; left: 0.75rem; top: 0.75rem; padding: 0.25rem 0.75rem; border-radius: 99px; background: color-mix(in oklab, var(--cream) 90%, transparent); color: var(--soil); font-size: 0.72rem; font-weight: 600; }
.bcard__meta { margin-top: 1rem; font-size: 0.85rem; color: var(--clay-deep); }
.bcard__title { margin-top: 0.35rem; font-family: var(--font-display); font-size: 1.25rem; color: var(--soil); transition: color 0.2s; }
.bcard:hover .bcard__title { color: var(--terracotta-deep); }
.bcard__excerpt { margin-top: 0.5rem; color: var(--clay-deep); }
.bcard__more { margin-top: 0.75rem; display: inline-flex; gap: 0.4rem; font-size: 0.875rem; font-weight: 600; color: var(--terracotta-deep); }

/* ---------- Sidhuvud (inner pages) ---------- */
.page-head { padding-top: calc(var(--header-h) + 3rem); padding-bottom: 1.5rem; }
.page-head h1 { font-size: clamp(2.4rem, 5vw, 4rem); color: var(--soil); }
.page-head .lead { margin-top: 1.25rem; }
.breadcrumb { display: flex; flex-wrap: wrap; gap: 0.5rem; font-size: 0.875rem; color: var(--clay-deep); }
.breadcrumb a:hover { color: var(--terracotta-deep); }

/* ---------- Artikel ---------- */
.article-body { max-width: 42rem; margin-inline: auto; }
.article-body p { font-size: 1.125rem; line-height: 1.8; color: color-mix(in oklab, var(--soil) 85%, transparent); margin-bottom: 1.25rem; }
.article-body h2 { font-size: 1.85rem; color: var(--soil); margin-top: 3rem; margin-bottom: 1rem; }
.article-body blockquote { margin: 2.5rem 0; border-left: 4px solid var(--honey); padding-left: 1.5rem; font-family: var(--font-display); font-style: italic; font-size: 1.5rem; line-height: 1.3; color: var(--soil); }

/* ---------- Tidslinje ---------- */
.timeline { position: relative; max-width: 48rem; margin-inline: auto; display: grid; gap: 2.5rem; }
.tl-item { display: grid; gap: 0.5rem; }
@media (min-width: 640px) { .tl-item { grid-template-columns: 7rem 1fr; gap: 2rem; } }
.tl-item .year { font-family: var(--font-display); font-size: 1.25rem; color: var(--terracotta-deep); }
.tl-item h3 { font-size: 1.5rem; color: var(--soil); }
.tl-item p { color: var(--clay-deep); margin-top: 0.5rem; }

/* ---------- Accordion (FAQ) ---------- */
.accordion { max-width: 48rem; margin-inline: auto; border-radius: var(--radius); background: var(--paper); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); overflow: hidden; }
.acc-item + .acc-item { border-top: 1px solid color-mix(in oklab, var(--soil) 10%, transparent); }
.acc-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.25rem 1.5rem; background: transparent; border: 0; text-align: left; font-family: var(--font-display); font-size: 1.15rem; color: var(--soil); }
.acc-q .plus { display: grid; place-items: center; width: 2rem; height: 2rem; border-radius: 99px; background: var(--sand); font-size: 1.25rem; transition: 0.3s; flex-shrink: 0; }
.acc-item.open .acc-q .plus { transform: rotate(45deg); background: var(--terracotta); color: var(--cream); }
.acc-a { max-height: 0; overflow: hidden; transition: max-height 0.35s var(--ease); }
.acc-a p { padding: 0 1.5rem 1.25rem; color: var(--clay-deep); line-height: 1.7; }

/* ---------- Formular ---------- */
.field label { display: block; font-size: 0.875rem; font-weight: 500; color: var(--soil); margin-bottom: 0.4rem; }
.field input, .field textarea, .field select { width: 100%; border-radius: 0.875rem; background: var(--paper); border: 0; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 15%, transparent); padding: 0.75rem 1rem; color: var(--soil); outline: none; transition: box-shadow 0.2s; font: inherit; }
.field input:focus, .field textarea:focus { box-shadow: inset 0 0 0 2px var(--terracotta); }
.form-card { border-radius: var(--radius); background: color-mix(in oklab, var(--paper) 60%, transparent); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); padding: 1.5rem; }
@media (min-width: 768px) { .form-card { padding: 2rem; } }
.info-card { border-radius: var(--radius); background: var(--soil); color: var(--cream); padding: 1.75rem; }
.info-card a { color: var(--cream); }
.info-card a:hover { color: var(--honey-soft); }

/* ---------- Plan-kort (veckobrev) ---------- */
.plans { display: grid; gap: 1.5rem; }
@media (min-width: 768px) { .plans { grid-template-columns: repeat(3, 1fr); } }
.plan { position: relative; display: flex; flex-direction: column; border-radius: var(--radius); background: var(--paper); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); padding: 2rem; }
.plan.feat { background: var(--soil); color: var(--cream); box-shadow: var(--shadow-lift); }
.plan .pop { position: absolute; top: -0.75rem; left: 50%; transform: translateX(-50%); background: var(--honey); color: var(--soil-deep); font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 0.25rem 1rem; border-radius: 99px; }
.plan h3 { font-family: var(--font-display); font-size: 1.5rem; }
.plan .price { font-family: var(--font-display); font-size: 2.25rem; margin-top: 1rem; }
.plan ul { list-style: none; padding: 0; margin: 1.5rem 0 2rem; display: grid; gap: 0.75rem; font-size: 0.9rem; }
.plan ul li { display: flex; gap: 0.6rem; align-items: center; }
.plan ul .check { display: grid; place-items: center; width: 1.25rem; height: 1.25rem; border-radius: 99px; background: color-mix(in oklab, var(--sage) 40%, transparent); color: var(--sage-deep); font-size: 0.7rem; flex-shrink: 0; }
.plan.feat ul .check { background: var(--honey); color: var(--soil-deep); }

/* ---------- Steg-kort ---------- */
.steps { display: grid; gap: 1.5rem; }
@media (min-width: 640px) { .steps { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .steps { grid-template-columns: repeat(4, 1fr); } }
.step { border-radius: var(--radius); background: var(--paper); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); padding: 1.75rem; }
.step .num { font-family: var(--font-display); font-size: 1.85rem; color: var(--honey); }
.step h3 { font-size: 1.25rem; margin-top: 0.75rem; }
.step p { color: var(--clay-deep); margin-top: 0.35rem; }

/* ============================================================
   WooCommerce
   ============================================================ */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews {
  border-radius: var(--radius); background: var(--paper); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent);
  border-top: 3px solid var(--terracotta); padding: 1rem 1.25rem; list-style: none; margin-bottom: 1.5rem;
}
.woocommerce-error { border-top-color: #c0392b; }
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce #respond input#submit,
.woocommerce a.button.alt, .woocommerce button.button.alt {
  background: var(--terracotta); color: var(--cream); border-radius: 99px; padding: 0.8rem 1.6rem; font-weight: 600; border: 0; transition: 0.2s;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce button.button.alt:hover { background: var(--terracotta-deep); }
.woocommerce .price, .woocommerce-Price-amount { color: var(--terracotta-deep); font-family: var(--font-display); }

/* Shop-rutnat (vi anvander egna .pcard via override, men sakra default-loop ocksa) */
.woocommerce ul.products { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; margin: 0; padding: 0; list-style: none; }
@media (min-width: 1024px) { .woocommerce ul.products { grid-template-columns: repeat(4, 1fr); } }
.woocommerce ul.products li.product { margin: 0; width: auto; }

/* Single product */
.woocommerce div.product { display: grid; gap: 2.5rem; }
@media (min-width: 1024px) { .woocommerce div.product { grid-template-columns: 1fr 1fr; gap: 4rem; } }
.woocommerce div.product .woocommerce-product-gallery { margin: 0; }
.woocommerce div.product .woocommerce-product-gallery__image img,
.single-product .product-art-wrap { border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); overflow: hidden; }
.single-product .product-art-wrap { aspect-ratio: 1; display: grid; place-items: center; padding: 4rem; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); }
.woocommerce div.product .product_title { font-size: clamp(2rem, 4vw, 3rem); color: var(--soil); }
.woocommerce div.product p.price, .woocommerce div.product span.price { font-size: 1.75rem; }
.woocommerce .quantity .qty { border-radius: 99px; border: 1px solid color-mix(in oklab, var(--soil) 15%, transparent); padding: 0.6rem; width: 4.5rem; text-align: center; background: var(--paper); }
.woocommerce div.product form.cart { margin-top: 1.5rem; display: flex; gap: 0.75rem; align-items: center; }
.woocommerce div.product .woocommerce-product-details__short-description { color: var(--clay-deep); font-size: 1.05rem; }

/* Cart + checkout tables */
.woocommerce table.shop_table { border-radius: var(--radius); border-collapse: separate; border-spacing: 0; overflow: hidden; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--soil) 10%, transparent); background: var(--paper); }
.woocommerce table.shop_table th { font-family: var(--font-body); color: var(--soil); }
.woocommerce .cart_totals h2, .woocommerce-checkout h3 { font-family: var(--font-display); color: var(--soil); }
.woocommerce-checkout #payment { background: var(--paper); border-radius: var(--radius); }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .select2-container .select2-selection {
  border-radius: 0.75rem !important; border: 1px solid color-mix(in oklab, var(--soil) 15%, transparent) !important; padding: 0.7rem 0.9rem !important; background: var(--paper);
}
#add_payment_method #payment, .woocommerce-cart #payment, .woocommerce-checkout #payment { border-radius: var(--radius); }
.woocommerce-checkout #place_order { width: 100%; font-size: 1.05rem; }

/* Doldfalt for snabb-add i loopen (vi anvander egen markup) */
.add_to_cart_button.added::after { display: none; }

/* ---------- Scrollande humla + notis ---------- */
.scroll-bee { position: fixed; width: 42px; z-index: 30; pointer-events: none; display: none; filter: drop-shadow(0 6px 10px rgb(58 46 37 / 0.25)); transition: opacity 0.4s ease; }
@media (max-width: 1023px) { .scroll-bee { display: none !important; } }
.h2-toast { position: fixed; bottom: 1.5rem; left: 50%; transform: translate(-50%, 1.5rem); z-index: 80; display: flex; align-items: center; gap: 0.6rem; background: var(--soil); color: var(--cream); padding: 0.85rem 1.5rem; border-radius: 99px; box-shadow: var(--shadow-lift); opacity: 0; transition: 0.35s var(--ease); font-size: 0.9rem; font-weight: 500; pointer-events: none; }
.h2-toast.show { opacity: 1; transform: translate(-50%, 0); }
.h2-toast .tick { display: grid; place-items: center; width: 1.5rem; height: 1.5rem; border-radius: 99px; background: var(--honey); color: var(--soil-deep); }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }
  .reveal, .stagger > * { opacity: 1 !important; transform: none !important; }
}
