/* ══════════════════════════════════════════════════════
   NEXUS — Editorial Luxury E-Commerce Theme
   Powered by Farzad Bagheri · farzadbagheri.fr
   ══════════════════════════════════════════════════════ */

/* ── Variables ──────────────────────────────────────── */
:root {
  --ob:      #080808;
  --ink:     #0f0f0f;
  --char:    #161616;
  --smoke:   #1e1e1e;
  --ivory:   #f5f0e8;
  --cream:   #ede8dc;
  --gold:    #d4a853;
  --gold-lt: #e8c07a;
  --muted:   #555555;
  --faint:   #888888;
  --line:    #242424;
  --display: 'Cormorant Garamond', serif;
  --heading: 'Syne', sans-serif;
  --body:    'DM Sans', sans-serif;
  --mono:    'JetBrains Mono', monospace;
  --ease:    cubic-bezier(0.22, 1, 0.36, 1);
  --fast:    0.2s;
  --mid:     0.5s;
  --slow:    1s;
}

/* ── Reset ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--body); font-weight: 300; background: var(--ob); color: var(--ivory); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { color: var(--gold); text-decoration: none; transition: color var(--fast); }
/* ── Required: links inside content must be underlined (WP.org requirement) ── */
.entry-content a,
.entry-summary a,
.comment-content a,
.widget a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.entry-content a:hover,
.entry-summary a:hover,
.comment-content a:hover,
.widget a:hover {
  text-decoration: none;
  color: var(--gold);
}

a:hover { color: var(--ivory); }
button, input, select, textarea { font-family: inherit; }

/* ── Custom Cursor ──────────────────────────────────── */
.nx-cur,
/* Custom cursor removed — system cursor used */

.nx-glow {
  position: fixed; width: 420px; height: 420px; border-radius: 50%;
  background: radial-gradient(circle, rgba(212,168,83,.04) 0%, transparent 65%);
  pointer-events: none; z-index: 1; transform: translate(-50%,-50%);
}

/* ── Progress ───────────────────────────────────────── */
.nx-progress {
  position: fixed; top: 0; left: 0; width: 0; height: 1px;
  background: linear-gradient(to right, var(--gold), var(--gold-lt));
  z-index: 5000; box-shadow: 0 0 6px rgba(212,168,83,.5);
  transition: width .1s linear;
}

/* ── Navigation ─────────────────────────────────────── */
.nx-nav {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  width: 100%;
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 clamp(1.5rem, 4vw, 4rem);
  gap: 2rem;
  transition: background .5s, border-color .5s;
  border-bottom: 1px solid transparent;
  overflow: visible;
  box-sizing: border-box;
}
.nx-nav.scrolled { background: rgba(8,8,8,.96); backdrop-filter: blur(24px); border-color: var(--line); }
.nx-nav-logo {
  font-family: var(--display); font-size: 1.625rem; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase; color: var(--ivory);
  text-decoration: none; display: flex; align-items: baseline; gap: .15em;
}
.nx-nav-logo em { font-style: italic; color: var(--gold); font-weight: 300; }
.nx-nav-center { display: flex; align-items: center; gap: 2.75rem; list-style: none; }
.nx-nav-center a {
  font-family: var(--mono); font-size: .6rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--muted); text-decoration: none;
  transition: color .2s; position: relative;
}
.nx-nav-center a::after {
  content: ''; position: absolute; bottom: -4px; left: 0;
  width: 0; height: 1px; background: var(--gold); transition: width .3s var(--ease);
}
.nx-nav-center a:hover { color: var(--ivory); }
.nx-nav-center a:hover::after { width: 100%; }
.nx-nav-right { display: flex; align-items: center; gap: 1.25rem; }
.nx-nav-cart {
  font-family: var(--mono); font-size: .65rem; letter-spacing: .12em;
  color: var(--muted); transition: color .2s;
}
.nx-nav-cart:hover { color: var(--gold); }
.nx-nav-cta {
  font-family: var(--mono); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase;
  border: 1px solid var(--gold); color: var(--gold); padding: .5rem 1.375rem;
  transition: all .3s var(--ease);
}
.nx-nav-cta:hover { background: var(--gold); color: var(--ob); }

/* ── HERO ───────────────────────────────────────────── */
.nx-hero {
  position: relative; min-height: 100vh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 0 clamp(1.5rem,4vw,5rem) clamp(3rem,6vw,6rem);
  overflow: hidden; background: var(--ob);
}

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

/* Gold diagonal accent lines */
.nx-hero-line {
  position: absolute; top: 0; right: 28%; width: 1px; height: 100%;
  background: linear-gradient(to bottom, transparent, rgba(212,168,83,.12) 35%, rgba(212,168,83,.25) 65%, transparent);
  animation: line-breathe 7s ease-in-out infinite alternate;
}
.nx-hero-line2 {
  position: absolute; top: 0; left: 45%; width: 1px; height: 100%;
  background: linear-gradient(to bottom, transparent, rgba(212,168,83,.06) 50%, transparent);
  animation: line-breathe 11s ease-in-out infinite alternate-reverse;
}
@keyframes line-breathe {
  from { opacity: .4; transform: translateX(-20px) scaleY(.8); }
  to   { opacity: 1;  transform: translateX(20px)  scaleY(1); }
}

/* Large italic serif ghost text */
.nx-hero-ghost {
  position: absolute; right: -.02em; bottom: -.1em;
  font-family: var(--display); font-style: italic;
  font-size: clamp(18rem, 38vw, 52rem); font-weight: 300; line-height: 1;
  color: transparent; -webkit-text-stroke: 1px rgba(212,168,83,.045);
  pointer-events: none; user-select: none; letter-spacing: -.03em;
  animation: ghost-breathe 10s ease-in-out infinite;
}
@keyframes ghost-breathe {
  0%,100% { -webkit-text-stroke-color: rgba(212,168,83,.045); }
  50%     { -webkit-text-stroke-color: rgba(212,168,83,.09); }
}

/* Horizontal rule that sweeps in */
.nx-hero-rule {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 1px; background: linear-gradient(to right, transparent, var(--line) 20%, var(--line) 80%, transparent);
}

.nx-hero-inner { position: relative; z-index: 3; max-width: 1600px; width: 100%; }

.nx-hero-overline {
  font-family: var(--mono); font-size: .58rem; letter-spacing: .3em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 1.75rem;
  display: flex; align-items: center; gap: 1rem;
  opacity: 0; animation: fade-up .8s var(--ease) .1s forwards;
}
.nx-hero-overline::before { content: ''; width: 40px; height: 1px; background: var(--gold); }

/* Big serif headline */
.nx-hero-h1 {
  font-family: var(--display); font-weight: 300; font-style: normal;
  font-size: clamp(5rem, 14vw, 19rem); line-height: .86;
  letter-spacing: -.025em; color: var(--ivory);
}
.nx-word { display: inline-block; overflow: hidden; vertical-align: bottom; }
.nx-word-in { display: inline-block; transform: translateY(108%); animation: word-up .95s var(--ease) forwards; }
.nx-hero-h1 .nx-word:nth-child(1) .nx-word-in { animation-delay: .2s; }
.nx-hero-h1 .nx-word:nth-child(2) .nx-word-in { animation-delay: .35s; }
.nx-hero-h1 .nx-word:nth-child(3) .nx-word-in { animation-delay: .5s; }
.nx-hero-h1 .nx-word:nth-child(4) .nx-word-in { animation-delay: .65s; }
.nx-hero-h1 .nx-word:nth-child(5) .nx-word-in { animation-delay: .8s; }
.nx-hero-h1 em { font-style: italic; color: var(--gold); }
.nx-hero-h1 .nx-line2 { display: block; }
@keyframes word-up { from { transform: translateY(108%); } to { transform: translateY(0); } }

.nx-hero-bottom {
  display: grid; grid-template-columns: 1fr 1fr; gap: 5rem;
  margin-top: 4rem; padding-top: 2.5rem; border-top: 1px solid var(--line);
  opacity: 0; animation: fade-up .8s var(--ease) 1.15s forwards;
}
@media (max-width: 768px) { .nx-hero-bottom { grid-template-columns: 1fr; gap: 2rem; } }
.nx-hero-desc {
  font-size: clamp(.9rem, 1.5vw, 1.0625rem); font-style: italic;
  color: var(--faint); line-height: 1.85; max-width: 460px;
  font-family: var(--display);
}
.nx-hero-actions { display: flex; flex-direction: column; justify-content: flex-end; gap: 1rem; }

/* Scroll indicator */
.nx-scroll-hint {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  z-index: 4; opacity: 0; animation: fade-in 1s ease 2.4s forwards;
}
.nx-scroll-line {
  width: 1px; height: 52px;
  background: linear-gradient(to bottom, var(--gold), transparent);
  animation: scroll-pulse 1.5s ease-in-out infinite;
}
@keyframes scroll-pulse { 0%,100%{transform:scaleY(1);opacity:1} 50%{transform:scaleY(.5);opacity:.4} }
.nx-scroll-lbl { font-family: var(--mono); font-size: .45rem; letter-spacing: .22em; text-transform: uppercase; color: var(--muted); writing-mode: vertical-lr; }

/* ── Buttons ─────────────────────────────────────────── */
.nx-btn {
  display: inline-flex; align-items: center; gap: 1.5rem;
  font-family: var(--mono); font-size: .6rem; letter-spacing: .2em; text-transform: uppercase;
  padding: 1rem 2rem; text-decoration: none; transition: all .35s var(--ease);
}
.nx-btn-primary { background: var(--gold); color: var(--ob); }
.nx-btn-primary:hover { background: var(--ivory); color: var(--ob); transform: translateY(-2px); box-shadow: 0 12px 36px rgba(212,168,83,.2); }
.nx-btn-outline { border: 1px solid rgba(212,168,83,.4); color: var(--faint); }
.nx-btn-outline:hover { border-color: var(--gold); color: var(--gold); }
.nx-btn-ghost { color: var(--muted); border-bottom: 1px solid var(--line); padding: .875rem 0; border-left: none; border-right: none; border-top: none; }
.nx-btn-ghost:hover { color: var(--gold); border-color: var(--gold); }
.nx-btn-arrow { transition: transform .3s var(--ease); }
.nx-btn:hover .nx-btn-arrow { transform: translateX(5px); }

/* ── Marquee ─────────────────────────────────────────── */
.nx-marquee-wrap {
  overflow: hidden; background: var(--ink);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 1.25rem 0; position: relative; z-index: 10;
}
.nx-marquee { display: flex; width: max-content; animation: marquee 30s linear infinite; }
.nx-marquee:hover { animation-play-state: paused; }
.nx-marquee-inner { display: flex; align-items: center; gap: 4rem; padding-right: 4rem; white-space: nowrap; }
.nx-marquee-item { font-family: var(--display); font-style: italic; font-size: clamp(1.125rem, 2.5vw, 1.75rem); font-weight: 300; color: var(--muted); letter-spacing: .04em; }
.nx-marquee-item.hl { color: var(--gold); font-style: normal; font-family: var(--mono); font-size: clamp(.7rem, 1.2vw, .9rem); letter-spacing: .2em; text-transform: uppercase; }
.nx-marquee-sep { width: 4px; height: 4px; border-radius: 50%; background: var(--line); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── Section base ───────────────────────────────────── */
.nx-section { padding: clamp(5rem,12vw,11rem) clamp(1.5rem,4vw,5rem); position: relative; }
.nx-section-ink   { background: var(--ink);   border-top: 1px solid var(--line); }
.nx-section-smoke { background: var(--smoke); border-top: 1px solid var(--line); }
.nx-section-char  { background: var(--char);  border-top: 1px solid var(--line); }

.nx-label {
  font-family: var(--mono); font-size: .55rem; letter-spacing: .3em;
  text-transform: uppercase; color: var(--gold); margin-bottom: .875rem;
  display: flex; align-items: center; gap: .875rem;
}
.nx-label::before { content: ''; width: 24px; height: 1px; background: var(--gold); opacity: .6; }
.nx-title {
  font-family: var(--display); font-weight: 300; font-size: clamp(3.5rem, 8vw, 10rem);
  line-height: .88; letter-spacing: -.025em; color: var(--ivory);
}
.nx-title em { font-style: italic; color: var(--gold); }
.nx-title .nx-outline { color: transparent; -webkit-text-stroke: 1px rgba(212,168,83,.5); }
.nx-subtitle { font-family: var(--display); font-style: italic; font-size: clamp(1rem,1.75vw,1.25rem); color: var(--faint); line-height: 1.85; max-width: 540px; margin-top: 1.5rem; }

/* ── Product Grid ───────────────────────────────────── */
.nx-product-grid {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 1px;
  background: var(--line); margin-top: 4rem;
}
@media(max-width:1200px){ .nx-product-grid { grid-template-columns: repeat(3,1fr); } }
@media(max-width:860px){  .nx-product-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:480px){  .nx-product-grid { grid-template-columns: 1fr; } }

.nx-product-card { background: var(--ink); position: relative; overflow: hidden; display: flex; flex-direction: column; transition: background .4s; }
.nx-product-card:hover { background: var(--char); }

.nx-product-img { position: relative; overflow: hidden; aspect-ratio: 2/3; }
.nx-product-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.nx-product-card:hover .nx-product-img img { transform: scale(1.06); }

/* Reveal overlay that wipes up on hover */
.nx-product-overlay {
  position: absolute; inset: 0; background: rgba(8,8,8,.7);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .4s var(--ease);
}
.nx-product-card:hover .nx-product-overlay { opacity: 1; }
.nx-product-add {
  font-family: var(--mono); font-size: .58rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); border: 1px solid rgba(212,168,83,.5); padding: .875rem 2rem;
  background: none; transition: all .3s var(--ease); transform: translateY(12px);
  transition: all .4s var(--ease);
}
.nx-product-card:hover .nx-product-add { transform: translateY(0); }
.nx-product-add:hover { background: var(--gold); color: var(--ob); }

.nx-product-badge {
  position: absolute; top: 1rem; left: 1rem; z-index: 2;
  font-family: var(--mono); font-size: .48rem; letter-spacing: .14em;
  text-transform: uppercase; padding: 3px 8px;
}
.nx-badge-new  { background: var(--gold); color: var(--ob); }
.nx-badge-sale { border: 1px solid var(--gold); color: var(--gold); }

.nx-product-body { padding: 1.25rem 1.25rem 1.75rem; flex: 1; display: flex; flex-direction: column; gap: .375rem; }
.nx-product-cat { font-family: var(--mono); font-size: .52rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); opacity: .7; }
.nx-product-name { font-family: var(--display); font-size: 1.25rem; font-weight: 300; font-style: italic; color: var(--ivory); text-decoration: none; transition: color .2s; line-height: 1.2; }
.nx-product-name:hover { color: var(--gold); }
.nx-product-price { display: flex; align-items: baseline; gap: .5rem; margin-top: auto; padding-top: .75rem; border-top: 1px solid var(--line); }
.nx-product-price .amount { font-family: var(--mono); font-size: .875rem; color: var(--ivory); letter-spacing: .08em; }
.nx-product-price del .amount { color: var(--muted); text-decoration: line-through; }
.nx-product-price ins { text-decoration: none; }
.nx-product-price ins .amount { color: var(--gold); }

/* ── Stats ──────────────────────────────────────────── */
.nx-stats {
  display: grid; grid-template-columns: repeat(4,1fr);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: var(--char);
}
@media(max-width:768px){ .nx-stats { grid-template-columns: repeat(2,1fr); } }
.nx-stat { padding: 3rem clamp(1.5rem,3vw,3.5rem); border-right: 1px solid var(--line); position: relative; overflow: hidden; }
.nx-stat:last-child { border-right: none; }
.nx-stat::after {
  content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 1px;
  background: linear-gradient(to right, var(--gold), transparent);
  transition: width 1.1s var(--ease);
}
.nx-stat.nx-in::after { width: 100%; }
.nx-stat-num { font-family: var(--display); font-size: clamp(3rem,6vw,6rem); font-weight: 300; font-style: italic; color: var(--ivory); line-height: 1; margin-bottom: .5rem; }
.nx-stat-suf { font-size: .5em; color: var(--gold); font-style: normal; }
.nx-stat-lbl { font-family: var(--mono); font-size: .55rem; letter-spacing: .22em; text-transform: uppercase; color: var(--muted); }

/* ── Split layout ───────────────────────────────────── */
.nx-split { display: grid; grid-template-columns: 1fr 1fr; min-height: 75vh; }
@media(max-width:900px){ .nx-split { grid-template-columns: 1fr; } }
.nx-split-left { background: var(--ink); padding: clamp(4rem,8vw,9rem) clamp(1.5rem,4vw,5rem); display: flex; flex-direction: column; justify-content: center; border-right: 1px solid var(--line); position: relative; overflow: hidden; }
.nx-split-left::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 0% 100%, rgba(212,168,83,.04) 0%, transparent 55%); pointer-events: none; }
.nx-split-right { background: var(--char); padding: clamp(4rem,8vw,9rem) clamp(1.5rem,4vw,5rem); display: flex; flex-direction: column; justify-content: center; gap: 0; }
.nx-split-title { font-family: var(--display); font-weight: 300; font-size: clamp(3rem,6vw,7rem); line-height: .88; letter-spacing: -.02em; color: var(--ivory); margin-bottom: 1.75rem; position: relative; z-index: 1; }
.nx-split-title em { font-style: italic; color: var(--gold); }
.nx-split-body { font-family: var(--display); font-style: italic; font-size: 1.0625rem; color: var(--faint); line-height: 1.85; max-width: 440px; position: relative; z-index: 1; }

/* Feature list */
.nx-features { display: flex; flex-direction: column; }
.nx-feature { display: grid; grid-template-columns: 48px 1fr; gap: 1.75rem; align-items: flex-start; padding: 2rem 0; border-bottom: 1px solid var(--line); transition: all .3s var(--ease); }
.nx-feature:first-child { padding-top: 0; }
.nx-feature:hover { padding-left: .875rem; }
.nx-feature-idx { font-family: var(--mono); font-size: .6rem; color: var(--gold); letter-spacing: .1em; padding-top: .2rem; opacity: .7; }
.nx-feature-title { font-family: var(--heading); font-size: 1rem; font-weight: 700; color: var(--ivory); margin-bottom: .375rem; }
.nx-feature-desc { font-size: .875rem; color: var(--muted); line-height: 1.7; }

/* ── Process ─────────────────────────────────────────── */
.nx-process { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; margin-top: 4rem; border-left: 1px solid var(--line); border-top: 1px solid var(--line); }
@media(max-width:900px){ .nx-process { grid-template-columns: 1fr 1fr; } }
@media(max-width:480px){ .nx-process { grid-template-columns: 1fr; } }
.nx-step { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 2.5rem; transition: background .35s; }
.nx-step:hover { background: var(--smoke); }
.nx-step-n { font-family: var(--display); font-style: italic; font-size: 4rem; font-weight: 300; color: rgba(212,168,83,.15); line-height: 1; margin-bottom: 1.5rem; transition: color .3s; }
.nx-step:hover .nx-step-n { color: var(--gold); }
.nx-step-title { font-family: var(--heading); font-size: 1rem; font-weight: 700; color: var(--ivory); margin-bottom: .625rem; }
.nx-step-desc { font-size: .875rem; color: var(--muted); line-height: 1.7; }

/* ── Testimonial ─────────────────────────────────────── */
.nx-testimonial { text-align: center; padding: clamp(5rem,12vw,11rem) clamp(1.5rem,4vw,5rem); position: relative; overflow: hidden; }
.nx-testimonial::before {
  content: '\201C'; position: absolute; top: -.2em; left: 50%; transform: translateX(-50%);
  font-family: var(--display); font-style: italic; font-size: 26rem; font-weight: 300;
  color: transparent; -webkit-text-stroke: 1px rgba(212,168,83,.05);
  pointer-events: none; user-select: none; line-height: 1;
}
.nx-quote { font-family: var(--display); font-style: italic; font-size: clamp(1.5rem,3vw,2.5rem); font-weight: 300; line-height: 1.45; color: var(--ivory); max-width: 900px; margin: 0 auto 2.5rem; position: relative; z-index: 1; }
.nx-quote em { color: var(--gold); }
.nx-quote-author { font-family: var(--mono); font-size: .58rem; letter-spacing: .24em; text-transform: uppercase; color: var(--muted); position: relative; z-index: 1; }
.nx-quote-author span { color: var(--gold); }

/* ── CTA section ─────────────────────────────────────── */
.nx-cta { background: var(--ink); text-align: center; padding: clamp(5rem,12vw,11rem) clamp(1.5rem,4vw,5rem); position: relative; overflow: hidden; }
.nx-cta::before { content: ''; position: absolute; top: -30%; left: 50%; transform: translateX(-50%); width: 560px; height: 560px; background: radial-gradient(circle, rgba(212,168,83,.06) 0%, transparent 65%); pointer-events: none; }
.nx-cta-title { font-family: var(--display); font-weight: 300; font-size: clamp(4rem,11vw,14rem); line-height: .88; letter-spacing: -.025em; color: var(--ivory); margin-bottom: 1.5rem; position: relative; z-index: 1; }
.nx-cta-title em { font-style: italic; color: var(--gold); }
.nx-cta-sub { font-family: var(--display); font-style: italic; font-size: 1.125rem; color: var(--faint); margin-bottom: 3rem; position: relative; z-index: 1; }
.nx-cta-btns { display: flex; align-items: center; justify-content: center; gap: 1.5rem; flex-wrap: wrap; position: relative; z-index: 1; }

/* ── Footer ──────────────────────────────────────────── */
.nx-footer { background: var(--ob); border-top: 1px solid var(--line); }
.nx-footer-ticker { background: var(--ink); border-bottom: 1px solid var(--line); padding: .875rem 0; overflow: hidden; }
.nx-footer-main { padding: 4.5rem clamp(1.5rem,4vw,5rem); display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 3rem; }
@media(max-width:900px){ .nx-footer-main { grid-template-columns: 1fr 1fr; } }
@media(max-width:480px){ .nx-footer-main { grid-template-columns: 1fr; } }
.nx-footer-logo { font-family: var(--display); font-size: 2.5rem; font-weight: 600; letter-spacing: .12em; color: var(--ivory); text-decoration: none; display: block; margin-bottom: .875rem; }
.nx-footer-logo em { font-style: italic; color: var(--gold); }
.nx-footer-tagline { font-family: var(--display); font-style: italic; font-size: .9375rem; color: var(--muted); line-height: 1.7; max-width: 240px; margin-bottom: 1.75rem; }
.nx-footer-credit { font-family: var(--mono); font-size: .55rem; letter-spacing: .16em; text-transform: uppercase; color: var(--line); }
.nx-footer-credit a { color: var(--gold); text-decoration: none; }
.nx-footer-col-title { font-family: var(--mono); font-size: .52rem; letter-spacing: .24em; text-transform: uppercase; color: var(--muted); margin-bottom: 1.375rem; }
.nx-footer-links { list-style: none; display: flex; flex-direction: column; gap: .625rem; }
.nx-footer-links a { font-family: var(--display); font-style: italic; font-size: .9375rem; color: var(--muted); text-decoration: none; transition: all .2s; display: flex; align-items: center; gap: .5rem; }
.nx-footer-links a::before { content: ''; width: 0; height: 1px; background: var(--gold); transition: width .25s var(--ease); }
.nx-footer-links a:hover { color: var(--gold); padding-left: .375rem; }
.nx-footer-links a:hover::before { width: 8px; }
.nx-footer-newsletter p { font-family: var(--display); font-style: italic; font-size: .875rem; color: var(--muted); margin-bottom: 1rem; line-height: 1.65; }
.nx-footer-newsletter input { width: 100%; background: var(--ink); border: 1px solid var(--line); color: var(--ivory); padding: .75rem 1rem; font-family: var(--mono); font-size: .7rem; letter-spacing: .08em; outline: none; transition: border-color .2s; }
.nx-footer-newsletter input:focus { border-color: var(--gold); }
.nx-footer-newsletter button { width: 100%; background: none; border: 1px solid rgba(212,168,83,.4); color: var(--gold); font-family: var(--mono); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; padding: .75rem; margin-top: .5rem; transition: all .3s; }
.nx-footer-newsletter button:hover { background: var(--gold); color: var(--ob); }
.nx-footer-bottom { padding: 1.5rem clamp(1.5rem,4vw,5rem); border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: .875rem; }
.nx-footer-copy { font-family: var(--mono); font-size: .58rem; letter-spacing: .1em; color: var(--muted); }
.nx-footer-copy a { color: var(--gold); text-decoration: none; }
.nx-footer-legal { display: flex; gap: 1.5rem; }
.nx-footer-legal a { font-family: var(--mono); font-size: .58rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); text-decoration: none; transition: color .2s; }
.nx-footer-legal a:hover { color: var(--gold); }

/* ── Page hero ───────────────────────────────────────── */
.nx-page-hero { background: var(--ob); padding: 8rem clamp(1.5rem,4vw,5rem) 4rem; position: relative; overflow: hidden; }
.nx-page-h1 { font-family: var(--display); font-weight: 300; font-size: clamp(4rem,11vw,14rem); line-height: .86; letter-spacing: -.025em; color: var(--ivory); }
.nx-page-h1 em { font-style: italic; color: var(--gold); }
.nx-page-sub { font-family: var(--display); font-style: italic; font-size: clamp(.9375rem,1.5vw,1.1875rem); color: var(--faint); line-height: 1.85; max-width: 600px; margin-top: 1.5rem; }

/* ── Shop ────────────────────────────────────────────── */
.nx-shop-wrap { display: grid; grid-template-columns: 260px 1fr; }
@media(max-width:900px){ .nx-shop-wrap { grid-template-columns: 1fr; } }
.nx-shop-sidebar { background: var(--ink); border-right: 1px solid var(--line); padding: 2.5rem 1.75rem; position: sticky; top: 72px; height: calc(100vh - 72px); overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--line) transparent; }
.nx-shop-sidebar h3 { font-family: var(--mono); font-size: .52rem; letter-spacing: .24em; text-transform: uppercase; color: var(--muted); margin-bottom: 1.125rem; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--line); }
.nx-shop-sidebar h3:first-child { margin-top: 0; border-top: none; padding-top: 0; }
.nx-filter-swatches { display: flex; flex-wrap: wrap; gap: .5rem; }
.nx-swatch { width: 22px; height: 22px; border-radius: 50%; border: 2px solid transparent; transition: all .2s; }
.nx-swatch.active, .nx-swatch:hover { border-color: var(--gold); transform: scale(1.15); }
.nx-filter-sizes { display: flex; flex-wrap: wrap; gap: .375rem; }
.nx-size-btn { min-width: 40px; padding: .375rem .625rem; font-family: var(--mono); font-size: .6rem; letter-spacing: .06em; border: 1px solid var(--line); color: var(--muted); background: none; transition: all .2s; }
.nx-size-btn:hover, .nx-size-btn.active { border-color: var(--gold); color: var(--gold); }
.nx-filter-checks { display: flex; flex-direction: column; gap: .5rem; }
.nx-filter-checks label { display: flex; align-items: center; gap: .625rem; font-size: .8125rem; font-family: var(--display); font-style: italic; color: var(--muted); }
.nx-filter-checks input[type=checkbox] { accent-color: var(--gold); width: 13px; height: 13px; }
.nx-sidebar-btn { display: block; width: 100%; margin-top: 2rem; padding: .875rem; background: none; border: 1px solid rgba(212,168,83,.35); color: var(--gold); font-family: var(--mono); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; transition: all .3s; }
.nx-sidebar-btn:hover { background: var(--gold); color: var(--ob); }
.nx-shop-main { padding: 2.5rem clamp(1rem,3vw,3rem); }
.nx-shop-toolbar { display: flex; justify-content: space-between; align-items: center; padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); margin-bottom: 2rem; flex-wrap: wrap; gap: .75rem; }
.nx-shop-count { font-family: var(--mono); font-size: .58rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); }
.nx-sort-select { background: var(--ink); border: 1px solid var(--line); color: var(--ivory); padding: .5rem .875rem; font-family: var(--mono); font-size: .6rem; outline: none; transition: border-color .2s; }
.nx-sort-select:focus { border-color: var(--gold); }

/* ── Single product ─────────────────────────────────── */
.nx-product-single { display: grid; grid-template-columns: 1.1fr 1fr; min-height: 90vh; }
@media(max-width:900px){ .nx-product-single { grid-template-columns: 1fr; } }
.nx-prod-gallery { background: var(--char); position: relative; overflow: hidden; }
.nx-prod-gallery-main img { width: 100%; height: 100%; object-fit: cover; min-height: 70vh; transition: transform .8s var(--ease); }
.nx-prod-gallery:hover .nx-prod-gallery-main img { transform: scale(1.03); }
.nx-prod-thumbs { display: flex; gap: 1px; background: var(--line); }
.nx-prod-thumb { flex: 1; overflow: hidden; height: 90px; opacity: .45; transition: opacity .2s; }
.nx-prod-thumb img { width: 100%; height: 100%; object-fit: cover; }
.nx-prod-thumb.active, .nx-prod-thumb:hover { opacity: 1; outline: 1px solid var(--gold); }
.nx-prod-info { background: var(--ink); padding: clamp(2.5rem,5vw,5rem); display: flex; flex-direction: column; justify-content: center; }
.nx-prod-breadcrumb { font-family: var(--mono); font-size: .55rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 1.5rem; }
.nx-prod-breadcrumb a { color: var(--muted); text-decoration: none; transition: color .2s; }
.nx-prod-breadcrumb a:hover { color: var(--gold); }
.nx-prod-brand { font-family: var(--mono); font-size: .55rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); opacity: .7; margin-bottom: .875rem; }
.nx-prod-title { font-family: var(--display); font-style: italic; font-weight: 300; font-size: clamp(2.25rem,5vw,4.5rem); line-height: .9; letter-spacing: -.02em; color: var(--ivory); margin-bottom: 1rem; }
.nx-prod-price { font-family: var(--mono); font-size: 1.375rem; color: var(--ivory); letter-spacing: .06em; margin-bottom: 1rem; }
.nx-prod-price .gold { color: var(--gold); }
.nx-prod-rating { display: flex; align-items: center; gap: .75rem; margin-bottom: 2rem; font-family: var(--mono); font-size: .6rem; color: var(--muted); }
.nx-prod-stars { display: flex; gap: 3px; }
.nx-prod-star { width: 10px; height: 10px; background: var(--gold); clip-path: polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%); }
.nx-prod-star.empty { background: var(--line); }
.nx-prod-desc { font-family: var(--display); font-style: italic; font-size: .9375rem; color: var(--muted); line-height: 1.8; margin-bottom: 2rem; }
.nx-variant-label { font-family: var(--mono); font-size: .52rem; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); margin-bottom: .75rem; display: block; }
.nx-variants { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.5rem; }
.nx-var-btn { padding: .5rem 1rem; border: 1px solid var(--line); font-family: var(--mono); font-size: .65rem; letter-spacing: .06em; color: var(--muted); background: none; transition: all .2s; }
.nx-var-btn:hover, .nx-var-btn.active { border-color: var(--gold); color: var(--gold); }
.nx-color-sw { width: 30px; height: 30px; border-radius: 50%; border: 2px solid transparent; transition: all .2s; }
.nx-color-sw:hover, .nx-color-sw.active { border-color: var(--gold); transform: scale(1.1); }
.nx-qty-row { display: flex; gap: .75rem; margin-bottom: 1.5rem; align-items: stretch; }
.nx-qty { display: flex; border: 1px solid var(--line); }
.nx-qty button { width: 44px; background: none; border: none; color: var(--muted); font-size: 1.125rem; transition: all .2s; }
.nx-qty button:hover { background: var(--gold); color: var(--ob); }
.nx-qty input { width: 52px; background: none; border: none; border-left: 1px solid var(--line); border-right: 1px solid var(--line); color: var(--ivory); text-align: center; font-family: var(--mono); font-size: .875rem; outline: none; }
.nx-add-cart { flex: 1; background: var(--gold); color: var(--ob); border: none; font-family: var(--mono); font-size: .6rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; padding: 1rem 2rem; transition: all .35s var(--ease); }
.nx-add-cart:hover { background: var(--ivory); transform: translateY(-2px); box-shadow: 0 10px 32px rgba(212,168,83,.2); }
.nx-trust { display: flex; flex-wrap: wrap; gap: 1.25rem; padding: 1.25rem 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin: 1.5rem 0; }
.nx-trust-item { font-family: var(--mono); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.nx-acc-item { border-bottom: 1px solid var(--line); }
.nx-acc-btn { width: 100%; background: none; border: none; padding: 1.25rem 0; display: flex; justify-content: space-between; align-items: center; font-family: var(--heading); font-size: .9375rem; font-weight: 600; color: var(--ivory); transition: color .2s; }
.nx-acc-btn:hover { color: var(--gold); }
.nx-acc-icon { width: 18px; height: 18px; border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; font-size: .875rem; color: var(--muted); transition: all .25s var(--ease); }
.nx-acc-item.open .nx-acc-icon { background: var(--gold); border-color: var(--gold); color: var(--ob); transform: rotate(45deg); }
.nx-acc-body { display: none; padding: 0 0 1.5rem; font-family: var(--display); font-style: italic; font-size: .9375rem; color: var(--muted); line-height: 1.8; }
.nx-acc-item.open .nx-acc-body { display: block; }

/* ── Auth pages ──────────────────────────────────────── */
.nx-auth-wrap { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; }
@media(max-width:900px){ .nx-auth-wrap { grid-template-columns: 1fr; } }
.nx-auth-left { background: var(--ob); padding: clamp(4rem,8vw,8rem) clamp(2rem,5vw,5rem); display: flex; flex-direction: column; justify-content: center; border-right: 1px solid var(--line); position: relative; overflow: hidden; }
.nx-auth-right { background: var(--ink); padding: clamp(4rem,8vw,8rem) clamp(2rem,5vw,5rem); display: flex; flex-direction: column; justify-content: center; }
.nx-auth-h { font-family: var(--display); font-weight: 300; font-size: clamp(4rem,9vw,10rem); line-height: .88; letter-spacing: -.025em; color: var(--ivory); }
.nx-auth-h em { font-style: italic; color: var(--gold); }
.nx-auth-ghost { position: absolute; right: -.02em; bottom: -.08em; font-family: var(--display); font-style: italic; font-size: 20rem; font-weight: 300; color: transparent; -webkit-text-stroke: 1px rgba(212,168,83,.04); pointer-events: none; user-select: none; line-height: 1; }
.nx-auth-perks { margin-top: 3rem; display: flex; flex-direction: column; gap: 1.25rem; position: relative; z-index: 1; }
.nx-auth-perk { display: flex; align-items: center; gap: 1rem; font-family: var(--display); font-style: italic; font-size: .9375rem; color: var(--muted); }
.nx-auth-perk::before { content: ''; width: 24px; height: 1px; background: var(--gold); flex-shrink: 0; }
.nx-form-title { font-family: var(--display); font-style: italic; font-size: 3.25rem; font-weight: 300; color: var(--ivory); margin-bottom: 2.5rem; }
.nx-field { margin-bottom: 2rem; }
.nx-field label { font-family: var(--mono); font-size: .52rem; letter-spacing: .22em; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: .625rem; }
.nx-field input { width: 100%; background: none; border: none; border-bottom: 1px solid var(--line); padding: .75rem 0; font-family: var(--display); font-style: italic; font-size: 1rem; color: var(--ivory); outline: none; transition: border-color .2s; }
.nx-field input::placeholder { color: var(--line); }
.nx-field input:focus { border-color: var(--gold); }
.nx-field-note { margin-top: .5rem; text-align: right; font-family: var(--mono); font-size: .55rem; letter-spacing: .1em; text-transform: uppercase; }
.nx-field-note a { color: var(--muted); text-decoration: none; transition: color .2s; }
.nx-field-note a:hover { color: var(--gold); }
.nx-form-submit { width: 100%; background: var(--gold); color: var(--ob); border: none; padding: 1.125rem; font-family: var(--mono); font-size: .6rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; margin-top: .5rem; transition: all .35s var(--ease); }
.nx-form-submit:hover { background: var(--ivory); transform: translateY(-2px); box-shadow: 0 10px 32px rgba(212,168,83,.2); }
.nx-form-switch { font-family: var(--mono); font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); text-align: center; margin-top: 2rem; }
.nx-form-switch a { color: var(--gold); text-decoration: none; }

/* ── Contact ─────────────────────────────────────────── */
.nx-contact-wrap { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; }
@media(max-width:900px){ .nx-contact-wrap { grid-template-columns: 1fr; } }
.nx-contact-left { background: var(--ob); padding: clamp(4rem,8vw,8rem) clamp(2rem,5vw,5rem); display: flex; flex-direction: column; justify-content: center; border-right: 1px solid var(--line); position: relative; overflow: hidden; }
.nx-contact-right { background: var(--ink); padding: clamp(4rem,8vw,8rem) clamp(2rem,5vw,5rem); display: flex; flex-direction: column; justify-content: center; }
.nx-contact-info { margin-top: 3rem; display: flex; flex-direction: column; gap: 2rem; position: relative; z-index: 1; }
.nx-contact-item-lbl { font-family: var(--mono); font-size: .52rem; letter-spacing: .22em; text-transform: uppercase; color: var(--muted); margin-bottom: .375rem; }
.nx-contact-item-val { font-family: var(--display); font-style: italic; font-size: 1rem; color: var(--ivory); }
.nx-contact-item-val a { color: var(--gold); text-decoration: none; }
.nx-textarea { width: 100%; background: none; border: none; border-bottom: 1px solid var(--line); padding: .75rem 0; font-family: var(--display); font-style: italic; font-size: 1rem; color: var(--ivory); outline: none; resize: none; font-size: 1rem; transition: border-color .2s; }
.nx-textarea:focus { border-color: var(--gold); }

/* ── Blog ────────────────────────────────────────────── */
.nx-posts-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--line); margin-top: 3rem; }
@media(max-width:900px){ .nx-posts-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:480px){ .nx-posts-grid { grid-template-columns: 1fr; } }
.nx-post-card { background: var(--ink); display: flex; flex-direction: column; transition: background .3s; }
.nx-post-card:hover { background: var(--char); }
.nx-post-img { aspect-ratio: 16/9; overflow: hidden; }
.nx-post-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease); }
.nx-post-card:hover .nx-post-img img { transform: scale(1.05); }
.nx-post-body { padding: 1.75rem; flex: 1; display: flex; flex-direction: column; gap: .5rem; }
.nx-post-cat { font-family: var(--mono); font-size: .52rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); opacity: .7; }
.nx-post-title { font-family: var(--display); font-style: italic; font-size: 1.375rem; font-weight: 300; color: var(--ivory); text-decoration: none; transition: color .2s; line-height: 1.2; }
.nx-post-title:hover { color: var(--gold); }
.nx-post-excerpt { font-family: var(--display); font-style: italic; font-size: .875rem; color: var(--muted); line-height: 1.65; }
.nx-post-meta { font-family: var(--mono); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-top: auto; padding-top: .875rem; border-top: 1px solid var(--line); display: flex; justify-content: space-between; }

/* ── Comments ────────────────────────────────────────── */
.nx-comments { padding: clamp(3rem,6vw,6rem) clamp(1.5rem,4vw,5rem); background: var(--char); border-top: 1px solid var(--line); }
.nx-comments-title { font-family: var(--display); font-style: italic; font-weight: 300; font-size: 3rem; color: var(--ivory); margin-bottom: 2.5rem; }
.nx-comment { padding: 1.5rem 0; border-bottom: 1px solid var(--line); }
.nx-comment-wrap { display: grid; grid-template-columns: 44px 1fr; gap: 1.25rem; }
.nx-comment-avatar img { width: 44px; height: 44px; border-radius: 50%; }
.nx-comment-meta { font-family: var(--mono); font-size: .58rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: .5rem; }
.nx-comment-text p { font-family: var(--display); font-style: italic; font-size: .9375rem; color: var(--muted); line-height: 1.75; }
.comment-reply-link { font-family: var(--mono); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); text-decoration: none; }
.comment-form label { font-family: var(--mono); font-size: .52rem; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: .5rem; }
.comment-form input[type=text], .comment-form input[type=email], .comment-form textarea { width: 100%; background: none; border: none; border-bottom: 1px solid var(--line); padding: .75rem 0; font-family: var(--display); font-style: italic; font-size: 1rem; color: var(--ivory); outline: none; transition: border-color .2s; }
.comment-form input:focus, .comment-form textarea:focus { border-color: var(--gold); }
.comment-form input[type=submit] { background: var(--gold); color: var(--ob); border: none; padding: .875rem 2rem; font-family: var(--mono); font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; margin-top: 1rem; transition: all .3s; }
.comment-form input[type=submit]:hover { background: var(--ivory); }
.comment-form .comment-form-cookies-consent label { font-size: .8rem; font-family: var(--display); font-style: italic; }
.comment-form .comment-form-cookies-consent input { accent-color: var(--gold); }

/* ── WooCommerce overrides ──────────────────────────── */
.nx-woo-main .woocommerce { padding: 3rem clamp(1.5rem,4vw,5rem); }
.woocommerce ul.products li.product { background: var(--ink); border: 1px solid var(--line); margin: 0; padding: 0; }
.woocommerce ul.products li.product:hover { background: var(--char); }
.woocommerce .price { font-family: var(--mono); font-size: 1rem; color: var(--ivory); letter-spacing: .06em; }
.woocommerce .price ins { color: var(--gold); }
.woocommerce button.button, .woocommerce input.button { background: none; border: 1px solid rgba(212,168,83,.4); color: var(--gold); font-family: var(--mono); font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; border-radius: 0; transition: all .3s; }
.woocommerce button.button:hover { background: var(--gold); color: var(--ob); }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea { background: var(--ink); border: 1px solid var(--line); color: var(--ivory); border-radius: 0; padding: .75rem 1rem; transition: border-color .2s; }
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus { border-color: var(--gold); outline: none; }
.woocommerce table.shop_table { border: 1px solid var(--line); background: var(--ink); }
.woocommerce table.shop_table th, .woocommerce table.shop_table td { border: 1px solid var(--line); padding: .875rem 1rem; }
.woocommerce .woocommerce-info, .woocommerce .woocommerce-message { background: rgba(212,168,83,.06); border-left: 2px solid var(--gold); border-radius: 0; color: var(--ivory); }
.woocommerce .star-rating span::before { color: var(--gold); }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span { background: var(--ink); border: 1px solid var(--line); color: var(--muted); border-radius: 0; font-family: var(--mono); font-size: .6rem; }
.woocommerce nav.woocommerce-pagination ul li a:hover, .woocommerce nav.woocommerce-pagination ul li span.current { background: var(--gold); border-color: var(--gold); color: var(--ob); }

/* ── Pagination ──────────────────────────────────────── */
.nx-pagination { display: flex; justify-content: center; gap: .5rem; margin-top: 4rem; flex-wrap: wrap; }
.nx-pagination a, .nx-pagination span { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border: 1px solid var(--line); font-family: var(--mono); font-size: .65rem; color: var(--muted); text-decoration: none; transition: all .2s; }
.nx-pagination a:hover, .nx-pagination span.current { border-color: var(--gold); color: var(--gold); }

/* ── Reveal ──────────────────────────────────────────── */
.nx-reveal { opacity: 0; transform: translateY(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.nx-reveal.nx-in { opacity: 1; transform: none; }
.nx-reveal-l { opacity: 0; transform: translateX(-26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.nx-reveal-l.nx-in { opacity: 1; transform: none; }
.nx-reveal-r { opacity: 0; transform: translateX(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.nx-reveal-r.nx-in { opacity: 1; transform: none; }
.nx-d1{transition-delay:.1s}.nx-d2{transition-delay:.2s}.nx-d3{transition-delay:.3s}.nx-d4{transition-delay:.4s}.nx-d5{transition-delay:.5s}

/* ── Required WP ─────────────────────────────────────── */
.screen-reader-text { border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important }
.screen-reader-text:focus { background:var(--char);clip:auto!important;clip-path:none;color:var(--gold);display:block;font-size:.875rem;height:auto;left:6px;padding:12px 18px;text-decoration:none;top:6px;width:auto;z-index:100000 }

.alignleft { float:left;margin:0 1.5em 1em 0 }
.alignright { float:right;margin:0 0 1em 1.5em }
.aligncenter { clear:both;display:block;margin:0 auto 1em }
.alignwide { margin-left:auto;margin-right:auto }
.alignfull { width:100vw;max-width:100vw;margin-left:calc(-1 * var(--wp--style--root--padding-left,0px));margin-right:calc(-1 * var(--wp--style--root--padding-right,0px)) }
.wp-caption { max-width:100% }
.wp-caption-text { font-family:var(--mono);font-size:.75rem;color:var(--muted);text-align:center }
.sticky::before { content:'New';position:absolute;top:0;right:0;background:var(--gold);color:var(--ob);font-family:var(--mono);font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;z-index:2 }
.gallery { display:flex;flex-wrap:wrap;gap:.5rem }
.gallery-caption { font-size:.75rem;color:var(--muted) }
.bypostauthor > .comment-body { border-left:1px solid var(--gold);padding-left:1rem }

/* ── Keyframes ───────────────────────────────────────── */
@keyframes fade-up  { from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none} }
@keyframes fade-in  { from{opacity:0}to{opacity:1} }

/* ── Reduced motion ─────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .nx-cur,.nx-cursor,.nx-ring,.nx-glow{display:none}
  html{cursor:auto}body *{cursor:auto!important}
}

/* ══════════════════════════════════════════════════════
   BLOG INDEX & POST STYLES
   ══════════════════════════════════════════════════════ */
.nx-blog-wrap,
.nx-blog-main { padding: 6rem clamp(1.5rem,5vw,5rem); }

.nx-posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2.5rem;
  max-width: 1400px;
  margin: 0 auto 4rem;
}

.nx-post-card {
  background: var(--char);
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color .3s, transform .3s;
}
.nx-post-card:hover { border-color: var(--gold); transform: translateY(-4px); }

.nx-post-thumb img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.nx-post-body { padding: 1.75rem; }
.nx-post-cat { margin-bottom: .75rem; }
.nx-post-cat a { font-family: var(--mono); font-size: .55rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); text-decoration: none; }
.nx-post-heading { font-family: var(--display); font-style: italic; font-size: 1.375rem; font-weight: 300; line-height: 1.25; margin-bottom: .875rem; }
.nx-post-heading a { color: var(--ivory); text-decoration: none; transition: color .2s; }
.nx-post-heading a:hover { color: var(--gold); }
.nx-post-meta { font-family: var(--mono); font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: .875rem; display: flex; gap: 1rem; }
.nx-post-excerpt,
.entry-summary { font-size: .9rem; color: var(--muted); line-height: 1.7; margin-bottom: 1.25rem; }
.nx-read-more { font-family: var(--mono); font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); text-decoration: none; }
.nx-read-more:hover { text-decoration: underline; }
.nx-no-posts { color: var(--muted); font-style: italic; text-align: center; padding: 4rem 0; }

/* SINGLE POST */
.nx-single-wrap,
.nx-single-main { padding: 6rem clamp(1.5rem,5vw,5rem); }
.nx-article { max-width: 780px; margin: 0 auto; }
.nx-article-header { margin-bottom: 2.5rem; padding-bottom: 2rem; border-bottom: 1px solid var(--line); }
.nx-article-title { font-family: var(--display); font-style: italic; font-size: clamp(2.5rem,5vw,4.5rem); font-weight: 300; line-height: 1.05; color: var(--ivory); margin-bottom: 1.25rem; }
.nx-article-meta { font-family: var(--mono); font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); display: flex; gap: 1.5rem; }
.nx-article-featured { margin-bottom: 3rem; border-radius: 8px; overflow: hidden; }
.nx-article-featured img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.nx-article-footer { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--line); }

/* PAGE */
.nx-page-main { padding: 6rem clamp(1.5rem,5vw,5rem); }
.nx-page-article { max-width: 860px; margin: 0 auto; }
.nx-page-title { font-family: var(--display); font-style: italic; font-size: clamp(2.5rem,5vw,5rem); font-weight: 300; line-height: 1; color: var(--ivory); margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid var(--line); }

/* 404 */
.nx-404-main { min-height: 60vh; display: flex; align-items: center; justify-content: center; }
.nx-404-inner { text-align: center; max-width: 560px; padding: 2rem; }
.nx-404-title { font-family: var(--display); font-size: clamp(6rem,20vw,18rem); font-weight: 900; color: transparent; -webkit-text-stroke: 1px var(--line); line-height: 1; margin-bottom: 0; }
.nx-404-subtitle { font-family: var(--display); font-style: italic; font-size: 2rem; font-weight: 300; color: var(--ivory); margin-bottom: 1.5rem; }

/* ── WP Admin bar: prevent header overlap ─────────────────── */
.admin-bar .nx-nav,
.admin-bar .ob-nav,
.admin-bar .v-nav,
.admin-bar .q-nav {
    top: 32px;
}
@media screen and (max-width: 782px) {
    .admin-bar .nx-nav,
    .admin-bar .ob-nav,
    .admin-bar .v-nav,
    .admin-bar .q-nav {
        top: 46px;
    }
}

/* ── Skip to main content (WP.org accessibility requirement) ── */
/* ── Skip to main content (WP.org accessibility requirement) ── */
.skip-link {
    clip: rect(1px,1px,1px,1px);
    height: 1px;
    overflow: hidden;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}
.skip-link:focus {
    background-color: #d4a853;
    border-radius: 0 0 6px 6px;
    clip: auto;
    color: #080808;
    display: block;
    font-size: .875rem;
    font-weight: 700;
    height: auto;
    left: 6px;
    line-height: normal;
    padding: .75rem 1.5rem;
    text-decoration: none;
    top: 0;
    width: auto;
    z-index: 100000;
    outline: 3px solid #080808;
    outline-offset: 2px;
}
/* Remove focus outline on main element when skip link used */
#primary:focus { outline: none; }
/* Remove focus outline on main element when skip link used */
#primary:focus { outline: none; }

/* ── Footer: proper spacing and readability ─────────────────── */
.nx-footer {
    background: #080808;
    border-top: 1px solid rgba(212,168,83,.2);
    color: #f5f0e8;
}
.nx-footer-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 4rem clamp(1.5rem, 5vw, 5rem) 3rem;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 3rem;
    align-items: start;
}
@media (max-width: 768px) {
    .nx-footer-inner { grid-template-columns: 1fr; gap: 2rem; }
}
.nx-footer-brand {
    display: flex;
    flex-direction: column;
    gap: .75rem;
}
.nx-footer-logo {
    font-family: var(--display, 'Cormorant Garamond', serif);
    font-size: 1.5rem;
    font-style: italic;
    color: #f5f0e8;
    text-decoration: none;
}
.nx-footer-tagline {
    font-size: .875rem;
    color: #888888;
    line-height: 1.6;
}
.nx-footer-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}
@media (max-width: 480px) {
    .nx-footer-cols { grid-template-columns: 1fr; }
}
.nx-footer-col-title {
    font-family: var(--mono, 'JetBrains Mono', monospace);
    font-size: .55rem;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: #d4a853;
    margin-bottom: 1rem;
    font-weight: 400;
}
.nx-footer-nav a,
.nx-footer-legal-nav a {
    display: block;
    font-size: .875rem;
    color: #888888;
    padding: .25rem 0;
    text-decoration: none;
    transition: color .2s;
}
.nx-footer-nav a:hover,
.nx-footer-legal-nav a:hover { color: #d4a853; }
.nx-footer-bottom {
    max-width: 1400px;
    margin: 0 auto;
    padding: 1.5rem clamp(1.5rem, 5vw, 5rem);
    border-top: 1px solid rgba(255,255,255,.07);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .875rem;
}
.nx-footer-copy,
.nx-footer-credit {
    font-size: .8rem;
    color: #888888;
    line-height: 1.6;
    margin: 0;
}
.nx-footer-copy a,
.nx-footer-credit a {
    color: #d4a853;
    text-decoration: none;
}
.nx-footer-copy a:hover,
.nx-footer-credit a:hover { text-decoration: underline; }

/* ── Archive page: readable typography and layout ────────────── */
.nx-page-hero {
    padding: clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,5rem) clamp(2rem,4vw,4rem);
    border-bottom: 1px solid rgba(212,168,83,.15);
}
.nx-page-h1 {
    font-family: var(--display, 'Cormorant Garamond', serif);
    font-size: clamp(2.5rem, 6vw, 5rem);
    font-weight: 300;
    font-style: italic;
    line-height: 1.05;
    color: #f5f0e8;
    letter-spacing: -.01em;
    margin-bottom: 1rem;
}
.nx-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 2rem;
    padding: clamp(2rem,4vw,4rem) clamp(1.5rem,5vw,5rem);
    max-width: 1400px;
    margin: 0 auto;
}
.nx-post-card {
    background: #111111;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color .3s, transform .3s;
}
.nx-post-card:hover {
    border-color: #d4a853;
    transform: translateY(-4px);
}
.nx-post-img img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
}
.nx-post-body {
    padding: 1.5rem;
}
.nx-post-cat {
    font-family: var(--mono, 'JetBrains Mono', monospace);
    font-size: .55rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: #d4a853;
    margin-bottom: .625rem;
    display: block;
}
.nx-post-cat a {
    color: #d4a853;
    text-decoration: none;
}
.nx-post-title {
    font-family: var(--display, 'Cormorant Garamond', serif);
    font-size: 1.375rem;
    font-style: italic;
    font-weight: 300;
    line-height: 1.25;
    margin-bottom: .75rem;
    color: #f5f0e8;
}
.nx-post-title a {
    color: #f5f0e8;
    text-decoration: none;
    transition: color .2s;
}
.nx-post-title a:hover { color: #d4a853; }
.nx-post-excerpt {
    font-size: .9rem;
    color: #888888;
    line-height: 1.7;
    margin-bottom: 1rem;
}
.nx-post-meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: .75rem;
    color: #444444;
    font-family: var(--mono, 'JetBrains Mono', monospace);
}
.nx-pagination {
    padding: 2rem clamp(1.5rem,5vw,5rem);
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    gap: .5rem;
    flex-wrap: wrap;
}
.nx-pagination a,
.nx-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 42px;
    padding: 0 .875rem;
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 6px;
    font-size: .8rem;
    font-family: var(--mono, 'JetBrains Mono', monospace);
    color: #888888;
    text-decoration: none;
    transition: all .2s;
    background: #111111;
}
.nx-pagination a:hover { border-color: #d4a853; color: #d4a853; }
.nx-pagination .current { background: #d4a853; border-color: #d4a853; color: #080808; }

/* ── Mobile navigation fix ──────────────────────────────────── */
/* .nx-nav position defined above in primary rule */

/* WordPress FSE Navigation block mobile overlay */
.nx-nav .wp-block-navigation__responsive-container.is-menu-open {
    background: #080808;
    padding: 1.5rem;
}

.nx-nav .wp-block-navigation__responsive-container-open,
.nx-nav .wp-block-navigation__responsive-container-close {
    color: #f5f0e8;
    background: transparent;
    border: 1px solid rgba(212,168,83,.3);
    border-radius: 4px;
    padding: .4rem .6rem;
    cursor: pointer;
}

.nx-nav .wp-block-navigation__responsive-container-open:hover,
.nx-nav .wp-block-navigation__responsive-container-close:hover {
    border-color: #d4a853;
    color: #d4a853;
}

/* Ensure nav items don't overflow and get cut off */
.nx-nav .wp-block-navigation__container {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.nx-nav .wp-block-navigation-item__content {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    padding: .5rem 1rem;
    margin: 0 .25rem;
    font-family: var(--mono, 'JetBrains Mono', monospace);
    font-size: .6rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: #888888;
    text-decoration: none;
    transition: color .2s;
}

.nx-nav .wp-block-navigation-item__content:hover {
    color: #d4a853;
}

/* Mobile: full-width overlay menu */
@media (max-width: 781px) {
    .nx-nav-center,
    .nx-nav-right {
        display: none;
    }
    .nx-nav-brand {
        flex: 1;
    }
    .nx-nav .wp-block-navigation__responsive-container.is-menu-open {
        display: flex !important;
        flex-direction: column !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 9999 !important;
        background-color: #080808 !important;
        background: #080808 !important;
        color: #f5f0e8 !important;
        padding: 5rem 2rem 2rem !important;
        overflow-y: auto !important;
    }
    /* Force dark background on the overlay container itself */
    .nx-nav .wp-block-navigation__responsive-container-overlay-background {
        background-color: #080808 !important;
    }
    .nx-nav .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__container {
        flex-direction: column !important;
        gap: 2rem !important;
        align-items: flex-start !important;
        padding: 1rem 0 !important;
    }
    .nx-nav .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation-item__content,
    .nx-nav .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation-item__content:link,
    .nx-nav .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation-item__content:visited {
        font-family: 'JetBrains Mono', monospace !important;
        font-size: 1.25rem !important;
        letter-spacing: .18em !important;
        text-transform: uppercase !important;
        color: #f5f0e8 !important;
        padding: .75rem 0 !important;
        text-decoration: none !important;
        display: block !important;
        width: 100% !important;
        transition: color .2s !important;
    }
    .nx-nav .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation-item__content:hover {
        color: #d4a853 !important;
    }
    /* Close button must be visible on dark background */
    .nx-nav .wp-block-navigation__responsive-container-close {
        position: absolute !important;
        top: 1.5rem !important;
        right: 1.5rem !important;
        color: #f5f0e8 !important;
        background: transparent !important;
        border: 1px solid rgba(245,240,232,.3) !important;
        border-radius: 4px !important;
        padding: .5rem .75rem !important;
        cursor: pointer !important;
        z-index: 10000 !important;
    }
    .nx-nav .wp-block-navigation__responsive-container-close:hover {
        border-color: #d4a853 !important;
        color: #d4a853 !important;
    }
}
