/* ===================================================================
   D BLACK'S THRIFT — Chrome Hearts-inspired gothic streetwear
   Iron Sharp Media · dark · chrome · high-contrast · cinematic motion
   =================================================================== */

:root {
  /* Deep black base — high contrast */
  --ink:     #050506;
  --ink-2:   #0a0a0c;
  --ink-3:   #0f0f12;
  --panel:   #121216;
  --panel-2: #17171c;
  --line:    rgba(196,201,211,0.10);
  --line-2:  rgba(196,201,211,0.22);

  /* Text */
  --text:  #f3f4f7;
  --muted: #b6bac3;
  --faint: #74777f;

  /* Chrome / metal */
  --chrome-lite: #eef1f6;
  --chrome:      #c4c9d3;
  --chrome-mid:  #80858f;
  --chrome-dark: #3a3d45;

  /* Accents — restrained, luxe */
  --red:      #e11d33;
  --red-deep: #8e0f20;
  --gold:     #d9b25a;
  --steel:    #8fa3c4;

  /* Brushed-metal gradients */
  --grad-chrome: linear-gradient(180deg,#ffffff 0%,#cfd4de 18%,#7c818d 42%,#42454d 50%,#6b707b 58%,#d8dce4 80%,#9aa0ac 100%);
  --grad-chrome-h: linear-gradient(105deg,#eef1f6 0%,#9aa0ac 25%,#4a4d55 50%,#aeb4be 72%,#e8ebf1 100%);

  --radius:   14px;
  --radius-lg:22px;
  --maxw:     1200px;
  --ease:     cubic-bezier(.19,1,.22,1);
  --shadow:   0 30px 80px -30px rgba(0,0,0,.92);
  --shadow-2: 0 18px 50px -22px rgba(0,0,0,.9);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:92px; }
body {
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--ink); color:var(--text); line-height:1.62;
  overflow-x:hidden; -webkit-font-smoothing:antialiased; position:relative;
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
em { font-style:normal; color:var(--chrome-lite);
  background:var(--grad-chrome-h); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
::selection { background:var(--red); color:#fff; }

/* ---------- Texture overlays ---------- */
.grain {
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.vignette {
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 0%, transparent 55%, rgba(0,0,0,.55) 100%);
}

/* ---------- Drifting motif field ---------- */
.motif-field { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.motif {
  position:absolute; color:var(--chrome-mid); opacity:.05;
  animation:drift linear infinite; will-change:transform;
}
.motif svg { width:100%; height:100%; }
@keyframes drift {
  0%   { transform:translateY(110vh) rotate(0deg); }
  100% { transform:translateY(-30vh) rotate(360deg); }
}

/* ---------- Skip link ---------- */
.skip-link { position:absolute; left:-999px; top:0; background:var(--red); color:#fff;
  padding:10px 16px; border-radius:0 0 10px 0; z-index:300; font-weight:700; }
.skip-link:focus { left:0; }

/* ---------- Layout ---------- */
.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px; position:relative; z-index:2; }
.section { padding:clamp(78px,11vw,140px) 0; position:relative; z-index:2; }

/* ---------- Headings / kickers ---------- */
.kicker {
  display:inline-block; font-family:'Oswald',sans-serif; font-weight:600;
  letter-spacing:.34em; text-transform:uppercase; font-size:.72rem;
  color:var(--red); margin-bottom:18px;
}
.title {
  font-family:'Pirata One',serif; font-weight:400;
  font-size:clamp(2.1rem,5.2vw,3.7rem); line-height:1.02; letter-spacing:.01em;
  color:var(--text); text-shadow:0 2px 30px rgba(0,0,0,.6);
}
.lead { color:var(--muted); max-width:560px; margin-top:18px; font-size:1.06rem; }
.section-head { max-width:760px; margin-bottom:60px; }

/* chrome-line divider under section heads */
.section-head .title::after {
  content:""; display:block; width:108px; height:2px; margin-top:22px;
  background:var(--grad-chrome-h); box-shadow:0 0 16px rgba(196,201,211,.4);
}

/* ---------- Buttons ---------- */
.btn {
  position:relative; display:inline-flex; align-items:center; gap:10px;
  font-family:'Oswald',sans-serif; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  font-size:.92rem; padding:15px 28px; border-radius:999px; cursor:pointer; border:none;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease); white-space:nowrap; overflow:hidden; isolation:isolate;
}
.btn-arrow { transition:transform .35s var(--ease); }
.btn:hover .btn-arrow { transform:translateX(6px); }

.btn-chrome { background:var(--grad-chrome-h); background-size:220% 100%; color:#0a0a0c;
  box-shadow:0 12px 34px -10px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.7); animation:chromeflow 8s linear infinite; }
.btn-chrome::after { /* shine sweep */
  content:""; position:absolute; inset:0; background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.85) 50%,transparent 65%);
  transform:translateX(-130%); }
.btn-chrome:hover { transform:translateY(-4px); box-shadow:0 22px 50px -14px rgba(225,29,51,.45), inset 0 1px 0 rgba(255,255,255,.8); }
.btn-chrome:hover::after { transform:translateX(130%); transition:transform .8s var(--ease); }
@keyframes chromeflow { to { background-position:220% 0; } }

.btn-ghost { background:rgba(255,255,255,.03); color:var(--text); border:1px solid var(--line-2); backdrop-filter:blur(4px); }
.btn-ghost:hover { transform:translateY(-4px); border-color:var(--chrome); box-shadow:0 0 0 1px var(--chrome), 0 18px 40px -18px rgba(196,201,211,.5); }
.btn-block { width:100%; justify-content:center; }

/* ---------- NAV ---------- */
.nav { position:fixed; inset:0 0 auto 0; z-index:100; transition:background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease); border-bottom:1px solid transparent; }
.nav.scrolled { background:rgba(5,5,6,.78); backdrop-filter:blur(16px); border-bottom:1px solid var(--line); box-shadow:0 14px 40px -26px #000; }
.nav-inner { max-width:var(--maxw); margin:0 auto; padding:15px 26px; display:flex; align-items:center; justify-content:space-between; }

.brand { display:flex; align-items:center; gap:13px; }
.brand-emblem { width:34px; height:42px; filter:drop-shadow(0 3px 8px rgba(0,0,0,.7)); transition:transform .6s var(--ease); }
.brand:hover .brand-emblem { transform:rotate(8deg) scale(1.08); }
.brand-wm { display:flex; flex-direction:column; line-height:1; }
.brand-word { font-family:'UnifrakturCook',serif; font-weight:700; font-size:1.5rem;
  background:var(--grad-chrome-h); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.6)); }
.brand-sub { font-family:'Oswald',sans-serif; font-weight:500; font-size:.6rem; letter-spacing:.42em; color:var(--faint); margin-top:3px; }

.nav-links { display:flex; align-items:center; gap:4px; }
.nav-links a { font-family:'Oswald',sans-serif; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  font-size:.82rem; color:var(--muted); padding:9px 16px; border-radius:999px; transition:color .25s, background .25s; }
.nav-links a:hover { color:var(--text); background:rgba(255,255,255,.05); }
.nav-links .nav-cta { background:var(--grad-chrome-h); color:#0a0a0c; margin-left:8px; box-shadow:inset 0 1px 0 rgba(255,255,255,.6); }
.nav-links .nav-cta:hover { color:#0a0a0c; filter:brightness(1.05); }

.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.nav-toggle span { width:26px; height:2px; background:var(--chrome); border-radius:2px; transition:transform .3s var(--ease), opacity .3s var(--ease); }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- HERO ---------- */
.hero { position:relative; min-height:100vh; display:flex; flex-direction:column; justify-content:center;
  padding:130px 0 0; overflow:hidden;
  background:
    radial-gradient(900px 520px at 82% -8%, rgba(225,29,51,.16), transparent 60%),
    radial-gradient(820px 520px at -5% 40%, rgba(143,163,196,.12), transparent 58%),
    linear-gradient(180deg,#050506 0%,#0a0a0d 70%,#0d0d11 100%);
}
.hero-bg { position:absolute; inset:-10% 0; z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 30h60M30 0v60' stroke='%23ffffff' stroke-width='.5' opacity='.04'/%3E%3C/svg%3E");
  mask-image:radial-gradient(80% 70% at 50% 40%, #000 30%, transparent 80%); }
.hero-watermark { position:absolute; top:50%; left:50%; width:min(74vh,620px); transform:translate(-50%,-52%);
  opacity:.06; z-index:0; animation:spin 60s linear infinite; }
@keyframes spin { to { transform:translate(-50%,-52%) rotate(360deg); } }
.orb-wrap { position:absolute; inset:0; z-index:0; transition:transform .35s var(--ease); will-change:transform; }
.orb { position:absolute; border-radius:50%; filter:blur(90px); z-index:0; }
.orb-red { width:440px; height:440px; background:rgba(225,29,51,.26); top:8%; right:6%; animation:float 12s ease-in-out infinite; }
.orb-steel { width:380px; height:380px; background:rgba(143,163,196,.20); bottom:8%; left:4%; animation:float 16s ease-in-out infinite reverse; }
@keyframes float { 0%,100%{ transform:translate(0,0);} 50%{ transform:translate(24px,-30px);} }
.scanline { position:absolute; left:0; right:0; top:0; height:140%; z-index:1; pointer-events:none; opacity:.5;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.04) 50%,transparent);
  background-size:100% 6px; animation:scan 8s linear infinite; mix-blend-mode:overlay; }
@keyframes scan { to { transform:translateY(40px);} }

.hero-inner { max-width:var(--maxw); margin:0 auto; padding:0 26px; width:100%; flex:1;
  display:grid; grid-template-columns:1.08fr .92fr; gap:54px; align-items:center; position:relative; z-index:3; }

.eyebrow { display:inline-flex; align-items:center; gap:9px; font-family:'Oswald',sans-serif; font-size:.74rem;
  font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:var(--muted);
  padding:8px 16px; border:1px solid var(--line-2); border-radius:999px; background:rgba(255,255,255,.03); margin-bottom:28px; }
.eyebrow .dot { width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 12px var(--red); animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.35;} }

.hero-title { font-family:'Pirata One',serif; font-weight:400; font-size:clamp(3rem,8.4vw,6rem);
  line-height:.96; letter-spacing:.01em; margin-bottom:28px; }
.hero-title .line { display:block; color:var(--text); text-shadow:0 4px 40px rgba(0,0,0,.7); }
.hero-title .shine { position:relative; background:var(--grad-chrome-h); background-size:200% 100%;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; animation:chromeflow 6s linear infinite; }

.hero-sub { color:var(--muted); font-size:1.14rem; max-width:500px; margin-bottom:38px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:50px; }
.hero-stats { display:flex; gap:40px; flex-wrap:wrap; }
.hero-stats div { display:flex; flex-direction:column; }
.hero-stats strong { font-family:'Pirata One',serif; font-size:1.7rem; line-height:1;
  background:var(--grad-chrome-h); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.hero-stats span { font-family:'Oswald',sans-serif; font-size:.7rem; color:var(--faint); text-transform:uppercase; letter-spacing:.14em; margin-top:6px; }

/* Hero collage */
.hero-collage { position:relative; height:480px; display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:16px; transform-style:preserve-3d; }
.tile { position:relative; border-radius:var(--radius); border:1px solid var(--line-2); overflow:hidden;
  display:grid; place-items:center; transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  background:linear-gradient(150deg,#1b1c22,#0b0b0e); box-shadow:var(--shadow-2); will-change:transform; }
.tile::before { content:""; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 45%); }
.tile::after { content:""; position:absolute; inset:0; background:linear-gradient(110deg,transparent 40%,rgba(255,255,255,.12) 50%,transparent 60%);
  transform:translateX(-130%); transition:transform 1.1s var(--ease); }
.tile:hover::after { transform:translateX(130%); }
.tile .tile-cross { width:46%; opacity:.6; filter:drop-shadow(0 6px 14px rgba(0,0,0,.6)); }
.tile .tile-cross svg { width:100%; }
.tile-label { position:absolute; bottom:12px; left:14px; font-family:'Oswald',sans-serif; font-weight:600;
  font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--chrome); }
.t1 { background:linear-gradient(150deg,#20222b,#0c0d11); }
.t2 { background:linear-gradient(150deg,#2a1418,#0e0709); transform:translateY(22px); }
.t3 { background:linear-gradient(150deg,#262019,#0e0c08); transform:translateY(-14px); }
.t4 { background:linear-gradient(150deg,#1a2230,#0a0d12); }
.collage-seal { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) rotate(-10deg);
  width:96px; height:96px; border-radius:50%; display:grid; place-items:center; text-align:center;
  font-family:'Oswald',sans-serif; font-weight:700; font-size:.92rem; letter-spacing:.12em; line-height:1.05;
  color:#0a0a0c; background:var(--grad-chrome-h); border:2px solid #fff;
  box-shadow:0 18px 36px -12px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.7); z-index:5; animation:bob 4s ease-in-out infinite; }
@keyframes bob { 0%,100%{ transform:translate(-50%,-50%) rotate(-10deg);} 50%{ transform:translate(-50%,-58%) rotate(-10deg);} }

/* Marquee */
.marquee-wrap { margin-top:62px; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent); position:relative; z-index:3; }
.marquee { overflow:hidden; padding:16px 0; }
.marquee-track { display:flex; align-items:center; gap:30px; white-space:nowrap; width:max-content; animation:scroll 30s linear infinite; }
.marquee-track span { font-family:'Pirata One',serif; font-size:1.15rem; letter-spacing:.06em;
  background:var(--grad-chrome-h); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; opacity:.85; }
.marquee-track i { color:var(--red); font-style:normal; font-size:.9rem; }
@keyframes scroll { to { transform:translateX(-50%);} }

/* ---------- ABOUT ---------- */
.about { background:linear-gradient(180deg,#0a0a0d,#050506); }
.about-grid { display:grid; grid-template-columns:.82fr 1.18fr; gap:64px; align-items:center; }
.about-visual { position:relative; }
.about-frame { aspect-ratio:4/5; border-radius:var(--radius-lg); position:relative; overflow:hidden;
  background:radial-gradient(circle at 32% 22%, rgba(143,163,196,.22), transparent 58%), linear-gradient(160deg,#191a20,#0a0a0d);
  border:1px solid var(--line-2); display:grid; place-items:center; box-shadow:var(--shadow); }
.about-frame::before { content:""; position:absolute; inset:0; background:linear-gradient(120deg,transparent 38%,rgba(255,255,255,.08) 50%,transparent 62%); animation:shine 5.5s ease-in-out infinite; }
@keyframes shine { 0%{ transform:translateX(-120%);} 60%,100%{ transform:translateX(120%);} }
.frame-cross { width:38%; opacity:.5; filter:drop-shadow(0 8px 18px rgba(0,0,0,.6)); }
.ph-tag { position:absolute; bottom:16px; left:0; right:0; text-align:center; font-family:'Oswald',sans-serif;
  font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--faint); }
.about-badge { position:absolute; bottom:-16px; right:-12px; background:var(--grad-chrome-h); color:#0a0a0c;
  font-family:'Oswald',sans-serif; font-weight:600; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase;
  padding:11px 18px; border-radius:12px; box-shadow:0 16px 34px -12px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.6); }
.about-badge span { color:var(--red-deep); }
.about-copy p { color:var(--muted); margin-top:18px; font-size:1.07rem; }
.about-copy strong { color:var(--text); }
.about-points { display:flex; gap:24px; flex-wrap:wrap; margin-top:30px; }
.about-points span { font-family:'Oswald',sans-serif; font-weight:500; letter-spacing:.08em; text-transform:uppercase; font-size:.82rem; color:var(--chrome); }

/* ---------- CATEGORY / FIND CARDS (chrome) ---------- */
.shop { background:var(--ink); }
.cat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.cat-card { position:relative; background:linear-gradient(165deg,var(--panel-2),var(--panel)); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
  transform-style:preserve-3d; will-change:transform; }
.cat-card::before { content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:var(--grad-chrome-h); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .5s var(--ease); pointer-events:none; }
.cat-card:hover { transform:translateY(-10px); box-shadow:var(--shadow); border-color:transparent; }
.cat-card:hover::before { opacity:1; }
.cat-art { position:relative; aspect-ratio:16/10; display:grid; place-items:center; overflow:hidden;
  background:radial-gradient(circle at 50% 120%, rgba(255,255,255,.08), transparent 60%), linear-gradient(160deg,#15161b,#0a0b0e); }
.cat-art::after { content:""; position:absolute; inset:0; background:linear-gradient(110deg,transparent 42%,rgba(255,255,255,.1) 50%,transparent 58%);
  transform:translateX(-130%); transition:transform 1s var(--ease); }
.cat-card:hover .cat-art::after { transform:translateX(130%); }
.art-cross { width:34%; opacity:.62; filter:drop-shadow(0 8px 16px rgba(0,0,0,.6)); transition:transform .6s var(--ease); }
.cat-card:hover .art-cross { transform:rotate(6deg) scale(1.08); }
.cat-no { position:absolute; top:12px; right:16px; font-family:'Pirata One',serif; font-size:1.6rem; color:rgba(255,255,255,.08); }
.cat-card[data-accent="red"]  .cat-art { box-shadow:inset 0 -60px 80px -60px rgba(225,29,51,.6); }
.cat-card[data-accent="gold"] .cat-art { box-shadow:inset 0 -60px 80px -60px rgba(217,178,90,.5); }
.cat-card[data-accent="steel"].cat-card .cat-art { box-shadow:inset 0 -60px 80px -60px rgba(143,163,196,.5); }
.cat-body { padding:22px 24px 26px; }
.cat-body h3 { font-family:'Pirata One',serif; font-weight:400; font-size:1.42rem; letter-spacing:.01em; margin-bottom:8px; }
.cat-body p { color:var(--muted); font-size:.96rem; margin-bottom:16px; }
.cat-link { font-family:'Oswald',sans-serif; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  font-size:.78rem; color:var(--chrome); display:inline-flex; gap:8px; align-items:center; }
.cat-link i { color:var(--red); font-style:normal; transition:transform .3s var(--ease); }
.cat-link:hover { color:var(--text); } .cat-link:hover i { transform:translateX(5px); }

/* ---------- FEATURED FINDS ---------- */
.finds { background:linear-gradient(180deg,#050506,#0d0d11); overflow:hidden; }
.finds-glow { position:absolute; top:18%; right:-120px; width:500px; height:500px; border-radius:50%; background:rgba(225,29,51,.12); filter:blur(120px); }
.finds-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.find-card { position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line);
  background:var(--panel); transition:transform .5s var(--ease), box-shadow .5s var(--ease); transform-style:preserve-3d; will-change:transform; }
.find-card:hover { transform:translateY(-8px); box-shadow:var(--shadow); }
.find-art { position:relative; aspect-ratio:1/1; display:grid; place-items:center; overflow:hidden;
  background:radial-gradient(circle at 50% 40%, rgba(143,163,196,.16), transparent 60%), linear-gradient(150deg,#17181e,#090a0d); transition:transform .7s var(--ease); }
.find-art svg { width:42%; opacity:.5; filter:drop-shadow(0 10px 20px rgba(0,0,0,.6)); transition:transform .7s var(--ease); }
.find-card:hover .find-art svg { transform:scale(1.12) rotate(-5deg); opacity:.7; }
.find-art::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.6)); }
.find-card[data-accent="red"]  .find-art { box-shadow:inset 0 -70px 90px -60px rgba(225,29,51,.55); }
.find-card[data-accent="gold"] .find-art { box-shadow:inset 0 -70px 90px -60px rgba(217,178,90,.45); }
.find-meta { position:absolute; left:0; bottom:0; padding:18px 20px; z-index:2; }
.find-tag { display:inline-block; font-family:'Oswald',sans-serif; font-weight:600; font-size:.62rem; text-transform:uppercase;
  letter-spacing:.14em; color:#0a0a0c; background:var(--grad-chrome-h); padding:3px 10px; border-radius:6px; margin-bottom:9px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6); }
.find-meta h3 { font-family:'Pirata One',serif; font-weight:400; font-size:1.32rem; }

/* ---------- WHY ---------- */
.why { background:var(--ink-3); }
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.why-card { position:relative; background:linear-gradient(165deg,var(--panel-2),var(--panel)); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:34px 30px; overflow:hidden; transition:transform .5s var(--ease), border-color .5s var(--ease);
  transform-style:preserve-3d; will-change:transform; }
.why-card::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad-chrome-h);
  transform:scaleX(0); transform-origin:left; transition:transform .6s var(--ease); }
.why-card:hover { transform:translateY(-8px); border-color:var(--line-2); }
.why-card:hover::before { transform:scaleX(1); }
.why-num { font-family:'Pirata One',serif; font-size:2.2rem; display:block; margin-bottom:12px;
  background:var(--grad-chrome-h); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.why-card h3 { font-family:'Pirata One',serif; font-weight:400; font-size:1.3rem; margin-bottom:8px; }
.why-card p { color:var(--muted); font-size:.98rem; }

/* ---------- VISIT ---------- */
.visit { background:linear-gradient(180deg,#0d0d11,#050506); }
.visit-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.visit-list { margin:34px 0 38px; display:grid; gap:22px; }
.visit-list li { display:flex; gap:16px; align-items:flex-start; }
.visit-ico { flex:none; width:46px; height:46px; display:grid; place-items:center; border-radius:12px;
  background:linear-gradient(160deg,#17181e,#0c0d10); border:1px solid var(--line-2); color:var(--red); font-size:1.05rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06); }
.visit-list strong { font-family:'Oswald',sans-serif; font-weight:600; letter-spacing:.06em; text-transform:uppercase; font-size:.86rem; display:block; margin-bottom:3px; }
.visit-list p { color:var(--muted); font-size:.98rem; }
.visit-socials a { color:var(--chrome); font-family:'Oswald',sans-serif; font-weight:500; text-transform:uppercase; letter-spacing:.06em; font-size:.84rem; margin-right:16px; }
.visit-socials a:hover { color:var(--text); }
[data-placeholder] { font-style:italic; }
.visit-map { position:relative; }
.map-placeholder { aspect-ratio:4/3; border-radius:var(--radius-lg); border:1px solid var(--line-2); position:relative; overflow:hidden;
  display:grid; place-content:center; justify-items:center; gap:6px; text-align:center; box-shadow:var(--shadow);
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 14px,transparent 14px 28px), radial-gradient(circle at 50% 38%, rgba(225,29,51,.16), transparent 60%), linear-gradient(160deg,#15161b,#0a0b0e); }
.map-cross { width:74px; opacity:.5; }
.map-placeholder p { font-family:'Oswald',sans-serif; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-size:.86rem; }

/* ---------- CONTACT ---------- */
.contact { background:var(--ink); overflow:hidden; }
.contact-glow { position:absolute; bottom:-150px; left:8%; width:540px; height:540px; border-radius:50%; background:rgba(143,163,196,.12); filter:blur(130px); }
.contact-grid { display:grid; grid-template-columns:1fr 1.05fr; gap:58px; align-items:start; }
.contact-socials { display:flex; gap:18px; margin-top:28px; }
.contact-socials a { font-family:'Oswald',sans-serif; font-weight:500; text-transform:uppercase; letter-spacing:.08em; font-size:.86rem; color:var(--chrome); }
.contact-socials a:hover { color:var(--text); }
.contact-form { background:linear-gradient(165deg,var(--panel-2),var(--panel)); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:36px; display:grid; gap:18px; box-shadow:var(--shadow); position:relative; }
.contact-form::before { content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; background:var(--grad-chrome-h);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; opacity:.4; pointer-events:none; }
.field { display:grid; gap:7px; }
.field label { font-family:'Oswald',sans-serif; font-weight:500; letter-spacing:.06em; text-transform:uppercase; font-size:.78rem; color:var(--muted); }
.field .opt { color:var(--faint); text-transform:none; letter-spacing:0; }
.field input, .field textarea { background:rgba(0,0,0,.4); border:1px solid var(--line-2); border-radius:11px; padding:13px 16px;
  color:var(--text); font-family:inherit; font-size:1rem; transition:border-color .25s, box-shadow .25s; resize:vertical; }
.field input::placeholder, .field textarea::placeholder { color:var(--faint); }
.field input:focus, .field textarea:focus { outline:none; border-color:var(--chrome); box-shadow:0 0 0 3px rgba(196,201,211,.18); }
.form-note { font-size:.92rem; color:var(--chrome-lite); min-height:1.2em; }

/* ---------- FOOTER ---------- */
.footer { background:var(--ink-2); border-top:1px solid var(--line); padding-top:60px; position:relative; z-index:2; }
.footer-inner { display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:30px; padding-bottom:42px; }
.brand--footer { margin-bottom:16px; }
.footer-brand p { color:var(--muted); font-size:.95rem; max-width:340px; }
.footer-links, .footer-social { display:flex; flex-direction:column; gap:12px; }
.footer-links a, .footer-social a { font-family:'Oswald',sans-serif; font-weight:400; text-transform:uppercase; letter-spacing:.08em;
  font-size:.84rem; color:var(--muted); width:fit-content; transition:color .2s; }
.footer-links a:hover, .footer-social a:hover { color:var(--text); }
.footer-bottom { border-top:1px solid var(--line); padding:22px 26px; max-width:var(--maxw); margin:0 auto;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; color:var(--faint); font-size:.84rem; }
.footer-credit { color:var(--chrome); font-weight:600; }

/* ---------- Scroll reveal + stagger ---------- */
.reveal { opacity:0; transform:translateY(32px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s;} .reveal[data-d="2"]{ transition-delay:.16s;}
.reveal[data-d="3"]{ transition-delay:.24s;} .reveal[data-d="4"]{ transition-delay:.32s;} .reveal[data-d="5"]{ transition-delay:.40s;}

/* ---------- Focus ---------- */
:focus-visible { outline:2px solid var(--chrome); outline-offset:3px; border-radius:6px; }

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; gap:42px; padding-top:18px; }
  .hero-collage{ height:380px; max-width:470px; }
  .about-grid{ grid-template-columns:1fr; gap:46px; } .about-visual{ max-width:380px; }
  .visit-grid, .contact-grid{ grid-template-columns:1fr; gap:42px; }
  .cat-grid, .finds-grid, .why-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width:720px){
  .nav-toggle{ display:flex; }
  .nav-links{ position:fixed; top:0; right:0; height:100dvh; width:min(80vw,330px); flex-direction:column; align-items:stretch;
    justify-content:flex-start; gap:6px; padding:96px 22px 22px; background:rgba(7,7,9,.97); backdrop-filter:blur(18px);
    border-left:1px solid var(--line); transform:translateX(100%); transition:transform .45s var(--ease); z-index:90; }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ padding:14px 18px; font-size:.98rem; border-radius:12px; }
  .nav-links .nav-cta{ margin-left:0; margin-top:8px; text-align:center; }
  .hero{ min-height:auto; padding-top:116px; }
  .hero-stats{ gap:26px; }
  .hero-collage{ height:330px; }
  .cat-grid, .finds-grid, .why-grid{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; text-align:center; }
  .section-head{ margin-bottom:44px; }
  .contact-form{ padding:26px; }
}
@media (max-width:420px){
  .container,.nav-inner,.hero-inner{ padding-left:18px; padding-right:18px; }
  .hero-actions .btn{ width:100%; justify-content:center; }
  .brand-word{ font-size:1.3rem; }
}

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