/* ─── Reset & Base ─────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg:        #080808;
  --fg:        #F0EAE0;
  --muted:     #7A7570;
  --accent:    #C8A96E;
  --ink:       #1A1A1A;
  --light:     #E8E2D8;
}
html { font-size: 16px; scroll-behavior: smooth; }
body { background: var(--bg); color: var(--fg); font-family: 'Outfit', sans-serif; font-weight: 300; line-height: 1.6; -webkit-font-smoothing: antialiased; }

/* ─── Typography ───────────────────────────────────── */
h1, h2, h3, h4 { font-family: 'Playfair Display', serif; font-weight: 500; line-height: 1.15; }
a { color: inherit; text-decoration: none; }

/* ─── Nav ─────────────────────────────────────────── */
.nav { display: flex; align-items: center; justify-content: space-between; padding: 1.5rem 3rem; border-bottom: 1px solid rgba(240,234,224,0.08); }
.nav-wordmark { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 500; letter-spacing: 0.15em; }
.nav-tagline { font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }

/* ─── Hero ─────────────────────────────────────────── */
.hero { display: grid; grid-template-columns: 1fr 1fr; min-height: calc(100vh - 65px); }
.hero-image-block { background: var(--ink); position: relative; overflow: hidden; }
.hero-image-frame { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.hero-img-inner { width: 70%; padding-bottom: 120%; background: linear-gradient(160deg, #1c1c1c 0%, #111 50%, #0d0d0d 100%); border: 1px solid rgba(200,169,110,0.15); position: relative; }
.hero-img-inner::before { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient( -45deg, transparent, transparent 8px, rgba(200,169,110,0.03) 8px, rgba(200,169,110,0.03) 9px ); }
.hero-img-inner::after { content: 'CHROME HEARTS'; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%) rotate(-5deg); font-family: 'Playfair Display', serif; font-size: clamp(1.2rem,3vw,2.2rem); font-weight: 400; color: rgba(200,169,110,0.25); letter-spacing: 0.3em; white-space: nowrap; }
.hero-label { position: absolute; bottom: 2rem; left: 2rem; font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.hero-text-block { display: flex; flex-direction: column; justify-content: center; padding: 4rem 5rem; }
.hero-eyebrow { font-size: 0.65rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--accent); margin-bottom: 1.5rem; }
.hero-headline { font-size: clamp(2.2rem, 4.5vw, 4rem); color: var(--fg); margin-bottom: 2rem; font-style: italic; }
.hero-rule { width: 4rem; height: 1px; background: var(--accent); margin-bottom: 2rem; }
.hero-body { font-size: 1rem; color: var(--muted); max-width: 32ch; margin-bottom: 2.5rem; line-height: 1.7; }
.hero-location { display: flex; align-items: center; gap: 0.5rem; font-size: 0.75rem; color: var(--muted); letter-spacing: 0.05em; }

/* ─── Manifesto ─────────────────────────────────────── */
.manifesto { border-top: 1px solid rgba(240,234,224,0.06); border-bottom: 1px solid rgba(240,234,224,0.06); }
.manifesto-inner { display: grid; grid-template-columns: 80px 1fr; gap: 0; padding: 5rem 4rem; max-width: 1200px; margin: 0 auto; }
.manifesto-number { font-family: 'Playfair Display', serif; font-size: 3rem; color: rgba(200,169,110,0.2); font-style: italic; line-height: 1; padding-top: 0.25rem; }
.manifesto-title { font-size: clamp(1.6rem, 3vw, 2.5rem); margin-bottom: 1.5rem; color: var(--fg); }
.manifesto-body { font-size: 0.95rem; color: var(--muted); max-width: 55ch; line-height: 1.8; }

/* ─── Categories ────────────────────────────────────── */
.categories { padding: 6rem 4rem; }
.categories-header { margin-bottom: 4rem; }
.categories-title { font-size: clamp(1.8rem, 3vw, 2.8rem); margin-bottom: 0.75rem; }
.categories-sub { font-size: 0.8rem; color: var(--muted); letter-spacing: 0.1em; }
.categories-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(240,234,224,0.06); }
.category-card { background: var(--bg); display: flex; flex-direction: column; }
.category-visual { height: 280px; position: relative; overflow: hidden; }
.category-visual--jewelry { background: linear-gradient(135deg, #1a1410 0%, #0d0b09 100%); }
.category-visual--jewelry::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 60px; height: 60px; border: 1px solid rgba(200,169,110,0.2); transform: translate(-50%,-50%) rotate(45deg); }
.category-visual--eyewear { background: linear-gradient(135deg, #12100e 0%, #0a0908 100%); }
.category-visual--eyewear::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 80px; height: 30px; border: 1px solid rgba(200,169,110,0.15); border-radius: 50%; }
.category-visual--apparel { background: linear-gradient(135deg, #181614 0%, #0e0c0a 100%); }
.category-visual--apparel::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 40px; height: 50px; border: 1px solid rgba(200,169,110,0.18); }
.category-visual--leather { background: linear-gradient(135deg, #131110 0%, #0b0a09 100%); }
.category-visual--leather::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 70px; height: 45px; border: 1px solid rgba(200,169,110,0.12); }
.category-info { padding: 1.5rem 1.5rem 2rem; flex: 1; }
.category-index { font-size: 0.6rem; letter-spacing: 0.3em; color: var(--accent); margin-bottom: 0.5rem; }
.category-name { font-size: 1.15rem; margin-bottom: 0.6rem; color: var(--fg); }
.category-desc { font-size: 0.8rem; color: var(--muted); line-height: 1.6; }

/* ─── Authentication ────────────────────────────────── */
.authentication { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid rgba(240,234,224,0.06); }
.auth-left { padding: 5rem 4rem; border-right: 1px solid rgba(240,234,224,0.06); display: flex; flex-direction: column; justify-content: center; }
.auth-index-label { font-size: 0.6rem; letter-spacing: 0.3em; color: var(--accent); margin-bottom: 1rem; }
.auth-title { font-size: clamp(1.8rem, 3vw, 2.8rem); font-style: italic; color: var(--fg); line-height: 1.2; }
.auth-right { padding: 5rem 4rem; display: flex; flex-direction: column; justify-content: center; gap: 2.5rem; }
.auth-item { display: flex; gap: 1.25rem; align-items: flex-start; }
.auth-item-marker { width: 6px; height: 6px; background: var(--accent); margin-top: 0.6rem; flex-shrink: 0; }
.auth-item-title { font-size: 0.95rem; font-family: 'Outfit', sans-serif; font-weight: 500; margin-bottom: 0.4rem; color: var(--fg); }
.auth-item-body { font-size: 0.82rem; color: var(--muted); line-height: 1.6; }

/* ─── Philosophy ───────────────────────────────────── */
.philosophy { padding: 6rem 4rem; background: var(--ink); text-align: center; }
.philosophy-inner { max-width: 700px; margin: 0 auto; }
.philosophy-quote { font-family: 'Playfair Display', serif; font-size: clamp(2rem, 4vw, 3.5rem); font-style: italic; color: var(--fg); line-height: 1.2; margin-bottom: 1.5rem; }
.philosophy-attribution { font-size: 0.75rem; letter-spacing: 0.15em; color: var(--muted); text-transform: uppercase; }

/* ─── Closing ───────────────────────────────────────── */
.closing { padding: 8rem 4rem; border-top: 1px solid rgba(240,234,224,0.06); }
.closing-inner { max-width: 700px; }
.closing-eyebrow { font-size: 0.65rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--muted); margin-bottom: 2rem; }
.closing-headline { font-size: clamp(2.5rem, 5vw, 4.5rem); font-style: italic; color: var(--fg); margin-bottom: 2rem; line-height: 1.1; }
.closing-body { font-size: 1rem; color: var(--muted); max-width: 50ch; line-height: 1.7; }

/* ─── Footer ────────────────────────────────────────── */
.footer { padding: 3rem 4rem; border-top: 1px solid rgba(240,234,224,0.06); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.footer-brand { font-family: 'Playfair Display', serif; font-size: 1rem; letter-spacing: 0.15em; }
.footer-meta { font-size: 0.7rem; color: var(--muted); }
.footer-links { font-size: 0.7rem; color: var(--muted); display: flex; gap: 0.5rem; align-items: center; }
.footer-links a:hover { color: var(--fg); }
.footer-sep { color: rgba(240,234,224,0.2); }

/* ─── Mobile ────────────────────────────────────────── */
@media (max-width: 900px) {
  .nav { padding: 1.25rem 1.5rem; }
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-image-block { min-height: 50vh; position: relative; }
  .hero-text-block { padding: 3rem 1.5rem; }
  .manifesto-inner { grid-template-columns: 1fr; padding: 3rem 1.5rem; gap: 1rem; }
  .manifesto-number { font-size: 2rem; }
  .categories { padding: 4rem 1.5rem; }
  .categories-grid { grid-template-columns: 1fr 1fr; }
  .authentication { grid-template-columns: 1fr; }
  .auth-left { padding: 3rem 1.5rem; border-right: none; border-bottom: 1px solid rgba(240,234,224,0.06); }
  .auth-right { padding: 3rem 1.5rem; }
  .philosophy { padding: 4rem 1.5rem; }
  .closing { padding: 5rem 1.5rem; }
  .footer { padding: 2rem 1.5rem; flex-direction: column; align-items: flex-start; }
}
@media (max-width: 600px) {
  .categories-grid { grid-template-columns: 1fr; }
}