/*
Theme Name: GOODBADGIRL
Theme URI: https://goodbadgirls.com
Author: DeepRapid
Description: Split-personality storefront for GOODBADGIRL — GOODIES (soft girl, white world) vs BADDIES (bad girl, black world). Edgy streetwear WooCommerce theme powered by DeepRapid Workers.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: goodbadgirl
*/

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,600&family=Allura&display=swap');

:root {
  --black: #0a0a0a;
  --white: #ffffff;
  --pink: #ff2e9a;      /* electric pink — primary accent + the "girl" signature */
  --pink-dark: #d4187f; /* deeper pink — hovers / shadows */
  --gold: #c8a96a;      /* GOODIES accent (secondary) */
  --bone: #f6f4ef;      /* GOODIES soft surface */
  --smoke: #141318;     /* BADDIES surface */
  --ink: #0a0a0a;
  --muted: #8a8a8f;
  --display: 'Anton', 'Arial Narrow', sans-serif;
  --script: 'Allura', 'Snell Roundhand', 'Brush Script MT', cursive;
  --sans: 'Archivo', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
.gbg-display { font-family: var(--display); text-transform: uppercase; letter-spacing: .5px; }

/* ============ ANNOUNCEMENT MARQUEE ============ */
.gbg-announce { background: var(--black); color: #fff; overflow: hidden; white-space: nowrap; border-bottom: 1px solid #1d1d22; }
.gbg-announce .track { display: inline-flex; gap: 0; animation: gbg-marquee 28s linear infinite; }
.gbg-announce span { display: inline-block; padding: 9px 0; font-size: 12px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; }
.gbg-announce span::after { content: '✦'; color: var(--pink); margin: 0 26px; }
@keyframes gbg-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============ HEADER ============ */
.gbg-topbar {
  position: sticky; top: 0; z-index: 60;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  gap: 18px; padding: 16px 26px;
  background: var(--white); border-bottom: 2px solid var(--black);
}
/* Wordmark lockup: GOODBAD (display) with a lowercase "girl" pink-cursive
   signature tucked under the right. GOOD = white w/ black outline, BAD = black. */
.gbg-topbar .wordmark { justify-self: start; display: inline-block; }
.wordmark .lockup { position: relative; display: inline-flex; flex-direction: column; line-height: 1; }
.wordmark .line { font-family: var(--display); font-size: 27px; letter-spacing: 1px; white-space: nowrap; }
.wordmark .g1 { color: #fff; -webkit-text-stroke: 1.4px var(--black); }
.wordmark .g2 { color: var(--black); }
.wordmark .g3 {
  font-family: var(--script); color: var(--pink); text-transform: none; font-weight: 400;
  font-size: 30px; line-height: .7; align-self: flex-end;
  margin: -11px 0 0 0; transform: rotate(-6deg) translateX(0.5em);
  text-shadow: 0 0 16px rgba(255,46,154,.45);
}
/* dark world: flip BAD to white so it reads on black */
body.gbg-world-bad .wordmark .g1 { -webkit-text-stroke-color: rgba(255,255,255,.5); }
body.gbg-world-bad .wordmark .g2 { color: #fff; }
.gbg-nav { display: flex; gap: 24px; align-items: center; justify-self: center; font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: 1.5px; }
.gbg-nav a { position: relative; padding: 4px 0; }
.gbg-nav a::after { content: ''; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px; background: var(--pink); transition: width .22s ease; }
.gbg-nav a:hover::after { width: 100%; }
/* Studio + Club get a touch of flair so they stand out among the nav links */
.gbg-nav-studio { color: var(--pink) !important; }
.gbg-nav-studio .spk { margin-right: 5px; }
.gbg-nav-club { font-weight: 900; }

.gbg-actions { display: flex; gap: 6px; align-items: center; justify-self: end; }
/* Icon buttons (search, cart) */
.gbg-actions .gbg-ic { display: inline-flex; align-items: center; justify-content: center; position: relative; width: 38px; height: 38px; border-radius: 999px; color: inherit; cursor: pointer; transition: background .15s ease, color .15s ease; }
.gbg-actions .gbg-ic:hover { color: var(--pink); background: rgba(255,46,154,.1); }
.gbg-actions .gbg-ic svg { display: block; }
.gbg-cart-count { position: absolute; top: 1px; right: 0; background: var(--pink); color: #fff; border-radius: 999px; padding: 0 5px; min-width: 16px; height: 16px; line-height: 16px; text-align: center; font-size: 10px; font-weight: 900; }

/* Header dropdowns (language + profile) built on <details> */
.gbg-dd { position: relative; }
.gbg-dd > summary { list-style: none; display: inline-flex; align-items: center; justify-content: center; gap: 4px; height: 38px; min-width: 38px; padding: 0 8px; border-radius: 999px; cursor: pointer; color: inherit; transition: background .15s ease, color .15s ease; }
.gbg-dd > summary::-webkit-details-marker { display: none; }
.gbg-dd > summary:hover { color: var(--pink); background: rgba(255,46,154,.1); }
.gbg-dd[open] > summary { background: rgba(255,46,154,.12); }
.gbg-lang-dd .flag { font-size: 18px; line-height: 1; }
.gbg-lang-dd .caret { font-size: 9px; opacity: .6; }
.gbg-profile-dd summary.is-in { color: var(--pink); }
.gbg-dd-menu { position: absolute; top: calc(100% + 10px); right: 0; min-width: 230px; background: #fff; color: var(--black); border: 2px solid var(--black); border-radius: 14px; box-shadow: 0 18px 50px rgba(0,0,0,.22); padding: 8px; z-index: 80; animation: gbgddin .14s ease; }
@keyframes gbgddin { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
.gbg-dd-menu a { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 9px; font-size: 13px; font-weight: 700; text-transform: none; letter-spacing: 0; color: var(--black); }
.gbg-dd-menu a:hover { background: #f4f2f7; color: var(--pink); }
.gbg-dd-menu a.is-current { color: var(--pink); }
.gbg-lang-menu .flag { font-size: 17px; }
.gbg-profile-menu { min-width: 250px; }
.gbg-profile-menu .pm-head { padding: 10px 12px 8px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.gbg-profile-menu .pm-hi { font-family: var(--display); text-transform: uppercase; font-size: 16px; letter-spacing: .5px; }
.gbg-profile-menu .pm-badge { background: var(--gold); color: var(--black); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: 1px; padding: 2px 8px; border-radius: 999px; }
.gbg-profile-menu .pm-points { background: linear-gradient(120deg, #1b1b22, #2a2730); color: #fff; margin: 2px 4px 8px; border-radius: 11px; padding: 12px 14px; flex-direction: column; align-items: flex-start; gap: 2px; }
.gbg-profile-menu .pm-points:hover { background: linear-gradient(120deg, #26242e, #3a2740); color: #fff; }
.gbg-profile-menu .pm-points-n { font-family: var(--display); font-size: 26px; line-height: 1; color: var(--pink); }
.gbg-profile-menu .pm-points-l { font-size: 11px; font-weight: 700; opacity: .82; text-transform: none; }
.gbg-profile-menu .pm-cta { background: var(--pink); color: #fff; justify-content: center; margin: 2px 4px 6px; font-weight: 900; }
.gbg-profile-menu .pm-cta:hover { background: var(--pink); color: #fff; filter: brightness(1.06); }
.gbg-profile-menu .pm-logout { border-top: 1px solid #eee; margin-top: 4px; color: #777; }
/* dark world tweaks */
body.gbg-world-bad .gbg-actions { color: #fff; }
body.gbg-world-bad .gbg-dd-menu { background: #151318; color: #fff; border-color: var(--pink); }
body.gbg-world-bad .gbg-dd-menu a { color: #fff; }
body.gbg-world-bad .gbg-dd-menu a:hover { background: #221c26; }
body.gbg-world-bad .gbg-profile-menu .pm-logout { border-color: #2a2630; }

/* search drawer (CSS toggle via :checked) */
#gbg-search-toggle { display: none; }
.gbg-search { max-height: 0; overflow: hidden; transition: max-height .3s ease; background: var(--black); }
#gbg-search-toggle:checked ~ .gbg-search { max-height: 120px; }
.gbg-search form { max-width: 900px; margin: 0 auto; display: flex; padding: 18px 26px; gap: 0; }
.gbg-search input[type=search] { flex: 1; border: none; background: transparent; color: #fff; font-family: var(--display); text-transform: uppercase; font-size: 24px; letter-spacing: 1px; outline: none; border-bottom: 2px solid #333; padding: 6px 2px; }
.gbg-search input::placeholder { color: #4a4a52; }
.gbg-search button { background: var(--pink); color: #fff; border: none; font-weight: 900; text-transform: uppercase; letter-spacing: 1px; padding: 0 22px; cursor: pointer; }

/* ============ SPLIT LANDING ============ */
.gbg-split { display: flex; width: 100%; height: calc(100vh - 116px); min-height: 540px; overflow: hidden; position: relative; background: #0a0a0a; background-size: cover; background-position: center; }
/* Shared brand intro video sits behind BOTH halves; each side's overlay tints
   the same footage into its mood (light goodie / dark baddie). */
.gbg-hero-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; pointer-events: none; }
.gbg-side { position: relative; flex: 1; overflow: hidden; transition: flex .6s cubic-bezier(.7,0,.2,1); display: flex; align-items: center; justify-content: center; z-index: 1; }
.gbg-side .overlay { position: absolute; inset: 0; transition: background .6s ease; }
.gbg-side:hover { flex: 1.7; }
.gbg-good .overlay { background: linear-gradient(180deg, rgba(255,255,255,.30), rgba(255,255,255,.60)); }
.gbg-bad .overlay { background: linear-gradient(180deg, rgba(8,8,10,.46), rgba(8,8,10,.72)); }
/* hovering a side pulls its tint back so more of the video shows through */
.gbg-good:hover .overlay { background: linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.44)); }
.gbg-bad:hover .overlay { background: linear-gradient(180deg, rgba(8,8,10,.30), rgba(8,8,10,.56)); }
.gbg-side .label { position: relative; text-align: center; z-index: 2; padding: 24px; }
.gbg-side .eyebrow { font-size: 12px; letter-spacing: 5px; text-transform: uppercase; font-weight: 900; margin-bottom: 12px; }
.gbg-side .title { font-family: var(--display); font-size: clamp(64px, 11vw, 168px); line-height: .82; margin: 0; text-transform: uppercase; }
.gbg-side .sub { margin: 16px auto 24px; max-width: 320px; font-size: 14px; font-weight: 600; line-height: 1.5; }
.gbg-side .cta { display: inline-block; padding: 15px 38px; font-family: var(--display); font-size: 16px; letter-spacing: 2px; text-transform: uppercase; border: 2px solid; }
.gbg-good { color: var(--black); }
.gbg-good .eyebrow { color: var(--gold); }
.gbg-good .cta { background: var(--black); color: var(--white); border-color: var(--black); }
.gbg-good .cta:hover { background: var(--pink); border-color: var(--pink); }
.gbg-bad { color: var(--white); }
.gbg-bad .eyebrow { color: var(--pink); }
.gbg-bad .cta { background: var(--white); color: var(--black); border-color: var(--white); }
.gbg-bad .cta:hover { background: var(--pink); color: var(--white); border-color: var(--pink); }
.gbg-toggle { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 5; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; font-weight: 800; color: #fff; mix-blend-mode: difference; }
.gbg-sound { position: absolute; bottom: 18px; left: 18px; z-index: 6; display: inline-flex; align-items: center; gap: 8px; background: rgba(0,0,0,.42); color: #fff; border: 1px solid rgba(255,255,255,.38); border-radius: 999px; padding: 9px 16px 9px 14px; font-family: inherit; font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; cursor: pointer; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); transition: background .2s ease, border-color .2s ease, transform .2s ease; }
.gbg-sound:hover { background: var(--pink); border-color: var(--pink); transform: translateY(-1px); }
.gbg-sound.on { background: var(--pink); border-color: var(--pink); }
.gbg-sound .ico { font-size: 9px; line-height: 1; }
.gbg-sound.on .ico { font-size: 11px; }

/* ============ SECTIONS ============ */
.gbg-section { max-width: 1280px; margin: 0 auto; padding: 76px 26px; }
.gbg-section h2 { font-family: var(--display); font-size: clamp(34px,5vw,62px); margin: 0 0 4px; text-transform: uppercase; letter-spacing: .5px; }
.gbg-section .lede { color: var(--muted); margin: 0 0 30px; font-size: 15px; font-weight: 600; }
.gbg-section.dark { background: var(--black); color: var(--white); max-width: none; }
.gbg-section.dark .inner { max-width: 1280px; margin: 0 auto; }
.gbg-section.dark .lede { color: #9a9aa2; }
.gbg-rowhead { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; }
.gbg-rowhead .more { font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; white-space: nowrap; }
.gbg-good-accent { color: var(--gold); }
.gbg-bad-accent { color: var(--pink); }

/* category tiles */
.gbg-cats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: 12px; margin-top: 26px; }
.gbg-cat { position: relative; aspect-ratio: 3/4; overflow: hidden; background: #efefef; }
.gbg-cat .ci { position: absolute; inset: 0; background: linear-gradient(150deg, #faf4f7, #ece4ea); background-size: cover; background-position: center; box-shadow: inset 0 0 60px rgba(20,16,18,.10); transition: transform .5s ease; }
.gbg-cat:hover .ci { transform: scale(1.08); }
.gbg-cat .cn { position: absolute; left: 0; right: 0; bottom: 0; padding: 16px; color: #fff;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.78)); font-family: var(--display); letter-spacing: 1px; text-transform: uppercase; font-size: 17px; }

/* product grid (custom homepage cards) */
.gbg-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px,1fr)); gap: 18px; margin-top: 26px; }
.gbg-card { background: #fff; overflow: hidden; border: 2px solid var(--black); transition: transform .2s ease, box-shadow .2s ease; }
.gbg-section.dark .gbg-card { background: var(--smoke); border-color: #2a2930; color: #fff; }
.gbg-card:hover { transform: translateY(-4px); box-shadow: 8px 8px 0 var(--pink); }
/* card must stack image-over-meta (a stray flex rule from another sheet collapses the thumb) */
.gbg-grid .gbg-card, a.gbg-card { display: flex !important; flex-direction: column; }
.gbg-grid .gbg-card .thumb, a.gbg-card .thumb { width: 100%; }
.gbg-card .thumb { aspect-ratio: 1/1; background: linear-gradient(150deg, #faf4f7, #eee7ec); background-size: cover; background-position: center; box-shadow: inset 0 0 46px rgba(20,16,18,.07), inset 0 -1px 0 rgba(0,0,0,.06); }
.gbg-section.dark .gbg-card .thumb { background: linear-gradient(150deg, #1c1b22, #131217); box-shadow: inset 0 0 46px rgba(0,0,0,.28), inset 0 -1px 0 rgba(255,255,255,.05); }
.gbg-card .meta { padding: 14px 16px 18px; }
.gbg-card .pn { font-weight: 700; font-size: 14px; line-height: 1.35; margin: 0 0 6px; }
.gbg-card .pp { font-family: var(--display); font-size: 20px; letter-spacing: .5px; }
.gbg-card .pp .amount { color: inherit; }
.gbg-card .add { display: inline-block; margin-top: 12px; font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; padding: 9px 16px; background: var(--black); color: #fff; }
.gbg-section.dark .gbg-card .add { background: var(--pink); }

/* manifesto */
.gbg-manifesto { text-align: center; padding: 100px 26px; background: var(--black); color: #fff; }
.gbg-manifesto .q { font-family: var(--display); font-size: clamp(30px,5vw,58px); max-width: 900px; margin: 0 auto; line-height: 1.05; text-transform: uppercase; }
.gbg-manifesto .q .pink { color: var(--pink); }
.gbg-manifesto .q .gold { color: var(--gold); }

/* ============ "What mood are you in?" — a little of both ============ */
.gbg-mood { max-width: 1280px; margin: 0 auto; padding: 84px 26px 26px; }
.gbg-mood-head { text-align: center; max-width: 700px; margin: 0 auto 36px; }
.gbg-mood-head .eyebrow { color: var(--pink); font-weight: 900; letter-spacing: 4px; text-transform: uppercase; font-size: 12px; }
.gbg-mood-head h2 { font-family: var(--display); font-size: clamp(38px, 6.5vw, 76px); text-transform: uppercase; line-height: .9; margin: 10px 0 14px; }
.gbg-mood-head .lede { color: var(--muted); font-size: 16px; font-weight: 600; line-height: 1.6; }
.gbg-mood-head .lede em { font-style: normal; font-family: var(--script); font-size: 1.9em; color: var(--pink); line-height: 0; }
.cta-dark { display: inline-block; margin-top: 22px; background: var(--black); color: #fff; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; font-size: 13px; padding: 14px 28px; transition: background .2s ease; }
.cta-dark:hover { background: var(--pink); }
.gbg-card { position: relative; }
.gbg-card-chip { position: absolute; top: 10px; left: 10px; z-index: 2; font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: 1px; padding: 3px 9px; }
.gbg-manifesto .q .gold { color: var(--gold); }

/* ============ PER-WORLD SKINS (WooCommerce pages) ============ */
/* default = GOODIES / light */
body.gbg-world-good { background: var(--white); color: var(--black); }
body.gbg-world-good .gbg-topbar { background: var(--white); border-color: var(--black); }

/* BADDIES / dark */
body.gbg-world-bad { background: var(--black); color: #f3f3f5; }
body.gbg-world-bad .gbg-topbar { background: var(--black); border-color: var(--pink); color: #fff; }
body.gbg-world-bad a { color: inherit; }

/* ============ WOOCOMMERCE (shared) ============ */
.woocommerce, .woocommerce-page { font-family: var(--sans); }
#primary, .woocommerce-notices-wrapper { max-width: 1280px; margin: 0 auto; padding: 0 26px; }
.woocommerce .site-main, #main { max-width: 1280px; margin: 0 auto; padding: 40px 26px 80px; }
.woocommerce-breadcrumb { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; font-weight: 700; color: var(--muted); margin: 18px 0 8px; }
.woocommerce-products-header__title, .woocommerce h1.entry-title, .product_title {
  font-family: var(--display) !important; text-transform: uppercase; letter-spacing: .5px;
  font-size: clamp(32px,5vw,56px) !important; font-weight: 400 !important; margin: 6px 0 14px !important;
}
.woocommerce .woocommerce-result-count, .woocommerce .woocommerce-ordering { font-size: 13px; }
.woocommerce ul.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin: 24px 0 !important; }
/* WooCommerce adds clearfix ::before/::after to ul.products — as a grid they
   become phantom cells that shove the first product into column 2. Kill them. */
.woocommerce ul.products::before, .woocommerce ul.products::after { content: none !important; display: none !important; }
.woocommerce ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; text-align: left; }
.woocommerce ul.products li.product a img { margin: 0 0 12px !important; border: 2px solid var(--black); }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-weight: 700 !important; font-size: 14px !important; padding: 0 !important; line-height: 1.35;
}
.woocommerce ul.products li.product .price { font-family: var(--display); font-size: 20px; color: inherit !important; }
.woocommerce ul.products li.product .price del { opacity: .5; font-size: 15px; }
.woocommerce ul.products li.product .button,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce .single_add_to_cart_button {
  background: var(--black) !important; color: #fff !important; border-radius: 0 !important;
  font-family: var(--sans) !important; font-weight: 900 !important; text-transform: uppercase !important;
  letter-spacing: 1.5px !important; font-size: 12px !important; padding: 12px 20px !important; border: 2px solid var(--black) !important;
  transition: background .2s, color .2s;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce .button:hover,
.woocommerce .single_add_to_cart_button:hover { background: var(--pink) !important; border-color: var(--pink) !important; }
.woocommerce .single_add_to_cart_button { font-size: 15px !important; padding: 16px 36px !important; }
.woocommerce div.product .product_title + .price, .woocommerce div.product p.price, .woocommerce div.product span.price {
  font-family: var(--display); font-size: 30px; color: var(--pink) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { border-bottom-color: var(--pink); }
/* single product: two-column layout + brand polish */
.woocommerce div.product { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.woocommerce div.product .woocommerce-product-gallery, .woocommerce div.product .summary { width: 100% !important; float: none !important; margin: 0 !important; }
.woocommerce div.product .woocommerce-product-gallery img { border: 2px solid var(--black); }
.woocommerce div.product .product_title { margin-top: 0 !important; }
.woocommerce div.product form.cart { margin: 24px 0; }
.woocommerce div.product .woocommerce-tabs, .woocommerce div.product .related, .woocommerce div.product .up-sells, .woocommerce div.product .upsells { grid-column: 1 / -1; }
.woocommerce .related > h2, .woocommerce .upsells > h2 { font-family: var(--display); text-transform: uppercase; font-size: 30px; letter-spacing: .5px; }
.gbg-chip { display: inline-block; font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; padding: 4px 11px; margin-bottom: 12px; }
.gbg-chip-good { background: var(--gold); color: #0a0a0a; }
.gbg-chip-bad { background: var(--pink); color: #fff; }
.gbg-trust { list-style: none; display: flex; flex-wrap: wrap; gap: 12px 22px; margin: 24px 0 0; padding: 18px 0 0; border-top: 1px solid #e6e6e6; }
.gbg-trust li { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--muted); position: relative; padding-left: 18px; }
.gbg-trust li::before { content: '✦'; color: var(--pink); position: absolute; left: 0; }
body.gbg-world-bad .woocommerce div.product .woocommerce-product-gallery img { border-color: #2a2930; }
body.gbg-world-bad .gbg-trust { border-top-color: #2a2930; }
@media (max-width: 820px) { .woocommerce div.product { grid-template-columns: 1fr; gap: 26px; } }
.woocommerce span.onsale { background: var(--pink) !important; color: #fff !important; border-radius: 0; font-weight: 900; }
.woocommerce-message, .woocommerce-info { border-top-color: var(--pink) !important; }

/* dark-world woo overrides */
body.gbg-world-bad .woocommerce ul.products li.product a img { border-color: #2a2930; }
body.gbg-world-bad .woocommerce ul.products li.product .button { background: var(--pink) !important; border-color: var(--pink) !important; }
body.gbg-world-bad .woocommerce ul.products li.product .button:hover { background: #fff !important; color: var(--black) !important; }
body.gbg-world-bad .woocommerce-breadcrumb { color: #8a8a92; }
body.gbg-world-bad .woocommerce a.button, body.gbg-world-bad .woocommerce button.button { background: var(--pink) !important; border-color: var(--pink) !important; }
body.gbg-world-bad .woocommerce-tabs, body.gbg-world-bad table, body.gbg-world-bad .woocommerce-Tabs-panel { color: #e7e7ea; }
body.gbg-world-bad .woocommerce div.product p.price, body.gbg-world-bad .woocommerce div.product span.price { color: var(--pink) !important; }

/* hide the default woo sidebar (we render full-width) */
.woocommerce-page #secondary, .woocommerce #secondary, #secondary.widget-area { display: none !important; }

/* ============ PAGES · CART · CHECKOUT · ACCOUNT ============ */
.gbg-page { max-width: 1200px; margin: 0 auto; padding: 40px 26px 96px; }
.gbg-page-title { font-family: var(--display); text-transform: uppercase; font-size: clamp(34px,6vw,64px); letter-spacing: .5px; margin: 6px 0 26px; }
.gbg-page-body { font-size: 16px; line-height: 1.7; }
.gbg-page-body > p { margin: 0 0 16px; }

/* WooCommerce Blocks — cart + checkout */
.wc-block-components-button:not(.is-link), .wp-block-button__link {
  background: var(--black) !important; color: #fff !important; border-radius: 0 !important;
  font-family: var(--sans) !important; font-weight: 900 !important; text-transform: uppercase !important;
  letter-spacing: 1.5px !important; border: 2px solid var(--black) !important;
}
.wc-block-components-button:not(.is-link):hover, .wp-block-button__link:hover { background: var(--pink) !important; border-color: var(--pink) !important; }
.wc-block-cart__submit-button, .wc-block-components-checkout-place-order-button {
  background: var(--pink) !important; border-color: var(--pink) !important;
}
.wc-block-cart__submit-button:hover, .wc-block-components-checkout-place-order-button:hover { background: var(--pink-dark) !important; border-color: var(--pink-dark) !important; }
a.wc-block-components-button.is-link, .wc-block-cart-item__remove-link { color: var(--pink) !important; }
.wc-block-cart-items__header, .wc-block-components-checkout-step__title, .wc-block-cart__totals-title { font-family: var(--sans); text-transform: uppercase; letter-spacing: .5px; font-weight: 800; }
.wc-block-cart-item__product-name, .wc-block-grid__product-title { font-weight: 700 !important; }
.wc-block-components-product-price, .wc-block-formatted-money-amount, .wc-block-components-totals-item__value { font-weight: 700; }
.wc-block-checkout__actions .wc-block-components-checkout-place-order-button { width: 100%; }
.wp-block-woocommerce-cart, .wp-block-woocommerce-checkout { margin-top: 4px; }

/* Classic cart fallback (table) */
.woocommerce table.shop_table { border-radius: 0; border-color: #e6e6e6; }
.woocommerce table.shop_table th { text-transform: uppercase; letter-spacing: .5px; font-size: 12px; }
.woocommerce .cart-collaterals .cart_totals h2 { font-family: var(--display); text-transform: uppercase; }
.woocommerce .cart-empty, .wc-block-cart__empty-cart__title { font-family: var(--display); text-transform: uppercase; font-size: 28px; }

/* My Account (classic shortcode) */
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0 0 24px; padding: 0; border: 2px solid var(--black); }
.woocommerce-account .woocommerce-MyAccount-navigation li { border-bottom: 1px solid #eee; }
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child { border-bottom: none; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 12px 16px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; font-size: 13px; }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--black); color: #fff; }
.woocommerce-account .woocommerce-MyAccount-content { padding-left: 4px; }
.woocommerce form.login, .woocommerce form.register, .woocommerce-ResetPassword { border: 2px solid var(--black) !important; border-radius: 0; padding: 24px !important; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce .select2-selection { border: 1.5px solid #cfcfcf !important; border-radius: 0 !important; padding: 12px !important; }
@media (min-width: 783px) {
  .woocommerce-account .woocommerce-MyAccount-navigation { float: left; width: 25%; }
  .woocommerce-account .woocommerce-MyAccount-content { float: right; width: 71%; }
}

/* ============ ARTICLE ============ */
.gbg-article { max-width: 760px; margin: 0 auto; padding: 56px 24px 90px; }
.gbg-post-head .back { font-size: 12px; font-weight: 900; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); }
.gbg-post-head h1 { font-family: var(--display); font-size: clamp(34px,6vw,68px); line-height: .95; margin: 16px 0 8px; text-transform: uppercase; }
.gbg-post-head .date { color: var(--muted); font-size: 13px; margin-bottom: 28px; text-transform: uppercase; letter-spacing: 1px; }
.gbg-post-hero img { width: 100%; border: 2px solid var(--black); margin-bottom: 32px; }
.gbg-post-body { font-size: 17px; line-height: 1.75; }
.gbg-post-body h2 { font-family: var(--display); font-size: 30px; margin: 40px 0 12px; text-transform: uppercase; }
.gbg-post-body h3 { font-weight: 800; font-size: 21px; margin: 30px 0 10px; }
.gbg-post-body p { margin: 0 0 18px; }
.gbg-post-body ul { margin: 0 0 18px 20px; }
/* article — new editorial chrome */
.gbg-post-head { text-align: center; margin-bottom: 8px; }
.gbg-post-head .back { display: inline-block; margin-bottom: 18px; }
.gbg-post-cat { display: inline-block; background: var(--pink); color: #fff; font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: 2px; padding: 4px 12px; }
.gbg-post-head h1 { margin-top: 14px; }
.gbg-post-meta { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px; font-weight: 700; margin: 10px 0 30px; display: flex; gap: 10px; justify-content: center; }
.gbg-post-meta .dot { color: var(--pink); }
.gbg-post-foot { margin-top: 48px; padding-top: 28px; border-top: 2px solid var(--black); text-align: center; }
.gbg-post-sign { font-family: var(--script); font-size: 42px; color: var(--pink); margin: 0 0 16px; }
.gbg-post-shop { display: inline-block; background: var(--black); color: #fff; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; font-size: 13px; padding: 13px 28px; }
.gbg-post-shop:hover { background: var(--pink); }

/* ============ THE TEA — journal index ============ */
.gbg-journal { max-width: 1240px; margin: 0 auto; padding: 56px 26px 96px; }
.tea-masthead { text-align: center; margin-bottom: 48px; }
.tea-masthead .eyebrow { color: var(--pink); font-weight: 900; letter-spacing: 4px; text-transform: uppercase; font-size: 12px; }
.tea-title { font-family: var(--display); font-size: clamp(54px, 11vw, 150px); line-height: .85; text-transform: uppercase; margin: 8px 0 0; }
.ink-pink { color: var(--pink); font-family: var(--script); text-transform: none; font-size: 1.15em; line-height: 0; }
.tea-tag { color: var(--muted); font-size: 16px; font-weight: 600; max-width: 620px; margin: 18px auto 0; }
.tea-hero { display: grid; grid-template-columns: 1.15fr 1fr; gap: 0; border: 2px solid var(--black); margin-bottom: 40px; background: #fff; }
.tea-hero-img { min-height: 380px; background-size: cover; background-position: center; background-color: #eee; }
.tea-hero-body { padding: 44px; display: flex; flex-direction: column; justify-content: center; }
.tea-cat { align-self: flex-start; background: var(--black); color: #fff; font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: 2px; padding: 4px 11px; }
.tea-hero-body h2 { font-family: var(--display); font-size: clamp(30px, 4.5vw, 54px); line-height: .96; text-transform: uppercase; margin: 16px 0 12px; }
.tea-hero-body p { color: var(--muted); font-size: 16px; line-height: 1.6; margin: 0 0 18px; }
.tea-read { font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; font-size: 13px; color: var(--pink); }
.tea-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.tea-card { display: flex; flex-direction: column; border: 2px solid var(--black); background: #fff; transition: transform .18s ease, box-shadow .18s ease; }
.tea-card:hover { transform: translateY(-4px); box-shadow: 8px 8px 0 var(--pink); }
.tea-card-img { aspect-ratio: 4/3; background-size: cover; background-position: center; background-color: #eee; border-bottom: 2px solid var(--black); }
.tea-card-body { padding: 18px 18px 22px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.tea-card-body h3 { font-weight: 800; font-size: 18px; line-height: 1.2; margin: 4px 0 0; }
.tea-card-body p { color: var(--muted); font-size: 14px; line-height: 1.5; margin: 0; flex: 1; }
.tea-meta { font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--muted); font-weight: 700; }
.tea-empty { text-align: center; font-family: var(--display); text-transform: uppercase; font-size: 28px; padding: 60px 0; }
.gbg-journal .pagination, .gbg-journal nav.navigation { margin-top: 44px; text-align: center; }
.gbg-journal .page-numbers { display: inline-block; padding: 8px 14px; border: 2px solid var(--black); margin: 0 3px; font-weight: 900; }
.gbg-journal .page-numbers.current { background: var(--black); color: #fff; }
@media (max-width: 900px) { .tea-grid { grid-template-columns: repeat(2, 1fr); } .tea-hero { grid-template-columns: 1fr; } .tea-hero-img { min-height: 240px; } }
@media (max-width: 560px) { .tea-grid { grid-template-columns: 1fr; } }

/* ============ HEADER MEGA-MENU ============ */
.gbg-navitem { position: relative; display: inline-flex; align-items: center; }
.gbg-mega {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(10px);
  min-width: 360px; background: var(--white); color: var(--black); border: 2px solid var(--black);
  padding: 16px; opacity: 0; visibility: hidden; transition: opacity .16s ease, transform .16s ease;
  z-index: 200; box-shadow: 12px 12px 0 rgba(0,0,0,.12);
}
.gbg-mega::before { content: ''; position: absolute; top: -12px; left: 0; right: 0; height: 12px; } /* hover bridge */
.gbg-navitem:hover .gbg-mega { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.gbg-mega-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 16px; }
.gbg-mega a::after { display: none !important; }
.mega-link { display: flex; justify-content: space-between; align-items: center; padding: 9px 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; font-size: 12px; color: var(--black); }
.mega-link:hover { background: var(--black); color: #fff; }
.mega-link .ml-count { font-size: 10px; color: var(--muted); font-weight: 700; }
.mega-link:hover .ml-count { color: #fff; }
.gbg-mega-all { display: block; margin-top: 10px; padding-top: 12px; border-top: 1px solid #ececec; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; font-size: 12px; color: var(--pink); }
.gbg-navitem-bad .gbg-mega { background: var(--black); color: #fff; border-color: var(--pink); box-shadow: 12px 12px 0 rgba(255,46,154,.18); }
.gbg-navitem-bad .mega-link { color: #fff; }
.gbg-navitem-bad .mega-link:hover { background: var(--pink); color: #fff; }
.gbg-navitem-bad .mega-link .ml-count { color: #7a7a82; }
.gbg-navitem-bad .gbg-mega-all { border-top-color: #2a2930; }

/* ============ WORLD LANDING (category hub) ============ */
.gbg-world-hero { position: relative; min-height: 46vh; display: flex; align-items: flex-end; overflow: hidden; }
.gbg-world-hero .wh-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.gbg-world-hero .wh-overlay { position: absolute; inset: 0; }
.gbg-world-hero.is-good .wh-overlay { background: linear-gradient(to top, rgba(255,255,255,.95), rgba(255,255,255,.2)); }
.gbg-world-hero.is-bad .wh-overlay { background: linear-gradient(to top, rgba(0,0,0,.92), rgba(0,0,0,.3)); }
.gbg-world-hero .wh-inner { position: relative; padding: 44px 26px; max-width: 1280px; margin: 0 auto; width: 100%; }
.gbg-world-hero .eyebrow { font-weight: 900; letter-spacing: 4px; text-transform: uppercase; font-size: 12px; color: var(--pink); }
.gbg-world-hero h1 { font-family: var(--display); font-size: clamp(56px,13vw,160px); line-height: .82; text-transform: uppercase; margin: 8px 0 10px; }
.gbg-world-hero.is-bad h1 { color: #fff; }
.gbg-world-hero p { max-width: 580px; font-weight: 600; font-size: 16px; }

.gbg-world-cats { max-width: 1280px; margin: 0 auto; padding: 54px 26px 18px; }
.gbg-world-h2 { font-family: var(--display); text-transform: uppercase; font-size: clamp(24px,4vw,40px); margin-bottom: 22px; letter-spacing: .5px; }
.gbg-ptiles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.gbg-ptile { position: relative; display: block; border: 2px solid currentColor; overflow: hidden; }
.gbg-ptile .pt-img { aspect-ratio: 3/4; background-size: cover; background-position: center; background-color: #efe7ec; background-image: linear-gradient(150deg, #faf4f7, #ece4ea); box-shadow: inset 0 0 70px rgba(20,16,18,.10); transition: transform .4s ease; }
.gbg-ptile:hover .pt-img { transform: scale(1.05); }
.gbg-ptile .pt-meta { position: absolute; left: 0; right: 0; bottom: 0; padding: 14px; display: flex; justify-content: space-between; align-items: flex-end; background: linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,0)); color: #fff; }
.gbg-ptile .pt-name { font-family: var(--display); text-transform: uppercase; font-size: 20px; line-height: 1; }
.gbg-ptile .pt-count { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; opacity: .85; }
.gbg-world-feat { max-width: 1280px; margin: 0 auto; padding: 34px 26px 30px; }
.gbg-world-cross { text-align: center; padding: 22px 26px 84px; }
.gbg-world-cross a { font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; font-size: 13px; border-bottom: 2px solid var(--pink); padding-bottom: 4px; }

/* ============ LEAF CATEGORY ARCHIVE ============ */
.gbg-archive { max-width: 1280px; margin: 0 auto; padding: 48px 26px 92px; }
.gbg-archive-head { margin-bottom: 30px; }
.gbg-archive-head .back { font-size: 12px; font-weight: 900; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); display: inline-block; margin-bottom: 14px; }
.gbg-archive-head .gbg-chip { display: block; width: max-content; margin-bottom: 8px; }
.gbg-archive-head h1 { font-family: var(--display); font-size: clamp(40px,8vw,84px); line-height: .9; text-transform: uppercase; margin: 0; }
.gbg-archive-desc { color: var(--muted); margin-top: 12px; max-width: 640px; }
.gbg-archive .pagination, .gbg-archive nav.navigation { margin-top: 40px; text-align: center; }
.gbg-archive .page-numbers { display: inline-block; padding: 8px 14px; border: 2px solid currentColor; margin: 0 3px; font-weight: 900; }

@media (max-width: 900px) { .gbg-ptiles { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 860px) { .gbg-mega { display: none; } }
@media (max-width: 520px) { .gbg-ptiles { grid-template-columns: 1fr; } }

/* ============ FOOTER ============ */
.gbg-footer { background: var(--black); color: #cfcfd4; padding: 0; border-top: 2px solid var(--pink); }
.gbg-footer-top { max-width: 1280px; margin: 0 auto; padding: 60px 26px 40px; display: grid; grid-template-columns: 1.3fr 2fr; gap: 48px; }
.gbg-footer-brand .wordmark { display: inline-block; }
.gbg-footer-brand .wordmark .lockup { display: inline-flex; flex-direction: column; line-height: 1; }
.gbg-footer-brand .wordmark .line { font-family: var(--display); font-size: 46px; letter-spacing: 1px; }
.gbg-footer-brand .wordmark .g1, .gbg-footer-brand .wordmark .g2 { color: #fff; -webkit-text-stroke: 0; }
.gbg-footer-brand .wordmark .g3 { font-family: var(--script); color: var(--pink); text-transform: none; font-size: 48px; line-height: .7; align-self: flex-end; margin: -18px 0 0 0; transform: rotate(-6deg) translateX(0.45em); text-shadow: 0 0 18px rgba(255,46,154,.4); }
.gbg-footer-brand .tag { margin-top: 8px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; font-size: 12px; color: #fff; }
.gbg-footer-news { margin-top: 24px; max-width: 340px; }
.gbg-footer-news .fn-lede { font-size: 13px; font-weight: 700; color: #fff; margin: 0 0 10px; }
.gbg-footer-cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.gbg-footer-cols .fcol h4 { font-family: var(--display); font-size: 18px; letter-spacing: 1px; text-transform: uppercase; color: #fff; margin: 0 0 14px; }
.gbg-footer-cols .fcol a { display: block; color: #b6b6bd; font-size: 13px; font-weight: 600; padding: 5px 0; text-decoration: none; transition: color .15s ease; }
.gbg-footer-cols .fcol a:hover { color: var(--pink); }
.gbg-footer-bar { border-top: 1px solid #232228; max-width: 1280px; margin: 0 auto; padding: 18px 26px; display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: space-between; font-size: 11px; letter-spacing: .5px; text-transform: uppercase; color: #76757c; }
.gbg-footer-bar .fb-mid { display: flex; gap: 18px; }
.gbg-footer-bar a { color: #9a9aa2; font-weight: 700; } .gbg-footer-bar a:hover { color: var(--pink); }
.gbg-footer-bar .fb-right { display: flex; gap: 14px; align-items: center; }
.gbg-footer-bar .fb-trust { color: #b6b6bd; font-weight: 700; }
.gbg-footer-bar .fb-pay { color: #5d5c63; font-weight: 700; }
@media (max-width: 880px) {
  .gbg-footer-top { grid-template-columns: 1fr; gap: 36px; }
  .gbg-footer-cols { grid-template-columns: repeat(2, 1fr); }
  .gbg-footer-bar { justify-content: center; text-align: center; }
}

/* ============ Newsletter form (homepage + footer) ============ */
.gbg-news-form { display: flex; flex-wrap: wrap; gap: 8px; max-width: 460px; }
.gbg-news-form input[type=email] { flex: 1 1 200px; min-width: 0; padding: 13px 16px; border: 2px solid #2a2930; background: #15151a; color: #fff; font-family: inherit; font-size: 14px; border-radius: 10px; }
.gbg-news-form input[type=email]:focus { outline: none; border-color: var(--pink); }
.gbg-news-form button { padding: 13px 22px; border: none; cursor: pointer; background: var(--pink); color: #fff; font-family: inherit; font-weight: 900; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; border-radius: 10px; transition: filter .15s ease, transform .15s ease; white-space: nowrap; }
.gbg-news-form button:hover { filter: brightness(1.08); transform: translateY(-1px); }
.gbg-news-form button:disabled { opacity: .8; cursor: default; transform: none; }
.gbg-news-msg { flex-basis: 100%; margin: 6px 0 0; font-size: 13px; font-weight: 700; min-height: 1em; }
.gbg-news-msg.ok { color: var(--gold); }
.gbg-news-msg.err { color: var(--pink); }
.screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }

/* ============ AI Design Studio band ============ */
.gbg-studioband { background: radial-gradient(120% 120% at 80% 0%, rgba(255,46,154,.28), transparent 55%), var(--black); color: #fff; overflow: hidden; }
.gbg-studioband .sb-inner { max-width: 1280px; margin: 0 auto; padding: 80px 26px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: center; }
.gbg-studioband .eyebrow { color: var(--pink); font-weight: 900; letter-spacing: 4px; text-transform: uppercase; font-size: 12px; }
.gbg-studioband h2 { font-family: var(--display); font-size: clamp(40px, 7vw, 86px); line-height: .9; text-transform: uppercase; margin: 12px 0 16px; }
.gbg-studioband .sb-accent { color: var(--pink); }
.gbg-studioband p { color: #c2c2c9; font-size: 16px; font-weight: 600; max-width: 460px; margin: 0 0 24px; }
.gbg-studioband .sb-cta { display: inline-block; background: #fff; color: var(--black); font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; font-size: 14px; padding: 16px 32px; border-radius: 12px; transition: background .2s ease, color .2s ease, transform .2s ease; }
.gbg-studioband .sb-cta:hover { background: var(--pink); color: #fff; transform: translateY(-2px); }
.gbg-studioband .sb-prompts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.gbg-studioband .sb-prompts span { font-size: 12px; color: #b6b6bd; border: 1px solid #2f2e36; border-radius: 999px; padding: 7px 13px; font-style: italic; }
.gbg-studioband .sb-art { position: relative; aspect-ratio: 1/1; border-radius: 20px; background: conic-gradient(from 210deg, #ff2e9a, #c8a96a, #ff2e9a); display: flex; align-items: center; justify-content: center; box-shadow: 0 30px 80px rgba(255,46,154,.25); }
.gbg-studioband .sb-art::after { content: '✨'; font-size: clamp(60px, 12vw, 120px); }
.gbg-studioband .sb-chip { position: absolute; top: 16px; left: 16px; background: rgba(0,0,0,.55); color: #fff; font-weight: 900; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; padding: 7px 13px; border-radius: 999px; }
@media (max-width: 820px) { .gbg-studioband .sb-inner { grid-template-columns: 1fr; } .gbg-studioband .sb-art { max-width: 320px; } }

/* ============ GBG Club band (homepage) ============ */
.gbg-clubband { background: radial-gradient(130% 130% at 0% 0%, rgba(200,169,106,.20), transparent 52%), radial-gradient(130% 130% at 100% 100%, rgba(255,46,154,.22), transparent 52%), #100f14; color: #fff; }
.gbg-clubband-inner { max-width: 1280px; margin: 0 auto; padding: 84px 26px; display: grid; grid-template-columns: 1fr 1.05fr; gap: 52px; align-items: center; }
.gbg-clubband .cb-eyebrow { color: var(--gold); font-weight: 900; letter-spacing: 3px; text-transform: uppercase; font-size: 12px; }
.gbg-clubband h2 { font-family: var(--display); font-size: clamp(38px, 6vw, 76px); line-height: .92; text-transform: uppercase; margin: 12px 0 16px; }
.gbg-clubband h2 .ink-pink { color: var(--pink); }
.gbg-clubband p { color: #c2c2c9; font-size: 16px; font-weight: 600; max-width: 460px; margin: 0 0 26px; }
.gbg-clubband .cb-pick-label { display: block; font-size: 12px; font-weight: 900; letter-spacing: 2px; text-transform: uppercase; color: #8d8c95; margin-bottom: 14px; }

/* ---- Era picker (shared: band, page, account form) ---- */
.gbg-erapicker { display: grid; gap: 14px; }
.gbg-erapicker--band { grid-template-columns: 1fr; }
.gbg-erapicker--page, .gbg-erapicker--form { grid-template-columns: repeat(3, 1fr); }
.gbg-eracard { position: relative; display: block; text-align: left; border: 2px solid rgba(255,255,255,.16); border-radius: 16px; padding: 18px 20px; background: rgba(255,255,255,.04); color: #fff; transition: transform .18s ease, border-color .18s ease, background .18s ease; overflow: hidden; }
.gbg-eracard:hover { transform: translateY(-3px); border-color: var(--pink); background: rgba(255,255,255,.08); }
.gbg-eracard .ec-key { display: inline-block; font-family: var(--display); font-size: 13px; letter-spacing: 2px; text-transform: uppercase; padding: 3px 10px; border-radius: 999px; margin-bottom: 10px; }
.gbg-eracard.era-good .ec-key { background: var(--gold); color: #1a1a1a; }
.gbg-eracard.era-bad .ec-key { background: var(--pink); color: #fff; }
.gbg-eracard.era-surprise .ec-key { background: linear-gradient(90deg, var(--gold), var(--pink)); color: #1a1a1a; }
.gbg-eracard .ec-label { display: block; font-family: var(--display); font-size: 20px; text-transform: uppercase; line-height: 1; margin-bottom: 6px; }
.gbg-eracard .ec-desc { display: block; font-size: 13px; color: #b6b6bd; font-weight: 600; }
.gbg-eracard .ec-cta { display: inline-block; margin-top: 12px; font-size: 12px; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; color: var(--pink); }
.gbg-eracard.is-selected { border-color: var(--pink); background: rgba(255,46,154,.1); }
/* account/form variant: radios styled as cards on a light page */
.gbg-erapicker--form .gbg-eracard { color: var(--ink, #1a1a1a); background: #faf9fb; border-color: #e4e1ea; cursor: pointer; }
.gbg-erapicker--form .gbg-eracard:hover { background: #fff; }
.gbg-erapicker--form .gbg-eracard .ec-desc { color: #6b6975; }
.gbg-erapicker--form .gbg-eracard input { position: absolute; opacity: 0; }
.gbg-erapicker--form .gbg-eracard.is-selected, .gbg-erapicker--form .gbg-eracard:has(input:checked) { border-color: var(--pink); background: rgba(255,46,154,.06); }
@media (max-width: 900px) { .gbg-clubband-inner { grid-template-columns: 1fr; gap: 32px; } .gbg-erapicker--page, .gbg-erapicker--form { grid-template-columns: 1fr; } }

/* ============ Stay-close band (newsletter + social, merged) ============ */
.gbg-stay { background: #15151a; color: #fff; }
.gbg-stay-inner { max-width: 1180px; margin: 0 auto; padding: 76px 26px; display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px; align-items: center; }
.gbg-stay .eyebrow { color: var(--pink); font-weight: 900; letter-spacing: 4px; text-transform: uppercase; font-size: 12px; }
.gbg-stay-news h2 { font-family: var(--display); font-size: clamp(32px, 5vw, 58px); text-transform: uppercase; line-height: .9; margin: 12px 0 12px; }
.gbg-stay-news p { color: #b6b6bd; font-size: 15px; font-weight: 600; margin: 0 0 22px; }
.gbg-stay-social { border-left: 1px solid #2a2930; padding-left: 56px; }
.gbg-stay-social .gbg-stay-tag { font-family: var(--display); font-size: clamp(26px, 3.5vw, 40px); text-transform: uppercase; margin: 10px 0 8px; }
.gbg-stay-social .lede { color: #b6b6bd; font-size: 14px; font-weight: 600; margin: 0 0 20px; }
.gbg-social-links { display: flex; flex-wrap: wrap; gap: 12px; }
.gbg-social-links a { border: 2px solid #fff; color: #fff; font-weight: 900; text-transform: uppercase; letter-spacing: 1px; font-size: 12px; padding: 10px 18px; border-radius: 999px; transition: background .2s ease, color .2s ease, border-color .2s ease; }
.gbg-social-links a:hover { background: var(--pink); border-color: var(--pink); color: #fff; }
@media (max-width: 820px) { .gbg-stay-inner { grid-template-columns: 1fr; gap: 36px; } .gbg-stay-social { border-left: 0; padding-left: 0; border-top: 1px solid #2a2930; padding-top: 32px; } }

/* ============ Loyalty pillar pages (rewards / refer / club) ============ */
.gbg-pillarnav { display: flex; gap: 10px; flex-wrap: wrap; max-width: 1000px; margin: 0 auto 36px; padding: 0 20px; }
.gbg-pillarnav-item { flex: 1 1 200px; display: flex; flex-direction: column; gap: 2px; border: 2px solid var(--black); border-radius: 14px; padding: 14px 18px; transition: background .15s ease, color .15s ease, transform .15s ease; }
.gbg-pillarnav-item:hover { transform: translateY(-2px); background: var(--black); color: #fff; }
.gbg-pillarnav-item.is-current { background: var(--pink); border-color: var(--pink); color: #fff; }
.gbg-pillarnav-item .pn-t { font-family: var(--display); font-size: 17px; text-transform: uppercase; letter-spacing: .5px; }
.gbg-pillarnav-item .pn-s { font-size: 12px; font-weight: 700; opacity: .8; }
.gbg-statusstrip { max-width: 760px; margin: 0 auto 32px; display: flex; align-items: center; gap: 28px; justify-content: center; flex-wrap: wrap; background: #faf9fb; border: 2px solid #ece9f0; border-radius: 16px; padding: 22px 28px; }
.gbg-statusstrip .ss-fig { display: flex; flex-direction: column; align-items: center; }
.gbg-statusstrip .ss-n { font-family: var(--display); font-size: 34px; line-height: 1; color: var(--pink); }
.gbg-statusstrip .ss-l { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #777; }
.gbg-share-hero { max-width: 620px; margin: 0 auto 36px; }
.gbg-info-cta { text-align: center; margin: 12px 0 40px; }
.gbg-clubpage .gbg-erapicker--page { max-width: 1000px; margin: 0 auto 8px; padding: 0 20px; }
.gbg-clubhero { background: radial-gradient(120% 90% at 50% 0%, rgba(255,46,154,.16), transparent 60%); }
.gbg-faq { max-width: 760px; margin: 8px auto 0; padding: 0 20px 40px; }
.gbg-faq h3 { font-family: var(--display); text-transform: uppercase; font-size: 22px; margin: 0 0 14px; }
.gbg-faq details { border-bottom: 1px solid #e7e4ec; padding: 14px 0; }
.gbg-faq summary { cursor: pointer; font-weight: 800; list-style: none; }
.gbg-faq summary::-webkit-details-marker { display: none; }
.gbg-faq summary::after { content: '+'; float: right; color: var(--pink); font-weight: 900; }
.gbg-faq details[open] summary::after { content: '–'; }
.gbg-faq p { margin: 10px 0 0; color: #555; font-weight: 600; }
.gbg-eraform { max-width: 1000px; margin: 24px auto 0; }
.gbg-eraform h4 { font-family: var(--display); text-transform: uppercase; font-size: 20px; margin: 0 0 6px; }

/* ============ BRAND BOOK / PRESS ============ */
.bb-wrap { max-width: 1100px; margin: 0 auto; padding: 0 26px; }
.bb-hero { position: relative; overflow: hidden; background: var(--black); color: #fff; text-align: center; padding: 96px 26px 86px; }
.bb-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(120% 80% at 50% 0%, rgba(255,46,154,.18), transparent 60%), radial-gradient(100% 70% at 50% 100%, rgba(185,32,37,.22), transparent 60%); }
.bb-hero > * { position: relative; }
.bb-hero .ey { color: var(--pink); letter-spacing: 5px; text-transform: uppercase; font-weight: 900; font-size: 12px; }
.bb-hero h1 { font-family: var(--display); font-size: clamp(46px,9vw,118px); margin: .12em 0 0; text-transform: uppercase; line-height: .88; }
.bb-hero p { color: #c2c2c9; max-width: 620px; margin: 20px auto 0; font-size: 16px; }
.bb-sec { padding: 62px 0; border-bottom: 1px solid #ececec; }
.bb-sec h2 { font-family: var(--display); font-size: clamp(28px,4vw,46px); text-transform: uppercase; margin: 0 0 6px; }
.bb-sec .sub { color: var(--muted); font-weight: 600; margin: 0 0 28px; max-width: 720px; }
.bb-num { color: var(--pink); font-family: var(--display); margin-right: 12px; }
.bb-logos { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.bb-logobox { display: flex; align-items: center; justify-content: center; min-height: 210px; border: 2px solid var(--black); }
.bb-logobox.light { background: #fff; }
.bb-logobox.dark { background: var(--black); border-color: var(--pink); }
.bb-logobox .wordmark .line { font-size: 46px; }
.bb-logobox .wordmark .g3 { font-size: 48px; margin-top: -19px; }
.bb-logobox.dark .wordmark .g1 { -webkit-text-stroke-color: rgba(255,255,255,.5); }
.bb-logobox.dark .wordmark .g2 { color: #fff; }
.bb-sig { font-family: var(--script); color: var(--pink); font-size: 84px; line-height: 1; text-shadow: 0 0 22px rgba(255,46,154,.35); }
.bb-colors { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 14px; }
.bb-sw { border: 1px solid #e6e6e6; border-radius: 12px; overflow: hidden; }
.bb-sw .chip { height: 114px; }
.bb-sw .info { padding: 12px 14px; }
.bb-sw .nm { font-weight: 800; font-size: 13px; }
.bb-sw .hx { color: var(--muted); font-size: 12px; font-family: var(--display); letter-spacing: 1px; }
.bb-type { display: flex; flex-direction: column; gap: 26px; }
.bb-type .row { border-left: 4px solid var(--pink); padding-left: 18px; }
.bb-type .lab { font-size: 12px; text-transform: uppercase; letter-spacing: 2px; color: var(--muted); font-weight: 800; }
.bb-type .anton { font-family: var(--display); font-size: clamp(34px,6vw,54px); text-transform: uppercase; }
.bb-type .archivo { font-family: var(--sans); font-size: 24px; font-weight: 700; }
.bb-type .allura { font-family: var(--script); font-size: clamp(48px,8vw,68px); color: var(--pink); line-height: 1; }
.bb-worlds { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.bb-world { padding: 34px; border: 2px solid var(--black); }
.bb-world.good { background: var(--bone); }
.bb-world.bad { background: var(--black); color: #fff; border-color: var(--pink); }
.bb-world h3 { font-family: var(--display); font-size: 34px; margin: 0 0 4px; }
.bb-world.bad h3 { color: #fff; }
.bb-world .ac { font-weight: 900; letter-spacing: 2px; text-transform: uppercase; font-size: 12px; }
.bb-world.good .ac { color: var(--gold); }
.bb-world.bad .ac { color: var(--pink); }
.bb-world ul { margin: 14px 0 0; padding-left: 18px; font-size: 14px; line-height: 1.7; }
.bb-voice { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.bb-voice .col { padding: 24px; border-radius: 12px; }
.bb-voice .do { background: #eafbf0; }
.bb-voice .dont { background: #fdeef0; }
.bb-voice h4 { margin: 0 0 10px; font-size: 13px; text-transform: uppercase; letter-spacing: 1.5px; }
.bb-voice ul { margin: 0; padding-left: 18px; }
.bb-voice li { margin: 0 0 8px; font-size: 14px; }
/* press */
.pr-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 14px; }
.pr-fact { border: 1px solid #e6e6e6; border-radius: 12px; padding: 18px; }
.pr-fact .k { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); font-weight: 800; }
.pr-fact .v { font-family: var(--display); font-size: 24px; margin-top: 6px; }
.pr-quote { font-family: var(--display); font-size: clamp(26px,4vw,46px); text-transform: uppercase; line-height: 1.04; margin: 0; }
.pr-quote .pink { color: var(--pink); }
.pr-quote .gold { color: var(--gold); }
.pr-quote .red { color: var(--pink); }
.pr-byline { color: var(--muted); font-weight: 700; margin-top: 18px; text-transform: uppercase; letter-spacing: 1px; font-size: 13px; }
.pr-cta { background: var(--black); color: #fff !important; padding: 13px 26px; display: inline-block; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; font-size: 13px; }
.pr-cta:hover { background: var(--pink); }
.pr-feat { display: flex; flex-wrap: wrap; gap: 26px 40px; align-items: center; font-family: var(--display); font-size: 22px; text-transform: uppercase; color: #b9b9bf; letter-spacing: 1px; }
.pr-news { list-style: none; margin: 0; padding: 0; }
.pr-news li { padding: 16px 0; border-bottom: 1px solid #ececec; display: flex; gap: 18px; align-items: baseline; }
.pr-news .date { color: var(--pink); font-weight: 900; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; white-space: nowrap; }
@media (max-width: 760px) { .bb-logos, .bb-worlds, .bb-voice { grid-template-columns: 1fr; } }

/* ============ RESPONSIVE ============ */
@media (max-width: 900px) {
  .gbg-nav { display: none; }
  .gbg-topbar { grid-template-columns: 1fr auto; }
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .gbg-split { flex-direction: column; height: auto; }
  .gbg-side { height: 54vh; }
  .gbg-side:hover { flex: 1; }
}
