/*
Theme Name: MOONROAD Brand Site
Theme URI: https://www.moonroadhk.com/
Author: MOONROAD HK LIMITED
Description: One-page bilingual (Traditional Chinese + English) brand site for MOONROAD CARD STORE, with a built-in black-and-gold blog. Premium design, SEO, structured data, store locations, services, events gallery and a For-Brands section.
Version: 1.2
Requires at least: 5.8
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: moonroad
*/

/* ============================================================
   MOONROAD CARD STORE — Brand site styles
   ============================================================ */

:root{
  --bg:#0b0b0d;
  --bg-dark:#0c0c0f;
  --bg-darker:#08080a;
  --bg-card:#141417;
  --bg-card-2:#17171b;
  --gold:#e0b85c;
  --gold-bright:#f1d79a;
  --gold-deep:#b8923f;
  --text:#f3efe6;
  --muted:#9d978c;
  --muted-2:#736e66;
  --line:rgba(224,184,92,.16);
  --line-soft:rgba(255,255,255,.07);
  --font-display:"Playfair Display","Noto Serif TC",Georgia,serif;
  --font-body:"Inter","Noto Sans TC",system-ui,-apple-system,sans-serif;
  --nav-h:68px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h);-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);font-weight:300;line-height:1.75;
  font-size:clamp(15px,1.05vw,16.5px);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:600;line-height:1.2}
p{margin:0 0 1em}
ul{margin:0;padding:0;list-style:none}

/* Language toggle visibility */
html.lang-zh .en{display:none}
html.lang-en .zh{display:none}
html.lang-zh{font-family:var(--font-body)}

.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:.95em 1.8em;font-family:var(--font-body);font-weight:500;
  font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid transparent;border-radius:2px;cursor:pointer;
  transition:all .35s var(--ease);white-space:nowrap;
}
.btn--gold{background:linear-gradient(135deg,var(--gold-bright),var(--gold) 55%,var(--gold-deep));color:#1a1408;box-shadow:0 6px 24px -10px rgba(224,184,92,.6)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 12px 34px -10px rgba(224,184,92,.75);filter:brightness(1.06)}
.btn--ghost{border-color:var(--line);color:var(--text);background:transparent}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-bright)}
.btn--sm{padding:.7em 1.25em;font-size:.72rem}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);
  display:flex;align-items:center;transition:background .4s,border-color .4s,backdrop-filter .4s;
  border-bottom:1px solid transparent}
.nav.is-scrolled{background:rgba(8,8,10,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom-color:var(--line-soft)}
.nav__inner{max-width:var(--maxw);width:100%;margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.nav__logo img{height:38px;width:auto}
.nav__links{display:flex;gap:1.9rem}
.nav__links a{font-size:.86rem;letter-spacing:.05em;color:var(--muted);position:relative;padding:.3em 0;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--text)}
.nav__links a:hover::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:.85rem}
.lang-toggle{background:none;border:1px solid var(--line);color:var(--muted);
  font-family:var(--font-body);font-size:.74rem;letter-spacing:.1em;
  padding:.5em .85em;border-radius:2px;cursor:pointer;transition:all .3s}
.lang-toggle:hover{border-color:var(--gold);color:var(--gold-bright)}
.nav__burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;padding:8px}
.nav__burger span{display:block;height:1.5px;width:100%;background:var(--text);transition:transform .35s var(--ease),opacity .25s}
.nav.menu-open .nav__burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.menu-open .nav__burger span:nth-child(2){opacity:0}
.nav.menu-open .nav__burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;
  padding:calc(var(--nav-h) + 2rem) clamp(1.25rem,4vw,2.5rem) 3.5rem;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero__scrim{position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 50% 30%,rgba(8,8,10,.30),rgba(8,8,10,.78) 75%),
    linear-gradient(to bottom,rgba(8,8,10,.72),rgba(8,8,10,.45) 38%,rgba(8,8,10,.95))}
.hero__content{position:relative;z-index:2;max-width:880px;display:flex;flex-direction:column;align-items:center}
.eyebrow{font-size:.78rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);
  margin:0 0 1.6rem;font-weight:400;padding-left:.42em}
.hero__wordmark{width:clamp(250px,42vw,500px);height:auto;margin-bottom:1.6rem;
  filter:drop-shadow(0 4px 30px rgba(0,0,0,.5))}
.hero__title{font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.6rem,4.2vw,3.1rem);letter-spacing:.02em;margin-bottom:1rem}
.hero__sub{color:var(--text);opacity:.84;max-width:560px;margin:0 auto 2.4rem;
  font-size:clamp(.95rem,1.4vw,1.1rem);font-weight:300}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.hero__stats{position:relative;z-index:2;display:flex;flex-wrap:wrap;justify-content:center;
  gap:clamp(1.8rem,6vw,4.5rem);margin-top:clamp(2.5rem,6vw,4.5rem);padding-top:2.2rem;
  border-top:1px solid var(--line);width:min(760px,90%)}
.stat{display:flex;flex-direction:column;align-items:center;gap:.35rem}
.stat__num{font-family:var(--font-display);font-size:clamp(1.9rem,4vw,2.9rem);font-weight:600;
  color:var(--gold-bright);line-height:1}
.stat__num .plus{color:var(--gold);font-size:.7em;vertical-align:.1em}
.stat__label{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.hero__scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:2;
  width:26px;height:42px;border:1.5px solid var(--line);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.hero__scroll span{width:3px;height:8px;border-radius:2px;background:var(--gold);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}100%{opacity:0}}

/* ---------- Sections ---------- */
.section{padding:clamp(4.5rem,9vw,8rem) 0;position:relative}
.section--dark{background:var(--bg-dark)}
.section--darker{background:var(--bg-darker)}
.section__head{max-width:760px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.section__num{display:block;font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.4rem);
  color:transparent;-webkit-text-stroke:1px var(--gold-deep);opacity:.55;line-height:1;margin-bottom:.6rem}
.section__title{font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.7rem,3.6vw,2.7rem);letter-spacing:.01em;margin-bottom:.7rem}
.section__kicker{color:var(--gold);font-size:clamp(.95rem,1.5vw,1.1rem);letter-spacing:.04em;font-weight:400;margin:0}

/* ---------- Story ---------- */
.story{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.story__text p{color:var(--muted);margin-bottom:1.2em}
.story__text p:last-child{margin-bottom:0}
.story__media img{border-radius:4px;border:1px solid var(--line);box-shadow:0 30px 60px -30px rgba(0,0,0,.8)}
.pullquote{font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(1.3rem,3vw,2.1rem);line-height:1.45;text-align:center;color:var(--gold-bright);
  max-width:880px;margin:clamp(3rem,6vw,5rem) auto;padding:clamp(2rem,4vw,3rem) 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---------- Values ---------- */
.values{margin-top:clamp(3rem,6vw,5rem)}
.values__title{font-family:var(--font-display);font-size:clamp(1.3rem,2.4vw,1.7rem);margin-bottom:1.8rem;text-align:center}
.values__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.value{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:4px;
  padding:1.8rem 1.5rem;transition:transform .4s var(--ease),border-color .4s,background .4s}
.value:hover{transform:translateY(-6px);border-color:var(--line);background:var(--bg-card-2)}
.value__icon{color:var(--gold);font-size:1.4rem;display:block;margin-bottom:.9rem}
.value h4{font-size:1.15rem;margin-bottom:.5rem}
.value p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------- Network ---------- */
.netstats{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,5vw,4rem);justify-content:center;
  padding:2rem 0 clamp(2.5rem,5vw,3.5rem);margin-bottom:clamp(1rem,3vw,2rem);
  border-bottom:1px solid var(--line)}
.netstat{text-align:center}
.netstat__num{display:block;font-family:var(--font-display);font-weight:600;
  font-size:clamp(2rem,4.5vw,3.2rem);color:var(--gold-bright);line-height:1}
.netstat__cap{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:.5rem;display:block}
.stores{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem}
.store{border:1px solid var(--line-soft);border-radius:5px;overflow:hidden;background:var(--bg-card);
  transition:transform .45s var(--ease),border-color .45s}
.store:hover{transform:translateY(-6px);border-color:var(--line)}
.store__img{aspect-ratio:4/3;overflow:hidden;background:#000}
.store__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.store:hover .store__img img{transform:scale(1.06)}
.store__img--brand{display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 40%,rgba(224,184,92,.10),transparent 70%),var(--bg-darker)}
.store__emblem{width:90px;height:90px;opacity:.65}
.store__meta{padding:1.2rem 1.3rem 1.4rem}
.store__city{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.5rem}
.store__meta h3{font-size:1.18rem;font-weight:500}
.store--jp{border-color:var(--line)}
.store--jp .store__city{color:var(--gold-bright)}

/* ---------- Experience ---------- */
.experience{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:center;
  margin-top:clamp(3.5rem,7vw,6rem)}
.experience__media img{border-radius:4px;border:1px solid var(--line);box-shadow:0 30px 60px -30px rgba(0,0,0,.8)}
.experience__text h3{font-family:var(--font-display);font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:1.5rem}
.ticks li{position:relative;padding-left:1.8rem;margin-bottom:1.1rem;color:var(--muted)}
.ticks li:last-child{margin-bottom:0}
.ticks li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;
  border:1px solid var(--gold);transform:rotate(45deg)}
.ticks b{color:var(--text);font-weight:600}

/* ---------- Store gallery ---------- */
.store-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:clamp(2rem,4vw,3rem)}
.store-gallery figure{position:relative;margin:0;border-radius:5px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line-soft)}
.store-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.store-gallery figure:hover img{transform:scale(1.07)}
.store-gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1rem .9rem;
  font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text);
  background:linear-gradient(to top,rgba(8,8,10,.9),transparent)}

/* ---------- Product strategy ---------- */
.prodstrat{margin-top:clamp(3.5rem,7vw,6rem)}
.prodstrat__title{font-family:var(--font-display);font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:1.8rem;text-align:center}
.prodstrat__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.card{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:4px;padding:1.7rem 1.4rem;
  transition:transform .4s var(--ease),border-color .4s}
.card:hover{transform:translateY(-6px);border-color:var(--line)}
.card__no{font-family:var(--font-display);font-size:1.5rem;color:var(--gold-deep);display:block;margin-bottom:.7rem}
.card h4{font-size:1.1rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.9rem;margin:0}

/* ---------- Media / influence ---------- */
.bigstats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:clamp(2.5rem,5vw,4rem)}
.bigstat{text-align:center;padding:2rem 1.2rem;border:1px solid var(--line-soft);border-radius:5px;
  background:linear-gradient(160deg,var(--bg-card),var(--bg-darker))}
.bigstat__num{display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(2.4rem,5.5vw,3.6rem);line-height:1;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent}
.bigstat__cap{display:block;margin-top:.8rem;color:var(--muted);font-size:.88rem;letter-spacing:.02em}
.socialcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-bottom:clamp(2.5rem,5vw,4rem)}
.socialcard{margin:0}
.socialcard img{border-radius:5px;border:1px solid var(--line-soft);background:#000;width:100%;height:auto}
.socialcard figcaption{margin-top:.9rem;color:var(--muted);font-size:.86rem;text-align:center}
.mediamatrix{text-align:center;max-width:820px;margin:0 auto}
.mediamatrix h3{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,1.9rem);margin-bottom:1.1rem}
.mediamatrix p{color:var(--muted)}
.mediamatrix b{color:var(--gold-bright);font-weight:600}
.celebs{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin-top:1.8rem}
.celebs li{border:1px solid var(--line);color:var(--text);padding:.5em 1.1em;border-radius:30px;
  font-size:.84rem;letter-spacing:.04em;background:rgba(224,184,92,.05)}

/* ---------- Events ---------- */
.events{margin-top:clamp(3.5rem,7vw,6rem)}
.events__title{font-family:var(--font-display);font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:1.8rem;text-align:center}
.events__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.event{border:1px solid var(--line-soft);border-radius:5px;overflow:hidden;background:var(--bg-card);
  transition:transform .45s var(--ease),border-color .45s}
.event:hover{transform:translateY(-5px);border-color:var(--line)}
.event__img{aspect-ratio:16/10;overflow:hidden;background:#000}
.event__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.event:hover .event__img img{transform:scale(1.05)}
.event__body{padding:1.5rem 1.6rem 1.7rem}
.event__body h4{font-size:1.2rem;margin-bottom:.6rem}
.event__body p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------- Operations ---------- */
.ops{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.ops__big{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,1.9rem);margin-bottom:1rem;color:var(--text)}
.ops__big b{color:var(--gold-bright);font-size:1.4em}
.ops__lead p:last-child{color:var(--muted);margin:0}
.ops__depts{display:flex;flex-wrap:wrap;gap:.8rem}
.dept{border:1px solid var(--line);border-radius:3px;padding:.85em 1.2em;font-size:.9rem;
  background:rgba(224,184,92,.04);color:var(--text)}
.teamphoto{margin:clamp(2.5rem,5vw,4rem) 0 0}
.teamphoto img{width:100%;max-height:540px;object-fit:cover;object-position:center 35%;border-radius:5px;border:1px solid var(--line);box-shadow:0 30px 60px -30px rgba(0,0,0,.8)}
.teamphoto figcaption{margin-top:.9rem;text-align:center;color:var(--muted);font-size:.86rem;letter-spacing:.1em;text-transform:uppercase}

/* ---------- Partners ---------- */
.agencies{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-bottom:clamp(2rem,4vw,3rem)}
.agency{border:1px solid var(--line-soft);border-radius:6px;padding:2.2rem;background:var(--bg-card);text-align:center;
  transition:transform .4s var(--ease),border-color .4s}
.agency:hover{transform:translateY(-5px);border-color:var(--line)}
.agency__logo{background:#f6f4ef;border-radius:6px;padding:1.8rem;margin-bottom:1.5rem;
  display:flex;align-items:center;justify-content:center;min-height:130px}
.agency__logo img{max-height:84px;width:auto;object-fit:contain}
.agency h3{font-size:1.25rem;letter-spacing:.04em;margin-bottom:.8rem}
.agency p{color:var(--muted);font-size:.92rem;margin:0}
.partners__note{text-align:center;max-width:720px;margin:0 auto;color:var(--muted);font-size:1.02rem}

/* ---------- Story lead ---------- */
.story__lead{font-family:var(--font-display);font-size:clamp(1.12rem,1.9vw,1.45rem);line-height:1.5;color:var(--text);margin-bottom:1.3em}
.story__lead b{color:var(--gold-bright);font-weight:600}

/* ---------- Services ---------- */
.services{margin-top:clamp(3.5rem,7vw,6rem)}
.services__title{font-family:var(--font-display);font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:1.8rem;text-align:center}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.svc{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:5px;padding:2rem 1.6rem;transition:transform .4s var(--ease),border-color .4s,background .4s}
.svc:hover{transform:translateY(-6px);border-color:var(--line);background:var(--bg-card-2)}
.svc__icon{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border:1px solid var(--line);border-radius:50%;color:var(--gold);margin-bottom:1.1rem}
.svc__icon svg{width:26px;height:26px}
.svc h4{font-size:1.2rem;margin-bottom:.5rem}
.svc p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------- Credentials ---------- */
.creds{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:center;
  margin:clamp(2.2rem,4vw,3.2rem) 0;padding:clamp(1.8rem,3vw,2.4rem) 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cred{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.45rem}
.cred b{font-size:1.05rem;color:var(--text);font-weight:600}
.cred__sub{color:var(--gold);font-size:.84rem;letter-spacing:.05em}
.cred--badge{padding:0}
.cred--badge img{max-height:92px;width:auto;border-radius:4px}

/* ---------- Brands we carry ---------- */
.brands{text-align:center;margin-top:clamp(1rem,3vw,2rem)}
.brands__title{font-family:var(--font-display);font-size:clamp(1.2rem,2.2vw,1.6rem);margin-bottom:1.3rem}
.brandlist{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;max-width:800px;margin:0 auto}
.brandlist li{border:1px solid var(--line);color:var(--text);padding:.5em 1.15em;border-radius:30px;
  font-size:.86rem;letter-spacing:.03em;background:rgba(224,184,92,.05);transition:border-color .3s,color .3s}
.brandlist li:hover{border-color:var(--gold);color:var(--gold-bright)}

/* ---------- Logo wall ---------- */
.logowall{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;max-width:940px;margin:0 auto 1.6rem}
.logo-tile{background:#f6f4ef;border-radius:6px;display:flex;align-items:center;justify-content:center;
  padding:1rem 1.1rem;aspect-ratio:3/2;transition:transform .35s var(--ease)}
.logo-tile:hover{transform:translateY(-4px)}
.logo-tile img{max-height:46px;max-width:100%;width:auto;height:auto;object-fit:contain}

/* ---------- Event logo card ---------- */
.event__img--logo{display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 42%,rgba(224,184,92,.12),transparent 70%),var(--bg-darker)}
.event__img--logo img{width:auto;height:auto;max-width:60%;max-height:60%;object-fit:contain}
.event:hover .event__img--logo img{transform:none}

/* ---------- Event poster card (full poster on dark) ---------- */
.event__img--poster{display:flex;align-items:center;justify-content:center;background:#08080a;overflow:hidden}
.event__img--poster img{width:auto;height:100%;max-width:100%;object-fit:contain}
.event:hover .event__img--poster img{transform:none}

/* ---------- Milestones ---------- */
.milestones{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.7rem;margin-top:clamp(1.8rem,3vw,2.6rem)}
.milestones__label{color:var(--gold);font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;margin-right:.3rem}
.milestones ul{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}
.milestones li{border:1px solid var(--line);color:var(--muted);padding:.45em 1em;border-radius:30px;
  font-size:.82rem;background:rgba(224,184,92,.04)}

/* ---------- Store address + hours ---------- */
.store__addr{margin:.5rem 0 0;font-size:.8rem;line-height:1.45;color:var(--muted)}
.stores__hours{text-align:center;color:var(--gold);font-size:.88rem;letter-spacing:.04em;margin-top:1.6rem}

/* ---------- Brand promotion callout ---------- */
.brandpromo{border:1px solid var(--line);border-radius:8px;text-align:center;
  background:linear-gradient(180deg,rgba(224,184,92,.07),rgba(224,184,92,.02));
  padding:clamp(1.6rem,3vw,2.5rem);margin-bottom:clamp(2rem,4vw,3rem)}
.brandpromo__lead{font-family:var(--font-display);font-size:clamp(1.3rem,2.4vw,1.95rem);color:var(--text);margin:0 0 .6rem;line-height:1.3}
.brandpromo__lead b{color:var(--gold-bright);font-weight:600}
.brandpromo__desc{color:var(--muted);max-width:660px;margin:0 auto 1.3rem;font-size:.98rem;line-height:1.6}
.brandpromo__list{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;margin:0;padding:0;list-style:none}
.brandpromo__list li{border:1px solid var(--gold-deep);color:var(--gold-bright);padding:.45em 1.05em;border-radius:30px;
  font-size:.85rem;letter-spacing:.03em;background:rgba(224,184,92,.06);font-weight:500}

/* ---------- Gallery ---------- */
.gallery-wrap{margin-top:clamp(2.6rem,5vw,4rem)}
.gallery__title{font-family:var(--font-display);font-size:clamp(1.3rem,2.4vw,1.8rem);text-align:center;margin-bottom:1.6rem}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
.gallery__item{padding:0;border:0;background:none;cursor:pointer;overflow:hidden;border-radius:5px;aspect-ratio:3/4;display:block}
.gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.gallery__item:hover img{transform:scale(1.06)}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;background:rgba(8,8,10,.93);display:flex;align-items:center;justify-content:center;
  z-index:200;opacity:0;pointer-events:none;transition:opacity .3s;padding:5vw}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:6px;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.lightbox__close{position:absolute;top:1rem;right:1.6rem;font-size:2.4rem;color:var(--gold-bright);
  background:none;border:0;cursor:pointer;line-height:1}

/* ---------- For Brands ---------- */
.forbrands__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-bottom:clamp(2.5rem,5vw,3.5rem)}
.fb{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:6px;padding:1.9rem 1.7rem;
  transition:transform .4s var(--ease),border-color .4s}
.fb:hover{transform:translateY(-5px);border-color:var(--line)}
.fb h4{font-size:1.18rem;margin-bottom:.5rem;color:var(--gold-bright)}
.fb p{color:var(--muted);font-size:.94rem;margin:0;line-height:1.6}
.forbrands__cta{text-align:center}
.forbrands__cta p{font-family:var(--font-display);font-size:clamp(1.25rem,2.4vw,1.75rem);color:var(--text);margin-bottom:1.3rem}
.forbrands__cta .btn{margin:.3rem}

@media (max-width:860px){
  .gallery{grid-template-columns:repeat(2,1fr)}
  .forbrands__grid{grid-template-columns:1fr}
}

/* ---------- Footer ---------- */
.footer{background:var(--bg-darker);border-top:1px solid var(--line);padding:clamp(3.5rem,7vw,5.5rem) 0 2.2rem}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.footer__brand img{height:48px;width:auto;margin-bottom:1.1rem}
.footer__tag{color:var(--muted);font-size:.92rem;margin-bottom:1.3rem}
.footer__social{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer__social a{color:var(--gold);font-size:.86rem;letter-spacing:.08em;transition:color .3s;position:relative}
.footer__social a:hover{color:var(--gold-bright)}
.footer h4{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1.1rem;font-weight:500}
.footer__stores ul li{color:var(--text);font-size:.92rem;margin-bottom:.6rem;opacity:.85}
.footer__stores a{color:inherit;transition:color .3s,opacity .3s}
.footer__stores a:hover{color:var(--gold-bright)}
.footer__contact p{margin-bottom:.7rem}
.footer__contact a{color:var(--text);transition:color .3s}
.footer__contact a:hover{color:var(--gold-bright)}
.footer__legal{color:var(--muted);font-size:.86rem;letter-spacing:.05em}
.footer__contact .btn{margin-top:.6rem}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;
  margin-top:clamp(2.5rem,5vw,3.5rem);padding-top:1.8rem;border-top:1px solid var(--line-soft);
  color:var(--muted-2);font-size:.8rem;letter-spacing:.06em}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
  .ops{grid-template-columns:1fr;gap:2rem}
}
@media (max-width:860px){
  .nav__links{position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;gap:0;
    background:rgba(8,8,10,.97);backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line-soft);
    max-height:0;overflow:hidden;transition:max-height .4s var(--ease);padding:0 clamp(1.25rem,4vw,2.5rem)}
  .nav.menu-open .nav__links{max-height:60vh;padding:.5rem clamp(1.25rem,4vw,2.5rem) 1.2rem}
  .nav__links a{padding:.95em 0;border-bottom:1px solid var(--line-soft);width:100%}
  .nav__burger{display:flex}
  .values__grid{grid-template-columns:repeat(2,1fr)}
  .prodstrat__grid{grid-template-columns:repeat(2,1fr)}
  .bigstats{grid-template-columns:1fr}
  .socialcards{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}
  .events__grid{grid-template-columns:1fr}
  .story{grid-template-columns:1fr;gap:2.2rem}
  .story__media{order:-1}
  .experience{grid-template-columns:1fr;gap:2.2rem}
  .experience__media{order:-1}
  .store-gallery{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}
  .agencies{grid-template-columns:1fr}
  .services__grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}
  .creds{grid-template-columns:1fr;gap:1.8rem}
  .logowall{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:480px){
  .logowall{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .values__grid,.prodstrat__grid{grid-template-columns:1fr}
  .hero__cta{flex-direction:column;width:100%;max-width:320px}
  .hero__cta .btn{width:100%}
  .footer__top{grid-template-columns:1fr}
}

/* Hide language toggle label logic already handled; ensure nav store btn hidden text fits */
@media (max-width:380px){
  .nav__actions .btn--gold{display:none}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* Focus accessibility */
a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}


/* ============================================================
   BLOG / PAGES (WordPress templates)
   ============================================================ */
.container--narrow{max-width:780px}
.blog-section{min-height:60vh}
.page-head{padding-top:clamp(5rem,9vw,7rem);text-align:center;margin-bottom:clamp(2rem,4vw,3rem)}
.page-head__eyebrow{display:block;color:var(--gold);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;margin-bottom:.8rem}
.page-head__title{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.15}

/* Blog listing */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.post-card{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:6px;overflow:hidden;transition:transform .4s var(--ease),border-color .4s}
.post-card:hover{transform:translateY(-6px);border-color:var(--line)}
.post-card__link{display:flex;flex-direction:column;height:100%;color:inherit;text-decoration:none}
.post-card__img{aspect-ratio:16/10;overflow:hidden;background:var(--bg-darker)}
.post-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.post-card:hover .post-card__img img{transform:scale(1.05)}
.post-card__img--ph{display:flex;align-items:center;justify-content:center}
.post-card__img--ph img{width:80px;height:80px;object-fit:contain;opacity:.5}
.post-card__body{padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.post-card__date{color:var(--gold);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}
.post-card__title{font-family:var(--font-display);font-size:1.3rem;line-height:1.3}
.post-card__excerpt{color:var(--muted);font-size:.92rem;line-height:1.6;margin:0}

/* Single post / page */
.post-single .container--narrow{padding-top:0}
.post-single__hero{margin:0 0 2rem;border-radius:8px;overflow:hidden}
.post-single__hero img{width:100%;height:auto;display:block}
.post-content{color:var(--text);font-size:1.05rem;line-height:1.85}
.post-content > *{margin:0 0 1.3em}
.post-content h2{font-family:var(--font-display);font-size:1.7rem;margin-top:1.6em;line-height:1.3}
.post-content h3{font-family:var(--font-display);font-size:1.35rem;margin-top:1.4em}
.post-content a{color:var(--gold-bright);text-decoration:underline;text-underline-offset:3px}
.post-content img{max-width:100%;height:auto;border-radius:6px}
.post-content blockquote{border-left:3px solid var(--gold);padding:.3em 0 .3em 1.2em;margin-left:0;color:var(--muted);font-family:var(--font-display);font-size:1.2rem}
.post-content ul,.post-content ol{padding-left:1.3em}
.post-content li{margin-bottom:.5em}
.post-content code{background:var(--bg-card);padding:.15em .45em;border-radius:4px;font-size:.9em}
.post-tags{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.5rem}
.post-tags a{border:1px solid var(--line);color:var(--muted);padding:.35em .9em;border-radius:30px;font-size:.8rem;text-decoration:none}
.post-tags a:hover{border-color:var(--gold);color:var(--gold-bright)}
.post-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.post-nav a{color:var(--text);text-decoration:none;font-size:.95rem}
.post-nav a:hover{color:var(--gold-bright)}
.back-home{margin-top:2.5rem;text-align:center}
.back-home a{color:var(--gold);text-decoration:none}
.pagination{margin-top:3rem;text-align:center}
.pagination .page-numbers{display:inline-block;min-width:2.4em;padding:.5em .7em;margin:0 .2em;border:1px solid var(--line-soft);border-radius:4px;color:var(--text);text-decoration:none;transition:border-color .3s,background .3s}
.pagination .page-numbers.current{background:var(--gold);color:#1a1408;border-color:var(--gold)}
.pagination .page-numbers:hover{border-color:var(--gold)}
.blog-empty{text-align:center;color:var(--muted);padding:3rem 0}

@media (max-width:860px){ .posts{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto} }
