/*
 Theme Name:   BNR17 Child
 Theme URI:    https://bnr17.my
 Description:  BNR17 MY child theme of Blocksy. K-Health premium brand for Medibeu Sdn Bhd.
 Author:       Medibeu Sdn Bhd
 Author URI:   https://bnr17.my
 Template:     blocksy
 Version:      1.1.0
 Text Domain:  bnr17-child
 Tags:         woocommerce, multilingual
*/

/* ==========================================================================
   BRAND TOKENS — BNR17 MY v1.1 (Mitopure-system redesign)
   ========================================================================== */

:root {
  /* --- Colour palette --- */
  --bnr-teal:         #0F766E;
  --bnr-teal-hover:   #0D6460;
  --bnr-teal-light:   #CCFBF1;
  --bnr-lime:         #84CC16;
  --bnr-dark:         #1A1A2E;
  --bnr-dark-80:      rgba(26,26,46,.8);
  --bnr-bg:           #FAF8F5;
  --bnr-white:        #FFFFFF;
  --bnr-border:       #E5E7EB;
  --bnr-muted:        #6B7280;
  --bnr-light-grey:   #F3F4F6;

  /* legacy aliases kept for WC / existing blocks */
  --bnr-green:        #0F766E;
  --bnr-green-mid:    #0D6460;
  --bnr-green-light:  #CCFBF1;
  --bnr-charcoal:     #1A1A2E;
  --bnr-slate:        #6B7280;
  --bnr-mist:         #FAF8F5;
  --bnr-coral:        #0F766E;
  --bnr-coral-hover:  #0D6460;
  --bnr-gold:         #84CC16;

  /* --- Typography --- */
  --bnr-font-serif:   'Playfair Display', Georgia, serif;
  --bnr-font-body:    'Inter', 'DM Sans', system-ui, sans-serif;
  --bnr-font-head:    var(--bnr-font-serif);

  --bnr-size-xs:      0.75rem;
  --bnr-size-sm:      0.875rem;
  --bnr-size-base:    1.0625rem;   /* 17px */
  --bnr-size-lg:      1.125rem;
  --bnr-size-xl:      1.5rem;
  --bnr-size-2xl:     2rem;
  --bnr-size-3xl:     2.5rem;
  --bnr-size-4xl:     4rem;
  --bnr-size-stat:    7.5rem;

  --bnr-weight-normal: 400;
  --bnr-weight-medium: 500;
  --bnr-weight-semi:   600;
  --bnr-weight-bold:   700;

  --bnr-leading-tight:  1.15;
  --bnr-leading-snug:   1.3;
  --bnr-leading-normal: 1.7;

  /* --- Spacing --- */
  --bnr-section-v:    100px;
  --bnr-section-h:    clamp(1.5rem, 5vw, 0px);
  --bnr-container:    1200px;
  --bnr-content:      720px;
  --bnr-narrow:       560px;

  /* --- Borders & radius --- */
  --bnr-radius-btn:  4px;
  --bnr-radius-sm:   4px;
  --bnr-radius-md:   8px;
  --bnr-radius-lg:   16px;
  --bnr-radius-pill: 999px;

  /* --- Shadows --- */
  --bnr-shadow-sm:   0 2px 8px rgba(26,26,46,.07);
  --bnr-shadow-md:   0 4px 24px rgba(26,26,46,.10);
  --bnr-shadow-lg:   0 8px 48px rgba(26,26,46,.13);
  --bnr-shadow-nav:  0 2px 16px rgba(26,26,46,.09);

  /* --- Transitions --- */
  --bnr-ease:          cubic-bezier(0.4, 0, 0.2, 1);
  --bnr-duration-fast: 150ms;
  --bnr-duration-base: 250ms;
  --bnr-duration-slow: 400ms;
}

/* ==========================================================================
   BASE OVERRIDES
   ========================================================================== */

html { scroll-behavior: smooth; }

body {
  background-color: var(--bnr-bg);
  color: var(--bnr-dark);
  font-family: var(--bnr-font-body);
  font-size: var(--bnr-size-base);
  line-height: var(--bnr-leading-normal);
  -webkit-font-smoothing: antialiased;
}

h1, h2 {
  font-family: var(--bnr-font-serif);
  font-weight: var(--bnr-weight-bold);
  line-height: var(--bnr-leading-tight);
  color: var(--bnr-dark);
}

h3, h4, h5, h6 {
  font-family: var(--bnr-font-body);
  font-weight: var(--bnr-weight-semi);
  line-height: var(--bnr-leading-snug);
  color: var(--bnr-dark);
}

a {
  color: var(--bnr-teal);
  transition: color var(--bnr-duration-fast) var(--bnr-ease);
}
a:hover { color: var(--bnr-teal-hover); }

img { max-width: 100%; height: auto; }

/* Blocksy content width override */
.ct-container,
.alignwide { max-width: var(--bnr-container) !important; }

/* ==========================================================================
   NAVIGATION — fixed, shrinks on scroll
   ========================================================================== */

/* Blocksy header wrapper */
.site-header,
header.site-header {
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--bnr-white) !important;
  border-bottom: 1px solid var(--bnr-border);
  transition: height var(--bnr-duration-base) var(--bnr-ease),
              box-shadow var(--bnr-duration-base) var(--bnr-ease);
}

/* Push page content below fixed nav */
body { padding-top: 80px; }

/* Nav inner height */
.ct-header,
.site-header .ct-header {
  height: 80px;
  transition: height var(--bnr-duration-base) var(--bnr-ease);
}

/* Scrolled state — JS adds .bnr-scrolled to <body> */
body.bnr-scrolled .site-header { box-shadow: var(--bnr-shadow-nav); }
body.bnr-scrolled .ct-header   { height: 60px; }

/* Nav CTA button */
.bnr-nav-cta,
.site-header .bnr-nav-cta {
  display: inline-block;
  background: var(--bnr-teal) !important;
  color: var(--bnr-white) !important;
  font-weight: var(--bnr-weight-semi);
  font-size: .9rem;
  padding: .55rem 1.25rem;
  border-radius: var(--bnr-radius-btn);
  text-decoration: none;
  white-space: nowrap;
  transition: background var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-nav-cta:hover { background: var(--bnr-teal-hover) !important; color: var(--bnr-white) !important; }

/* ==========================================================================
   BUTTONS — global overrides
   ========================================================================== */

.wp-block-button__link,
.button,
button.alt,
input[type="submit"],
.wc-block-components-button {
  background-color: var(--bnr-teal) !important;
  color: var(--bnr-white) !important;
  border-radius: var(--bnr-radius-btn) !important;
  font-weight: var(--bnr-weight-semi);
  font-family: var(--bnr-font-body);
  border: none;
  transition: background-color var(--bnr-duration-fast) var(--bnr-ease),
              transform var(--bnr-duration-fast) var(--bnr-ease);
}
.wp-block-button__link:hover,
.button:hover,
button.alt:hover,
input[type="submit"]:hover {
  background-color: var(--bnr-teal-hover) !important;
  transform: translateY(-1px);
}

/* Outline button variant */
.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: var(--bnr-teal) !important;
  border: 2px solid var(--bnr-teal) !important;
}
.is-style-outline .wp-block-button__link:hover {
  background: var(--bnr-teal) !important;
  color: var(--bnr-white) !important;
}

/* White outline variant (on dark backgrounds) */
.bnr-btn-white-outline .wp-block-button__link,
.bnr-btn-white-outline {
  background: transparent !important;
  color: var(--bnr-white) !important;
  border: 2px solid rgba(255,255,255,.7) !important;
}
.bnr-btn-white-outline .wp-block-button__link:hover,
.bnr-btn-white-outline:hover {
  background: rgba(255,255,255,.1) !important;
  border-color: var(--bnr-white) !important;
}

/* ==========================================================================
   HERO SECTION  (.bnr-hero)
   ========================================================================== */

.bnr-hero {
  position: relative;
  width: 100%;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: var(--bnr-dark);
}

.bnr-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center 30%;
  background-repeat: no-repeat;
}

.bnr-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    rgba(26,26,46,.72) 0%,
    rgba(26,26,46,.45) 60%,
    rgba(26,26,46,.18) 100%
  );
}

.bnr-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--bnr-container);
  margin: 0 auto;
  padding: 140px clamp(1.5rem, 5vw, 4rem) 80px;
}

.bnr-hero__content {
  max-width: 600px;
}

.bnr-hero__headline {
  font-family: var(--bnr-font-serif);
  font-size: clamp(2.5rem, 5.5vw, 4rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--bnr-white);
  margin: 0 0 1.25rem;
}

.bnr-hero__sub {
  font-size: 1.25rem;
  color: rgba(255,255,255,.85);
  line-height: 1.6;
  margin: 0 0 2rem;
  font-weight: 400;
}

.bnr-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: .875rem;
  margin-bottom: 2.5rem;
}

.bnr-hero__cta-primary {
  display: inline-block;
  background: var(--bnr-teal);
  color: var(--bnr-white) !important;
  font-weight: 600;
  font-size: 1rem;
  padding: .875rem 2rem;
  border-radius: var(--bnr-radius-btn);
  text-decoration: none;
  transition: background var(--bnr-duration-fast) var(--bnr-ease), transform var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-hero__cta-primary:hover { background: var(--bnr-teal-hover); transform: translateY(-1px); }

.bnr-hero__cta-secondary {
  display: inline-block;
  background: transparent;
  color: var(--bnr-white) !important;
  font-weight: 600;
  font-size: 1rem;
  padding: .875rem 2rem;
  border-radius: var(--bnr-radius-btn);
  border: 2px solid rgba(255,255,255,.65);
  text-decoration: none;
  transition: background var(--bnr-duration-fast) var(--bnr-ease), border-color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-hero__cta-secondary:hover { background: rgba(255,255,255,.1); border-color: var(--bnr-white); }

.bnr-hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}

.bnr-hero__trust-item {
  font-size: .75rem;
  font-weight: 600;
  color: rgba(255,255,255,.75);
  letter-spacing: .08em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.bnr-hero__trust-item::before {
  content: '✓';
  color: var(--bnr-lime);
  font-size: .9rem;
}

@media (max-width: 768px) {
  .bnr-hero { min-height: 80vh; }
  .bnr-hero__inner { padding: 120px 1.5rem 60px; }
  .bnr-hero__sub { font-size: 1.05rem; }
  .bnr-hero__ctas { flex-direction: column; }
  .bnr-hero__cta-primary,
  .bnr-hero__cta-secondary { text-align: center; }
}

/* ==========================================================================
   USP SPLIT SECTIONS  (.bnr-split)
   ========================================================================== */

.bnr-split {
  padding: var(--bnr-section-v) 0;
}

.bnr-split__inner {
  max-width: var(--bnr-container);
  margin: 0 auto;
  padding: 0 clamp(1.5rem, 5vw, 4rem);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(3rem, 6vw, 6rem);
  align-items: center;
}

.bnr-split--reversed .bnr-split__inner {
  direction: rtl;
}
.bnr-split--reversed .bnr-split__text,
.bnr-split--reversed .bnr-split__image {
  direction: ltr;
}

.bnr-split__image img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  border-radius: var(--bnr-radius-lg);
  display: block;
}

.bnr-split__eyebrow {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bnr-teal);
  margin: 0 0 .75rem;
}

.bnr-split__headline {
  font-family: var(--bnr-font-serif);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--bnr-dark);
  margin: 0 0 1.25rem;
}

.bnr-split__body {
  font-size: 1.0625rem;
  line-height: 1.75;
  color: #374151;
  margin: 0 0 1.75rem;
}

.bnr-split__link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 600;
  font-size: .95rem;
  color: var(--bnr-teal);
  text-decoration: none;
  border-bottom: 1px solid var(--bnr-teal-light);
  padding-bottom: 2px;
  transition: color var(--bnr-duration-fast) var(--bnr-ease), border-color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-split__link:hover { color: var(--bnr-teal-hover); border-color: var(--bnr-teal-hover); }

@media (max-width: 768px) {
  .bnr-split { padding: 60px 0; }
  .bnr-split__inner { grid-template-columns: 1fr; direction: ltr !important; }
  .bnr-split--reversed .bnr-split__text { order: 1; }
  .bnr-split--reversed .bnr-split__image { order: 2; }
  .bnr-split__image img { height: 280px; }
}

/* ==========================================================================
   CLINICAL EVIDENCE STRIP  (.bnr-stat-strip)
   ========================================================================== */

.bnr-stat-strip {
  background: var(--bnr-dark);
  padding: var(--bnr-section-v) clamp(1.5rem, 5vw, 4rem);
  text-align: center;
}

.bnr-stat-strip__stat {
  font-family: var(--bnr-font-serif);
  font-size: clamp(5rem, 12vw, 7.5rem);
  font-weight: 700;
  color: var(--bnr-white);
  line-height: 1;
  margin: 0 0 .5rem;
  letter-spacing: -0.02em;
}

.bnr-stat-strip__label {
  font-size: clamp(1rem, 2vw, 1.375rem);
  color: rgba(255,255,255,.85);
  font-weight: 400;
  max-width: 520px;
  margin: 0 auto .875rem;
  line-height: 1.5;
}

.bnr-stat-strip__citation {
  font-size: .875rem;
  color: rgba(255,255,255,.55);
  font-style: italic;
  margin: 0 auto 1rem;
  max-width: 560px;
}

.bnr-stat-strip__disclaimer {
  font-size: .7rem;
  color: rgba(255,255,255,.38);
  max-width: 480px;
  margin: 0 auto;
  line-height: 1.6;
}

@media (max-width: 768px) {
  .bnr-stat-strip { padding: 60px 1.5rem; }
}

/* ==========================================================================
   CREDENTIAL BADGES STRIP  (.bnr-badges)
   ========================================================================== */

.bnr-badges {
  background: var(--bnr-light-grey);
  padding: 56px clamp(1.5rem, 5vw, 4rem);
}

.bnr-badges__inner {
  max-width: var(--bnr-container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

.bnr-badge-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1.5rem 2rem;
  border-right: 1px solid var(--bnr-border);
}
.bnr-badge-item:last-child { border-right: none; }

.bnr-badge-item__icon {
  font-size: 1.75rem;
  margin-bottom: .625rem;
  line-height: 1;
}

.bnr-badge-item__label {
  font-size: .8125rem;
  font-weight: 700;
  color: var(--bnr-dark);
  letter-spacing: .03em;
  line-height: 1.4;
}

@media (max-width: 768px) {
  .bnr-badges { padding: 40px 1.5rem; }
  .bnr-badges__inner { grid-template-columns: repeat(2, 1fr); }
  .bnr-badge-item:nth-child(2) { border-right: none; }
  .bnr-badge-item:nth-child(1),
  .bnr-badge-item:nth-child(2) { border-bottom: 1px solid var(--bnr-border); }
}

/* ==========================================================================
   EXPERT QUOTE BLOCK  (.bnr-quote)
   ========================================================================== */

.bnr-quote {
  background: var(--bnr-bg);
  padding: var(--bnr-section-v) clamp(1.5rem, 5vw, 4rem);
}

.bnr-quote__inner {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
}

.bnr-quote__mark {
  font-family: var(--bnr-font-serif);
  font-size: 7rem;
  line-height: .6;
  color: var(--bnr-teal);
  opacity: .25;
  margin-bottom: .5rem;
  display: block;
  user-select: none;
  letter-spacing: -0.05em;
}

.bnr-quote__text {
  font-family: var(--bnr-font-serif);
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.65;
  color: var(--bnr-dark);
  margin: 0 0 1.5rem;
}

.bnr-quote__attr {
  font-size: .8125rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--bnr-muted);
}

@media (max-width: 768px) {
  .bnr-quote { padding: 60px 1.5rem; }
  .bnr-quote__mark { font-size: 5rem; }
}

/* ==========================================================================
   PRODUCT SECTION  (.bnr-product)
   ========================================================================== */

.bnr-product {
  background: var(--bnr-white);
  padding: var(--bnr-section-v) clamp(1.5rem, 5vw, 4rem);
}

.bnr-product__inner {
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
}

.bnr-product__image {
  width: 100%;
  max-width: 400px;
  margin: 0 auto 2.5rem;
  display: block;
}

.bnr-product__image img {
  width: 100%;
  height: auto;
  border-radius: var(--bnr-radius-lg);
}

.bnr-product__name {
  font-family: var(--bnr-font-serif);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--bnr-dark);
  margin: 0 0 .75rem;
}

.bnr-product__desc {
  font-size: 1.0625rem;
  color: #374151;
  line-height: 1.7;
  margin: 0 0 1.5rem;
}

.bnr-product__pricing {
  margin-bottom: 1.75rem;
}

.bnr-product__price-row {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: .5rem;
  margin-bottom: .375rem;
}

.bnr-product__price {
  font-size: 2rem;
  font-weight: 700;
  color: var(--bnr-dark);
}

.bnr-product__price-sub {
  font-size: .9rem;
  color: var(--bnr-muted);
}

.bnr-product__sub-price {
  font-size: .875rem;
  color: var(--bnr-teal);
  font-weight: 600;
}

.bnr-product__cta {
  display: block;
  width: 100%;
  background: var(--bnr-teal);
  color: var(--bnr-white);
  font-weight: 700;
  font-size: 1.0625rem;
  padding: 1rem 2rem;
  border-radius: var(--bnr-radius-btn);
  text-align: center;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: background var(--bnr-duration-fast) var(--bnr-ease), transform var(--bnr-duration-fast) var(--bnr-ease);
  margin-bottom: 1.25rem;
}
.bnr-product__cta:hover { background: var(--bnr-teal-hover); transform: translateY(-1px); color: var(--bnr-white); }

.bnr-product__micro-trust {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: .75rem 1.25rem;
}

.bnr-product__micro-trust-item {
  font-size: .76rem;
  font-weight: 600;
  color: var(--bnr-muted);
  letter-spacing: .03em;
  display: flex;
  align-items: center;
  gap: .3rem;
}
.bnr-product__micro-trust-item::before {
  content: '✓';
  color: var(--bnr-teal);
}

/* ==========================================================================
   FAQ ACCORDION  (.bnr-faq)
   ========================================================================== */

.bnr-faq {
  padding: var(--bnr-section-v) clamp(1.5rem, 5vw, 4rem);
  background: var(--bnr-bg);
}

.bnr-faq__inner {
  max-width: 720px;
  margin: 0 auto;
}

.bnr-faq__headline {
  font-family: var(--bnr-font-serif);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: 700;
  text-align: center;
  margin: 0 0 3rem;
  color: var(--bnr-dark);
}

.bnr-faq__item {
  border-bottom: 1px solid var(--bnr-border);
}
.bnr-faq__item:first-of-type { border-top: 1px solid var(--bnr-border); }

.bnr-faq__question {
  width: 100%;
  background: none;
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 0;
  text-align: left;
  font-family: var(--bnr-font-body);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--bnr-dark);
  cursor: pointer;
  transition: color var(--bnr-duration-fast) var(--bnr-ease);
  gap: 1rem;
}
.bnr-faq__question:hover { color: var(--bnr-teal); }

.bnr-faq__icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  position: relative;
  color: var(--bnr-teal);
}
.bnr-faq__icon::before,
.bnr-faq__icon::after {
  content: '';
  position: absolute;
  background: currentColor;
  border-radius: 2px;
  transition: transform var(--bnr-duration-base) var(--bnr-ease), opacity var(--bnr-duration-base) var(--bnr-ease);
}
.bnr-faq__icon::before { width: 20px; height: 2px; top: 50%; left: 0; transform: translateY(-50%); }
.bnr-faq__icon::after  { width: 2px; height: 20px; left: 50%; top: 0; transform: translateX(-50%); }

.bnr-faq__item.bnr-open .bnr-faq__icon::after { transform: translateX(-50%) rotate(90deg); opacity: 0; }

.bnr-faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--bnr-duration-slow) var(--bnr-ease);
}

.bnr-faq__item.bnr-open .bnr-faq__answer { max-height: 400px; }

.bnr-faq__answer-inner {
  padding: 0 0 1.5rem;
  font-size: 1rem;
  color: #374151;
  line-height: 1.75;
}
.bnr-faq__answer-inner a { color: var(--bnr-teal); text-decoration: underline; }

.bnr-faq__more {
  text-align: center;
  margin-top: 2.5rem;
}

.bnr-faq__more a {
  font-size: .9375rem;
  font-weight: 600;
  color: var(--bnr-teal);
  text-decoration: none;
  border-bottom: 1px solid var(--bnr-teal-light);
  padding-bottom: 2px;
  transition: border-color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-faq__more a:hover { border-color: var(--bnr-teal); }

@media (max-width: 768px) {
  .bnr-faq { padding: 60px 1.5rem; }
}

/* ==========================================================================
   FOOTER  (.bnr-footer)
   ========================================================================== */

.bnr-footer {
  background: var(--bnr-dark);
  color: var(--bnr-white);
  padding: var(--bnr-section-v) clamp(1.5rem, 5vw, 4rem) 0;
}

.bnr-footer__inner {
  max-width: var(--bnr-container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1.5fr;
  gap: clamp(2rem, 5vw, 5rem);
  padding-bottom: 4rem;
}

.bnr-footer__brand-tagline {
  font-size: .9375rem;
  color: rgba(255,255,255,.6);
  line-height: 1.6;
  margin: .875rem 0 1.5rem;
}

.bnr-footer__socials {
  display: flex;
  gap: .875rem;
}
.bnr-footer__socials a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.65);
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
  transition: border-color var(--bnr-duration-fast) var(--bnr-ease), color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-footer__socials a:hover { border-color: var(--bnr-white); color: var(--bnr-white); }

.bnr-footer__col-title {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin: 0 0 1.25rem;
}

.bnr-footer__links {
  list-style: none;
  padding: 0;
  margin: 0;
}
.bnr-footer__links li { margin-bottom: .625rem; }
.bnr-footer__links a {
  color: rgba(255,255,255,.65);
  text-decoration: none;
  font-size: .9375rem;
  transition: color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-footer__links a:hover { color: var(--bnr-white); }

.bnr-footer__newsletter input[type="email"] {
  width: 100%;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--bnr-radius-btn);
  padding: .75rem 1rem;
  color: var(--bnr-white);
  font-family: var(--bnr-font-body);
  font-size: .9375rem;
  margin-bottom: .625rem;
  transition: border-color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-footer__newsletter input[type="email"]:focus {
  outline: none;
  border-color: var(--bnr-teal);
}
.bnr-footer__newsletter input[type="email"]::placeholder { color: rgba(255,255,255,.35); }

.bnr-footer__newsletter button {
  width: 100%;
  background: var(--bnr-teal);
  color: var(--bnr-white);
  border: none;
  border-radius: var(--bnr-radius-btn);
  padding: .75rem 1rem;
  font-weight: 600;
  font-family: var(--bnr-font-body);
  font-size: .9375rem;
  cursor: pointer;
  transition: background var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-footer__newsletter button:hover { background: var(--bnr-teal-hover); }

.bnr-footer__newsletter-note {
  font-size: .73rem;
  color: rgba(255,255,255,.35);
  margin-top: .625rem;
  line-height: 1.5;
}

.bnr-footer__bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 1.5rem 0;
  max-width: var(--bnr-container);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
}

.bnr-footer__npra {
  font-size: .7rem;
  color: rgba(255,255,255,.3);
}

.bnr-footer__legal {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.bnr-footer__legal a {
  font-size: .7rem;
  color: rgba(255,255,255,.35);
  text-decoration: none;
  transition: color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-footer__legal a:hover { color: rgba(255,255,255,.7); }

@media (max-width: 900px) {
  .bnr-footer__inner { grid-template-columns: 1fr 1fr; }
  .bnr-footer__col:first-child { grid-column: 1 / -1; }
}
@media (max-width: 576px) {
  .bnr-footer__inner { grid-template-columns: 1fr; }
  .bnr-footer { padding-top: 60px; }
  .bnr-footer__bottom { flex-direction: column; align-items: flex-start; }
}

/* ==========================================================================
   PHASE 2 — COMMERCE (WooCommerce / PDP — unchanged)
   ========================================================================== */

.bnr-purchase-options {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-bottom: 1.5rem;
}
.bnr-purchase-option {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: 1rem 1.25rem;
  border: 2px solid #e0e0e0;
  border-radius: var(--bnr-radius-md);
  cursor: pointer;
  transition: border-color var(--bnr-duration-fast) var(--bnr-ease),
              background-color var(--bnr-duration-fast) var(--bnr-ease);
}
.bnr-purchase-option input[type="radio"] {
  margin-top: .3rem;
  accent-color: var(--bnr-teal);
  flex-shrink: 0;
}
.bnr-option-active {
  border-color: var(--bnr-teal);
  background-color: var(--bnr-teal-light);
}
.bnr-option-inner  { display: flex; flex-direction: column; gap: .2rem; }
.bnr-option-title  { font-weight: var(--bnr-weight-semi); font-size: .95rem; display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.bnr-option-price  { font-size: 1.25rem; font-weight: var(--bnr-weight-bold); color: var(--bnr-dark); }
.bnr-option-price small { font-size: .75rem; font-weight: var(--bnr-weight-normal); }
.bnr-option-note   { font-size: .8rem; color: var(--bnr-slate); }
.bnr-badge {
  font-size: .7rem;
  background: var(--bnr-teal);
  color: #fff;
  padding: .15rem .45rem;
  border-radius: var(--bnr-radius-pill);
  font-weight: var(--bnr-weight-semi);
  white-space: nowrap;
}
.bnr-subscribe-btn {
  background-color: var(--bnr-teal) !important;
  color: #fff !important;
  display: block;
  width: 100%;
  text-align: center;
  border-radius: var(--bnr-radius-btn) !important;
}
.bnr-subscribe-btn:hover {
  background-color: var(--bnr-teal-hover) !important;
  color: #fff !important;
}

.bnr-verify-form-wrap { max-width: 520px; margin: 0 auto; }
.bnr-verify-form-wrap input,
.bnr-verify-form-wrap select {
  width: 100%;
  padding: .75rem 1rem;
  border: 2px solid #e0e0e0;
  border-radius: var(--bnr-radius-md);
  font-size: 1rem;
  margin-bottom: 1rem;
  font-family: var(--bnr-font-body);
}
.bnr-verify-form-wrap input:focus,
.bnr-verify-form-wrap select:focus {
  border-color: var(--bnr-teal);
  outline: none;
}
#bnr-verify-error { background:#fdecea;color:#c0392b;padding:.75rem 1rem;border-radius:var(--bnr-radius-md);margin-bottom:1rem;font-size:.9rem; }
#bnr-verify-success { background:var(--bnr-teal-light);border:2px solid var(--bnr-teal);border-radius:var(--bnr-radius-lg);padding:2rem;text-align:center; }

/* ==========================================================================
   LANGUAGE BAR (Polylang)
   ========================================================================== */

.bnr17-lang-bar {
  background: var(--bnr-dark);
  padding: 4px 16px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.bnr17-lang-bar ul { list-style:none;margin:0;padding:0;display:flex;gap:10px;align-items:center; }
.bnr17-lang-bar li { margin:0;line-height:1; }
.bnr17-lang-bar li + li::before { content:'|';color:rgba(255,255,255,.25);margin-right:10px; }
.bnr17-lang-bar a,
.bnr17-lang-bar .no-translation { color:rgba(255,255,255,.55);font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:color .15s;display:inline-flex;align-items:center;gap:5px; }
.bnr17-lang-bar .current-lang a { color:#fff; }
.bnr17-lang-bar a:hover { color:#fff; }
.bnr17-lang-bar img { width:14px;height:10px;vertical-align:middle;border-radius:1px; }

/* ==========================================================================
   WHATSAPP  (unchanged)
   ========================================================================== */

.bnr-wa-bar { background:var(--bnr-teal);text-align:center;padding:.5rem 1rem;position:relative;z-index:1000; }
.bnr-wa-bar-link { display:inline-flex;align-items:center;gap:.45rem;color:#fff;text-decoration:none;font-size:.8rem;font-weight:500;letter-spacing:.01em;transition:opacity var(--bnr-duration-fast) var(--bnr-ease); }
.bnr-wa-bar-link:hover { opacity:.85;color:#fff; }
.bnr-wa-bar .bnr-wa-icon { width:16px;height:16px;fill:#25D366;flex-shrink:0; }

.bnr-wa-footer-strip { background:var(--bnr-dark);display:flex;align-items:center;justify-content:center;gap:1.25rem;padding:1.25rem 1rem;flex-wrap:wrap; }
.bnr-wa-footer-text { color:#a0b0b2;margin:0;font-size:.9rem; }
.bnr-wa-footer-btn { display:inline-flex;align-items:center;gap:.5rem;background:#25D366;color:#fff;text-decoration:none;padding:.55rem 1.25rem;border-radius:var(--bnr-radius-pill);font-size:.85rem;font-weight:600;transition:background-color var(--bnr-duration-fast) var(--bnr-ease); }
.bnr-wa-footer-btn:hover { background:#1da950;color:#fff; }

.bnr-wa-float { position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;align-items:center;gap:.6rem;background:#25D366;color:#fff;text-decoration:none;padding:.75rem 1.25rem .75rem 1rem;border-radius:var(--bnr-radius-pill);box-shadow:0 4px 20px rgba(37,211,102,.35);font-size:.875rem;font-weight:600;transition:transform var(--bnr-duration-fast) var(--bnr-ease),box-shadow var(--bnr-duration-fast) var(--bnr-ease); }
.bnr-wa-float svg { width:22px;height:22px;flex-shrink:0; }
.bnr-wa-float:hover { color:#fff;transform:translateY(-2px);box-shadow:0 6px 28px rgba(37,211,102,.45); }
.woocommerce-checkout .bnr-wa-float { display:none !important; }
@media (max-width:480px) {
  .bnr-wa-float { padding:.75rem;border-radius:50%; }
  .bnr-wa-float-label { display:none; }
  .bnr-wa-float svg { width:26px;height:26px; }
}
