/*
Theme Name: Wired to Be Wealthy
Theme URI: https://yourdomain.com
Author: Wired to Be Wealthy
Author URI: https://yourdomain.com
Description: Personal Finance Redefined — the official Wired to Be Wealthy WordPress theme.
Version: 1.0
License: Private
*/

/* ─── RESET & ROOT ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #0f0f0b;
  --bg2:       #161610;
  --bg3:       #1e1e16;
  --gold:      #c9a84c;
  --gold-lt:   #e8c97a;
  --gold-dk:   #9a7830;
  --cream:     #f5eed8;
  --cream-dk:  #c8b98a;
  --white:     #ffffff;
  --muted:     #7a7060;
  --border:    rgba(201,168,76,0.2);
  --border-lt: rgba(201,168,76,0.08);
  --radius:    4px;
  --gold-grad: linear-gradient(135deg, #9a7830 0%, #e8c97a 40%, #c9a84c 60%, #9a7830 100%);
  --gold-text: linear-gradient(135deg, #b8892a 0%, #f0d070 35%, #c9a84c 55%, #a07828 100%);
}

html { scroll-behavior: smooth; }
body {
  font-family: "Lato", sans-serif;
  background: var(--bg);
  color: var(--cream);
  overflow-x: hidden;
  line-height: 1.7;
}

/* ─── GOLD TEXT ─── */
.gold {
  background: var(--gold-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.gold-solid { color: var(--gold); }

/* ─── NOISE OVERLAY ─── */
body::before {
  content: "";
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 0; opacity: .4;
}

/* ─── NAV ─── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 5%; height: 90px;
  background: rgba(15,15,11,0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-lt);
  transition: all .3s;
}
nav.scrolled { border-bottom-color: var(--border); }

/* ── Header logo — significantly enlarged ── */
.nav-logo img { 
  height: 78px; 
  width: auto; 
  object-fit: contain;
transition: opacity 0.2s ease;
}

.nav-logo img: hover { 
  opacity: 0.85;
}

/* Slightly taller nav to accommodate larger logo */
nav {
  height: 80px;
}

.nav-links { display: flex; gap: 2rem; list-style: none; }
.nav-links a {
  font-family: "Cinzel", serif; font-size: .72rem;
  letter-spacing: .12em; color: var(--cream-dk);
  text-decoration: none; text-transform: uppercase; transition: color .2s;
}
.nav-links a:hover { color: var(--gold-lt); }
.nav-cta {
  font-family: "Cinzel", serif; font-size: .68rem;
  letter-spacing: .1em; text-transform: uppercase;
  padding: .55rem 1.4rem; border: 1px solid var(--gold);
  color: var(--gold); background: transparent;
  cursor: pointer; transition: all .25s; text-decoration: none;
}
.nav-cta:hover { background: var(--gold); color: var(--bg); }
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  cursor: pointer; background: none; border: none; padding: 4px;
}
.hamburger span { display: block; width: 24px; height: 1.5px; background: var(--gold); transition: .3s; }

/* ─── HERO ─── */
.hero {
  min-height: 100vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center; padding: 100px 5% 80px;
  position: relative; overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 40%, rgba(201,168,76,.07) 0%, transparent 70%),
              radial-gradient(ellipse 40% 40% at 20% 80%, rgba(201,168,76,.04) 0%, transparent 60%);
}
.hero-lines { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.hero-lines::before, .hero-lines::after {
  content: ""; position: absolute; width: 1px;
  background: linear-gradient(to bottom, transparent, var(--gold), transparent);
  opacity: .15; animation: lineFloat 8s ease-in-out infinite;
}
.hero-lines::before { left: 20%; height: 60%; top: 20%; }
.hero-lines::after  { right: 20%; height: 40%; top: 30%; animation-delay: 3s; }
@keyframes lineFloat {
  0%,100% { opacity: .05; transform: scaleY(.8); }
  50%      { opacity: .2;  transform: scaleY(1.1); }
}
.hero-logo {
  width: min(220px, 45vw); margin-bottom: 2.5rem;
  animation: fadeUp .9s ease both;
  filter: drop-shadow(0 0 40px rgba(201,168,76,.25));
}
.hero-eyebrow {
  font-family: "Cinzel", serif; font-size: 1rem;
  letter-spacing: .22em;
  text-transform: uppercase; margin-bottom: 1.4rem;
  animation: fadeUp .9s .1s ease both;

/* Gold gradient — same as .gold class */
  background: linear-gradient(135deg, #b8892a 0%, #f0d070 35%, #c9a84c 55%, #a07828 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-headline {
  font-family: "Playfair Display", serif;
  font-size: clamp(2.4rem, 6vw, 4.8rem);
  font-weight: 700; line-height: 1.12; color: var(--cream);
  max-width: 820px; margin-bottom: 1.6rem;
  animation: fadeUp .9s .2s ease both;
}
.hero-headline em { font-style: italic; }
.hero-sub {
  font-size: 1.05rem; color: var(--cream-dk);
  max-width: 560px; margin-bottom: 2.8rem; line-height: 1.8;
  animation: fadeUp .9s .3s ease both;
}
.hero-btns {
  display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center;
  animation: fadeUp .9s .4s ease both;
}
.hero-scroll {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  animation: fadeUp .9s .8s ease both;
}
.hero-scroll span { font-family: "Cinzel", serif; font-size: .6rem; letter-spacing: .2em; color: var(--muted); text-transform: uppercase; }
.scroll-line { width: 1px; height: 48px; background: linear-gradient(to bottom, var(--gold), transparent); animation: scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse {
  0%,100% { opacity: .3; transform: scaleY(.8) translateY(0); }
  50%      { opacity: 1;  transform: scaleY(1) translateY(4px); }
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── BUTTONS ─── */
.btn-primary {
  font-family: "Cinzel", serif; font-size: .72rem;
  letter-spacing: .12em; text-transform: uppercase;
  padding: .9rem 2.2rem; background: var(--gold-grad);
  color: var(--bg); border: none; cursor: pointer;
  text-decoration: none; font-weight: 700; transition: all .25s; display: inline-block;
}
.btn-primary:hover { filter: brightness(1.1); transform: translateY(-2px); box-shadow: 0 8px 30px rgba(201,168,76,.3); }
.btn-outline {
  font-family: "Cinzel", serif; font-size: .72rem;
  letter-spacing: .12em; text-transform: uppercase;
  padding: .9rem 2.2rem; border: 1px solid var(--gold);
  color: var(--gold); background: transparent; cursor: pointer;
  text-decoration: none; transition: all .25s; display: inline-block;
}
.btn-outline:hover { background: rgba(201,168,76,.08); transform: translateY(-2px); }

/* ─── TICKER ─── */
.ticker { background: var(--gold-grad); padding: .6rem 0; overflow: hidden; }
.ticker-inner { display: flex; gap: 3rem; animation: tickerScroll 30s linear infinite; width: max-content; }
.ticker-item {
  font-family: "Cinzel", serif; font-size: .68rem;
  letter-spacing: .15em; color: var(--bg); text-transform: uppercase;
  white-space: nowrap; display: flex; align-items: center; gap: 1rem;
}
.ticker-item::after { content: "◆"; opacity: .5; }
@keyframes tickerScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ─── SECTION COMMONS ─── */
section { position: relative; z-index: 1; }
.section-wrap { max-width: 1200px; margin: 0 auto; padding: 0 5%; }
.section-label {
  font-family: "Cinzel", serif; font-size: .65rem; letter-spacing: .22em;
  color: var(--gold); text-transform: uppercase;
  display: flex; align-items: center; gap: .8rem; margin-bottom: 1.2rem;
}
.section-label::before { content: ""; display: block; width: 28px; height: 1px; background: var(--gold); }
.section-title { font-family: "Playfair Display", serif; font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 700; line-height: 1.2; color: var(--cream); margin-bottom: 1rem; }
.section-sub { font-size: 1rem; color: var(--cream-dk); max-width: 560px; line-height: 1.8; }

/* ─── ABOUT STRIP ─── */
.about-strip { padding: 80px 0; background: var(--bg2); border-top: 1px solid var(--border-lt); border-bottom: 1px solid var(--border-lt); }
.about-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.stat-card { padding: 1.6rem; border: 1px solid var(--border); background: rgba(201,168,76,.03); transition: border-color .3s, background .3s; }
.stat-card:hover { border-color: var(--gold); background: rgba(201,168,76,.06); }
.stat-num { font-family: "Playfair Display", serif; font-size: 2.2rem; font-weight: 700; line-height: 1; margin-bottom: .3rem; }
.stat-label { font-family: "Cinzel", serif; font-size: .62rem; letter-spacing: .12em; color: var(--muted); text-transform: uppercase; }

/* ─── BLOG POSTS ─── */
.posts-section { padding: 100px 0; }
.posts-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 3rem; }
.posts-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 1.5px; background: var(--border-lt); }
.post-card { background: var(--bg2); padding: 2rem; cursor: pointer; transition: background .25s; position: relative; overflow: hidden; text-decoration: none; display: block; color: inherit; }
.post-card::before { content: ""; position: absolute; bottom: 0; left: 0; width: 100%; height: 2px; background: var(--gold-grad); transform: scaleX(0); transform-origin: left; transition: transform .35s; }
.post-card:hover { background: var(--bg3); }
.post-card:hover::before { transform: scaleX(1); }
.post-card.featured { padding: 2.5rem; }
.post-card.featured .post-title { font-size: 1.6rem; line-height: 1.25; }
.post-tag { font-family: "Cinzel", serif; font-size: .6rem; letter-spacing: .15em; color: var(--gold); text-transform: uppercase; margin-bottom: .9rem; display: block; }
.post-title { font-family: "Playfair Display", serif; font-size: 1.05rem; font-weight: 600; line-height: 1.4; color: var(--cream); margin-bottom: .8rem; }
.post-excerpt { font-size: .88rem; color: var(--cream-dk); line-height: 1.7; margin-bottom: 1.2rem; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.post-meta { display: flex; gap: 1rem; align-items: center; font-size: .75rem; color: var(--muted); font-family: "Cinzel", serif; letter-spacing: .06em; }
.post-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--muted); }

/* ─── ORNAMENT DIVIDER ─── */
.ornament-divider { display: flex; align-items: center; justify-content: center; gap: 1rem; padding: 0 5%; margin: 20px 0; }
.ornament-divider::before, .ornament-divider::after { content: ""; flex: 1; height: 1px; background: linear-gradient(to right, transparent, var(--border), transparent); }
.ornament { font-family: "Cinzel", serif; font-size: .7rem; color: var(--gold); letter-spacing: .2em; }

/* ─── EMAIL OPT-IN ─── */
.optin-section { padding: 0 0 100px; }
.optin-box { background: var(--bg2); border: 1px solid var(--border); padding: 60px 5%; text-align: center; position: relative; overflow: hidden; }
.optin-box::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(201,168,76,.05) 0%, transparent 70%); pointer-events: none; }
.optin-eyebrow { font-family: "Cinzel", serif; font-size: .65rem; letter-spacing: .22em; color: var(--gold); text-transform: uppercase; margin-bottom: 1rem; }
.optin-headline { font-family: "Playfair Display", serif; font-size: clamp(1.6rem, 3.5vw, 2.6rem); font-weight: 700; color: var(--cream); margin-bottom: 1rem; line-height: 1.2; }
.optin-sub { font-size: .95rem; color: var(--cream-dk); max-width: 480px; margin: 0 auto 2.2rem; line-height: 1.8; }
.optin-perks { display: flex; justify-content: center; gap: 2rem; flex-wrap: wrap; margin-bottom: 2rem; }
.optin-perk { font-size: .82rem; color: var(--cream-dk); display: flex; align-items: center; gap: .5rem; }
.optin-perk::before { content: "✦"; color: var(--gold); font-size: .7rem; }
.optin-form { display: flex; gap: .75rem; flex-wrap: wrap; justify-content: center; max-width: 520px; margin: 0 auto; }
.optin-form input { flex: 1; min-width: 220px; padding: .9rem 1.3rem; background: rgba(255,255,255,.04); border: 1px solid var(--border); color: var(--cream); font-family: "Lato", sans-serif; font-size: .9rem; outline: none; transition: border-color .2s; }
.optin-form input::placeholder { color: var(--muted); }
.optin-form input:focus { border-color: var(--gold); }
.optin-note { font-size: .72rem; color: var(--muted); margin-top: 1rem; font-style: italic; }
.optin-success { display: none; padding: 1rem 2rem; border: 1px solid var(--gold); color: var(--gold); font-family: "Cinzel", serif; font-size: .8rem; letter-spacing: .1em; }

/* ─── PRODUCTS ─── */
.products-section { padding: 100px 0; background: var(--bg2); }
.products-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border-lt); margin-top: 3rem; }
.product-card { background: var(--bg2); padding: 2.2rem; transition: background .25s; position: relative; display: flex; flex-direction: column; }
.product-card:hover { background: var(--bg3); }
.product-card.featured-product { background: var(--bg3); border: 1px solid var(--border); }
.product-badge { font-family: "Cinzel", serif; font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; padding: .3rem .8rem; background: var(--gold-grad); color: var(--bg); font-weight: 700; display: inline-block; margin-bottom: 1.2rem; align-self: flex-start; }
.product-icon { width: 48px; height: 48px; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; margin-bottom: 1.2rem; font-size: 1.3rem; }
.product-name { font-family: "Playfair Display", serif; font-size: 1.15rem; font-weight: 600; color: var(--cream); margin-bottom: .6rem; line-height: 1.3; }
.product-desc { font-size: .88rem; color: var(--cream-dk); line-height: 1.7; margin-bottom: 1.4rem; flex: 1; }
.product-price { font-family: "Playfair Display", serif; font-size: 1.5rem; font-weight: 700; margin-bottom: 1.2rem; }
.product-price .cents { font-size: .9rem; vertical-align: super; }
.product-price .original { font-size: .85rem; font-family: "Lato", sans-serif; color: var(--muted); text-decoration: line-through; margin-left: .5rem; font-weight: 400; }
.btn-add { font-family: "Cinzel", serif; font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; padding: .75rem 1.4rem; border: 1px solid var(--gold); color: var(--gold); background: transparent; cursor: pointer; transition: all .25s; width: 100%; text-align: center; }
.btn-add:hover { background: var(--gold-grad); color: var(--bg); border-color: transparent; }
.btn-add-primary { background: var(--gold-grad); color: var(--bg); border-color: transparent; font-weight: 700; }

/* ─── CATEGORIES ─── */
.categories-section { padding: 80px 0; }
.cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--border-lt); margin-top: 3rem; }
.cat-card { background: var(--bg2); padding: 2rem 1.5rem; text-align: center; cursor: pointer; transition: background .25s; border-bottom: 2px solid transparent; text-decoration: none; display: block; color: inherit; }
.cat-card:hover { background: var(--bg3); border-bottom-color: var(--gold); }
.cat-icon { font-size: 1.8rem; margin-bottom: .8rem; }
.cat-name { font-family: "Cinzel", serif; font-size: .75rem; letter-spacing: .12em; color: var(--cream); text-transform: uppercase; display: block; margin-bottom: .4rem; }
.cat-count { font-size: .78rem; color: var(--muted); }

/* ─── PARTNERSHIPS ─── */
.partners-section { padding: 80px 0; background: var(--bg2); border-top: 1px solid var(--border-lt); }
.partners-header { text-align: center; margin-bottom: 3rem; }
.partners-value { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5px; background: var(--border-lt); margin-bottom: 3rem; }
.value-card { background: var(--bg2); padding: 2rem 1.8rem; transition: background .25s; }
.value-card:hover { background: var(--bg3); }
.value-num { font-family: "Playfair Display", serif; font-size: 1.8rem; font-weight: 700; margin-bottom: .4rem; }
.value-title { font-family: "Cinzel", serif; font-size: .68rem; letter-spacing: .1em; color: var(--gold); text-transform: uppercase; margin-bottom: .6rem; }
.value-desc { font-size: .85rem; color: var(--cream-dk); line-height: 1.7; }
.partner-cta { text-align: center; padding: 2.5rem; border: 1px solid var(--border); background: rgba(201,168,76,.03); }
.partner-cta p { font-size: .95rem; color: var(--cream-dk); margin-bottom: 1.5rem; line-height: 1.8; max-width: 500px; margin-left: auto; margin-right: auto; }

/* ════════════════════════════════
   FOOTER — compact, 4-column
════════════════════════════════ */

footer {
  background: var(--bg);
  border-top: 1px solid var(--border-lt);
  padding: 28px 5% 0;            /* tight top padding */
}

/* ── Main row: brand | centre cols | company ── */
.footer-inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 2rem;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border-lt);
}

/* ── LEFT — brand block ── */
.footer-brand {
  flex: 0 0 240px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* ── Footer logo — significantly enlarged ── */
.footer-brand img {
  height: 110px;                 /* was 80px — much more prominent */
  width: auto;
  object-fit: contain;
  margin-bottom: 0.8rem;
  display: block;
}

.footer-brand p {
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.7;
  max-width: 220px;
  margin-bottom: 0.9rem;
}

/* ── Social icons ── */
.footer-socials {
  display: flex;
  gap: 7px;
}

.social-btn {
  width: 30px;
  height: 30px;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
}
.social-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
}

/* ── CENTRE — blog + shop columns side by side ── */
.footer-centre {
  display: flex;
  gap: 2.5rem;
  flex: 1;
  justify-content: center;
  padding-top: 4px;
}

/* ── RIGHT — company column, flush right, parallel to logo ── */
.footer-right {
  flex: 0 0 160px;
  display: flex;
  justify-content: flex-end;
  padding-top: 4px;
}

/* ── Column shared styles ── */
.footer-col h5 {
  font-family: "Cinzel", serif;
  font-size: 0.65rem;
  letter-spacing: 0.14em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 0.75rem;
}

.footer-col ul {
  list-style: none;
}

.footer-col ul li {
  margin-bottom: 0.38rem;        /* tight line spacing */
}

.footer-col ul li a {
  font-size: 0.8rem;
  color: var(--muted);
  text-decoration: none;
  transition: color 0.2s;
}
.footer-col ul li a:hover { color: var(--cream); }

/* ── Bottom bar — minimal height ── */
.footer-bottom {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.6rem;
  padding: 10px 0;               /* very tight — minimises bottom strip height */
  justify-content: space-between;
}

.footer-bottom p {
  font-size: 0.7rem;
  color: var(--muted);
  margin: 0;
}

.disclaimer {
  font-size: 0.66rem;
  color: var(--muted);
  font-style: italic;
}

.footer-legal {
  display: flex;
  gap: 1rem;
}

.footer-legal a {
  font-size: 0.7rem;
  color: var(--muted);
  text-decoration: none;
  transition: color 0.2s;
}
.footer-legal a:hover { color: var(--gold); }

/* ── Responsive ── */
@media (max-width: 900px) {
  .footer-inner {
    flex-wrap: wrap;
  }
  .footer-brand {
    flex: 0 0 100%;
  }
  .footer-centre {
    flex: 1;
    justify-content: flex-start;
  }
  .footer-right {
    flex: 0 0 auto;
    justify-content: flex-start;
  }
}

@media (max-width: 600px) {
  .footer-inner {
    flex-direction: column;
    gap: 1.5rem;
  }
  .footer-brand img {
    height: 80px;
  }
  .footer-right {
    flex: none;
    width: 100%;
  }
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.3rem;
  }
}

/* ─── MODAL ─── */
.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.8); z-index: 200; align-items: center; justify-content: center; padding: 5%; }
.modal-overlay.open { display: flex; }
.modal-box { background: var(--bg2); border: 1px solid var(--border); padding: 2.5rem; max-width: 480px; width: 100%; position: relative; animation: fadeUp .3s ease; }
.modal-close { position: absolute; top: 1rem; right: 1rem; background: none; border: none; color: var(--muted); font-size: 1.2rem; cursor: pointer; }
.modal-close:hover { color: var(--cream); }
.modal-title { font-family: "Playfair Display", serif; font-size: 1.4rem; font-weight: 700; color: var(--cream); margin-bottom: .5rem; }
.modal-sub { font-size: .9rem; color: var(--cream-dk); margin-bottom: 1.8rem; line-height: 1.7; }
.modal-form input { width: 100%; padding: .85rem 1.2rem; background: rgba(255,255,255,.04); border: 1px solid var(--border); color: var(--cream); font-family: "Lato", sans-serif; font-size: .9rem; outline: none; margin-bottom: .75rem; transition: border-color .2s; }
.modal-form input:focus { border-color: var(--gold); }

/* ─── SCROLL ANIMATIONS ─── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .nav-links.open { display: flex; flex-direction: column; position: fixed; inset: 72px 0 0; background: var(--bg2); padding: 2rem 5%; gap: 1.5rem; z-index: 99; border-top: 1px solid var(--border-lt); }
  .nav-links.open a { font-size: .9rem; }
  .about-inner { grid-template-columns: 1fr; }
  .posts-grid { grid-template-columns: 1fr; }
  .products-grid { grid-template-columns: 1fr 1fr; }
  .cat-grid { grid-template-columns: 1fr 1fr; }
  .partners-value { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 600px) {
  .products-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .posts-header { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .about-stats { grid-template-columns: 1fr 1fr; }
}
/* ── Wrapper: icon + flanking arrows in one centred row ── */
.hero-icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  width: 100%;
  max-width: 820px;
  margin: 0 auto 2.5rem;
}

/* ── The W logo icon ── */
.hero-logo {
  width: min(180px, 38vw);
  height: auto;
  flex-shrink: 0;
  filter: drop-shadow(0 0 40px rgba(201, 168, 76, 0.28));
  animation: fadeUp 0.9s ease both;
}

/* ── Arrow assemblies (left and right) ── */
.hero-arrow-line {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 60px;
  max-width: 200px;
}

.hero-arrow-left {
  justify-content: flex-end;
  padding-right: 22px;
}

.hero-arrow-right {
  justify-content: flex-start;
  padding-left: 22px;
}

/* ── The horizontal line ── */
.arrow-line {
  display: block;
  flex: 1;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent 0%,
    rgba(201, 168, 76, 0.25) 20%,
    rgba(201, 168, 76, 0.7) 50%,
    rgba(201, 168, 76, 0.25) 80%,
    transparent 100%
  );
}

/* Left line fades toward the icon (right side is brighter) */
.hero-arrow-left .arrow-line {
  background: linear-gradient(
    to right,
    transparent 0%,
    rgba(201, 168, 76, 0.2) 30%,
    rgba(201, 168, 76, 0.65) 100%
  );
}

/* Right line fades away from the icon (left side is brighter) */
.hero-arrow-right .arrow-line {
  background: linear-gradient(
    to right,
    rgba(201, 168, 76, 0.65) 0%,
    rgba(201, 168, 76, 0.2) 70%,
    transparent 100%
  );
}

/* ── Diamond tips ── */
.arrow-diamond {
  display: block;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  background: #c9a84c;
  transform: rotate(45deg);
  opacity: 0.75;
  box-shadow: 0 0 8px rgba(201, 168, 76, 0.5);
}

/* Left side: diamond is on the far left end */
.hero-arrow-left .arrow-diamond {
  margin-right: 6px;
}

/* Right side: diamond is on the far right end */
.hero-arrow-right .arrow-diamond {
  margin-left: 6px;
}

/* ── Fade-up animation (shared with hero text) ── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Responsive: hide arrows on small screens ── */
@media (max-width: 600px) {
  .hero-arrow-line {
    display: none;
  }
  .hero-icon-wrap {
    justify-content: center;
  }
}