/* ============================================================
   CHROME RONIN — ARCHIVE SYSTEM v2.0 / PAGE COMPOSITIONS
   ============================================================ */

/* ------------------------------------------------------------
   HOME / HERO — "ENTRANCE HALL"
   ------------------------------------------------------------ */
.hero {
  position: relative; min-height: 100svh;
  display: grid; align-content: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 110%, rgba(168,32,46,.10), transparent 60%),
    var(--void);
}
.hero .wrap { position: relative; z-index: 3; }
.hero-emblem {
  position: absolute; z-index: 1;
  right: 4vw; top: 50%; translate: 0 -50%;
  width: clamp(280px, 36vw, 620px);
  opacity: .9;
  filter: drop-shadow(0 60px 80px rgba(0,0,0,.8));
  will-change: transform;
}
.hero-title {
  font-size: var(--t-hero);
  position: relative; z-index: 3;
}
.hero-title .row { display: block; }
.hero-title .row:nth-child(2) { margin-left: clamp(2rem, 9vw, 11rem); }
.hero-sub { max-width: 46ch; margin-top: var(--s-3); color: var(--ash); font-size: clamp(1rem, 1.2vw, 1.15rem); }
.hero-cta { display: flex; gap: 1.2rem; margin-top: var(--s-3); flex-wrap: wrap; }
.hero-meta-l, .hero-meta-r {
  position: absolute; z-index: 3; bottom: 2rem;
  font-family: var(--f-mono); font-size: var(--t-micro);
  letter-spacing: .3em; text-transform: uppercase; color: var(--graphite);
}
.hero-meta-l { left: var(--gutter); }
.hero-meta-r { right: var(--gutter); text-align: right; }
.hero-kanji { position: absolute; z-index: 2; left: 3vw; top: 12svh; bottom: auto; height: 70svh; display: flex; }
.hero-scroll {
  position: absolute; z-index: 3; left: 50%; bottom: 1.6rem; translate: -50% 0;
  display: grid; justify-items: center; gap: .5rem;
}
.hero-scroll .line { width: 1px; height: 44px; background: var(--graphite); overflow: hidden; position: relative; }
.hero-scroll .line::after { content: ''; position: absolute; inset: 0; background: var(--crimson-hot); animation: scrollDrip 2s var(--e-slow) infinite; }
@keyframes scrollDrip { 0% { transform: translateY(-100%);} 60% { transform: translateY(0);} 100% { transform: translateY(100%);} }

/* coordinates grid backdrop */
.hero-grid {
  position: absolute; inset: 0; z-index: 0; opacity: .5;
  background-image:
    linear-gradient(rgba(232,230,225,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(232,230,225,.03) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse 90% 80% at 50% 40%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 40%, black 30%, transparent 75%);
}

/* ------------------------------------------------------------
   HOME / MANIFESTO STRIP
   ------------------------------------------------------------ */
.manifesto { background: var(--vault); border-block: 1px solid var(--hairline); }
.manifesto-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--s-4); align-items: start; }
.manifesto h2 { font-size: var(--t-h2); }
.manifesto h2 .accent { color: var(--crimson-hot); }
.manifesto p { color: var(--ash); margin-bottom: 1.4rem; max-width: 58ch; }
.manifesto .seal-row { display: flex; align-items: center; gap: 1.4rem; margin-top: var(--s-3); }
@media (max-width: 860px) { .manifesto-grid { grid-template-columns: 1fr; } }

/* ------------------------------------------------------------
   HOME / FEATURED VAULT (horizontal exhibit strip)
   ------------------------------------------------------------ */
.vault-strip { position: relative; }
.vault-rail {
  display: grid; grid-auto-flow: column;
  grid-auto-columns: clamp(260px, 26vw, 380px);
  gap: var(--s-2);
  overflow-x: auto; overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  padding-bottom: var(--s-2);
  scrollbar-width: none;
}
.vault-rail::-webkit-scrollbar { display: none; }
.vault-rail > * { scroll-snap-align: start; }
.vault-progress { height: 1px; background: var(--hairline); position: relative; margin-top: var(--s-2); }
.vault-progress i { position: absolute; left: 0; top: 0; bottom: 0; width: 20%; background: var(--crimson-hot); transition: transform .2s linear, width .2s; }

/* ------------------------------------------------------------
   HOME / RESEARCH DIVISIONS (categories)
   ------------------------------------------------------------ */
.division {
  position: relative; display: grid; grid-template-columns: auto 1fr auto auto auto;
  align-items: center; gap: var(--s-3);
  padding: 2.4rem 1rem;
  border-bottom: 1px solid var(--hairline);
  transition: background .4s var(--e-out), padding-left .4s var(--e-out);
}
.division:first-of-type { border-top: 1px solid var(--hairline); }
.division:hover { background: var(--vault); padding-left: 2rem; }
.division .d-idx { font-family: var(--f-mono); font-size: var(--t-meta); color: var(--crimson-hot); letter-spacing: .2em; }
.division .d-name { font-family: var(--f-display); font-size: clamp(1.8rem, 4.6vw, 4rem); text-transform: uppercase; line-height: 1; transition: letter-spacing .4s var(--e-out); }
.division:hover .d-name { letter-spacing: .04em; }
.division .d-jp { font-family: var(--f-jp); color: var(--graphite); font-size: 1.1rem; }
.division .d-count { font-family: var(--f-mono); font-size: var(--t-meta); color: var(--ash); letter-spacing: .2em; }
.division .d-arrow { font-family: var(--f-mono); color: var(--graphite); transition: transform .4s var(--e-out), color .4s; }
.division:hover .d-arrow { transform: translateX(8px); color: var(--crimson-hot); }
@media (max-width: 700px) {
  .division { grid-template-columns: auto 1fr auto; }
  .division .d-jp { display: none; }
}

/* ------------------------------------------------------------
   ARCHIVE (apparel index)
   ------------------------------------------------------------ */
.archive-head { padding-top: calc(var(--s-6) + 3rem); padding-bottom: var(--s-4); }
.archive-title { font-size: var(--t-h1); }
.archive-sub { display: flex; justify-content: space-between; align-items: flex-end; gap: var(--s-2); flex-wrap: wrap; margin-top: var(--s-3); }
.filterbar { display: flex; gap: .6rem; flex-wrap: wrap; }
.filterbar button {
  font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .18em;
  text-transform: uppercase; color: var(--ash);
  border: 1px solid var(--hairline); padding: .55rem 1.1rem;
  transition: all .3s var(--e-out);
}
.filterbar button:hover { color: var(--bone); border-color: var(--hairline-strong); }
.filterbar button.on { color: var(--bone); border-color: var(--crimson); background: rgba(168,32,46,.12); }
.archive-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-2);
}
.archive-grid .artifact.is-hidden { display: none; }
@media (max-width: 1080px) { .archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px)  { .archive-grid { grid-template-columns: 1fr; } }

/* ------------------------------------------------------------
   ARTIFACT DETAIL (dossier)
   ------------------------------------------------------------ */
.dossier { padding-top: calc(var(--s-5) + 3rem); }
.dossier-crumb { margin-bottom: var(--s-3); display: flex; gap: 1rem; align-items: center; }
.dossier-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: var(--s-4); align-items: start; }
.dossier-stage {
  position: sticky; top: 6rem;
  aspect-ratio: 4/4.4;
  display: grid; place-items: center;
  background:
    radial-gradient(ellipse 70% 55% at 50% 40%, rgba(200,204,210,.08), transparent 70%),
    linear-gradient(var(--vault), var(--concrete));
  border: 1px solid var(--hairline);
  overflow: hidden;
}
.dossier-stage svg.mark { width: 56%; filter: drop-shadow(0 40px 60px rgba(0,0,0,.75)); }
.dossier-stage .stage-meta { position: absolute; bottom: 1rem; left: 1.2rem; right: 1.2rem; display: flex; justify-content: space-between; }
.dossier-head h1 { font-size: clamp(2.6rem, 5.5vw, 5rem); }
.dossier-head .ed-line { display: flex; gap: 1.4rem; align-items: center; margin-top: 1.2rem; flex-wrap: wrap; }
.dossier-price { font-family: var(--f-mono); font-size: 1.3rem; color: var(--bone); letter-spacing: .1em; margin-top: var(--s-2); }
.dossier-desc { color: var(--ash); margin-top: var(--s-2); max-width: 55ch; }

.spec-table { margin-top: var(--s-3); border-top: 1px solid var(--hairline); }
.spec-row { display: grid; grid-template-columns: 1fr 1.6fr; gap: 1rem; padding: .8rem 0; border-bottom: 1px solid var(--hairline); }
.spec-row dt { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .28em; text-transform: uppercase; color: var(--graphite); padding-top: .2em; }
.spec-row dd { font-size: .92rem; color: var(--ash); }

.size-row { display: flex; gap: .6rem; margin-top: 1rem; flex-wrap: wrap; }
.size-row button {
  min-width: 3rem; padding: .7rem .8rem;
  font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .1em;
  border: 1px solid var(--hairline); color: var(--ash);
  transition: all .25s var(--e-out);
}
.size-row button:hover { border-color: var(--hairline-strong); color: var(--bone); }
.size-row button.on { border-color: var(--crimson); color: var(--bone); background: rgba(168,32,46,.14); }
.dossier-actions { display: grid; gap: .8rem; margin-top: var(--s-3); }
.dossier-actions .btn { justify-content: center; width: 100%; }
.archive-note {
  margin-top: var(--s-3); padding: 1.4rem;
  background: var(--vault); border: 1px solid var(--hairline);
  border-left: 3px solid var(--crimson);
}
.archive-note .t-micro { display: block; margin-bottom: .6rem; }
.archive-note p { font-size: .9rem; color: var(--ash); }
@media (max-width: 940px) {
  .dossier-grid { grid-template-columns: 1fr; }
  .dossier-stage { position: relative; top: 0; }
}

/* related rail */
.related { margin-top: var(--s-6); }

/* ------------------------------------------------------------
   ABOUT (research division)
   ------------------------------------------------------------ */
.about-hero { padding-top: calc(var(--s-6) + 3rem); position: relative; overflow: hidden; }
.about-hero h1 { font-size: var(--t-h1); max-width: 12ch; }
.about-hero .lede { max-width: 52ch; color: var(--ash); margin-top: var(--s-3); font-size: 1.1rem; }

.timeline { position: relative; margin-top: var(--s-4); }
.timeline::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 1px; background: var(--hairline-strong); }
.tl-item { position: relative; padding: 0 0 var(--s-4) var(--s-4); }
.tl-item::before {
  content: ''; position: absolute; left: -4px; top: .4rem;
  width: 9px; height: 9px; background: var(--void);
  border: 1px solid var(--crimson-hot); transform: rotate(45deg);
}
.tl-item .t-meta { color: var(--crimson-hot); display: block; margin-bottom: .6rem; }
.tl-item h3 { font-family: var(--f-display); text-transform: uppercase; font-size: 1.5rem; margin-bottom: .6rem; }
.tl-item p { color: var(--ash); max-width: 55ch; font-size: .95rem; }

.material-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-2); margin-top: var(--s-4); }
.material-card { border: 1px solid var(--hairline); background: var(--vault); padding: 1.6rem; position: relative; overflow: hidden; }
.material-card .swatch { height: 120px; margin-bottom: 1.2rem; position: relative; overflow: hidden; }
.material-card h3 { font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .25em; text-transform: uppercase; margin-bottom: .6rem; }
.material-card p { font-size: .85rem; color: var(--ash); }
.sw-1 { background: repeating-linear-gradient(45deg, #1a1a1e 0 6px, #141418 6px 12px); }
.sw-2 { background: linear-gradient(160deg, #2c2c31, #17171a 60%), repeating-linear-gradient(90deg, transparent 0 3px, rgba(201,204,209,.06) 3px 4px); }
.sw-3 { background: radial-gradient(circle at 30% 30%, rgba(201,204,209,.25), transparent 40%), linear-gradient(200deg, #26262b, #101013); }
@media (max-width: 860px) { .material-grid { grid-template-columns: 1fr; } }

/* ------------------------------------------------------------
   CONTACT (transmission)
   ------------------------------------------------------------ */
.contact-wrap { padding-top: calc(var(--s-6) + 3rem); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); align-items: start; }
.contact-grid h1 { font-size: clamp(2.6rem, 6vw, 5.5rem); }
.contact-form { display: grid; gap: var(--s-3); margin-top: var(--s-2); }
.coord-map {
  margin-top: var(--s-3);
  border: 1px solid var(--hairline);
  background: var(--vault);
  aspect-ratio: 16/9; position: relative; overflow: hidden;
}
.coord-map svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.contact-meta { display: grid; gap: 1.6rem; margin-top: var(--s-3); }
.contact-meta .cm-row { display: grid; gap: .3rem; }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }

/* ------------------------------------------------------------
   CART (holding vault)
   ------------------------------------------------------------ */
.cart-wrap { padding-top: calc(var(--s-6) + 3rem); min-height: 70vh; }
.cart-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--s-4); align-items: start; }
.cart-line {
  display: grid; grid-template-columns: 90px 1fr auto; gap: 1.4rem; align-items: center;
  padding: 1.4rem 0; border-bottom: 1px solid var(--hairline);
}
.cart-line .thumb {
  width: 90px; height: 104px; display: grid; place-items: center;
  background: linear-gradient(var(--vault), var(--concrete));
  border: 1px solid var(--hairline);
}
.cart-line .thumb svg { width: 60%; }
.cart-line h3 { font-family: var(--f-display); font-size: 1.05rem; text-transform: uppercase; letter-spacing: .05em; }
.cart-line .line-meta { display: flex; gap: 1.2rem; margin-top: .4rem; flex-wrap: wrap; }
.qty { display: inline-flex; align-items: center; border: 1px solid var(--hairline); margin-top: .8rem; }
.qty button { padding: .35rem .8rem; font-family: var(--f-mono); color: var(--ash); transition: color .2s; }
.qty button:hover { color: var(--crimson-hot); }
.qty span { padding: 0 .6rem; font-family: var(--f-mono); font-size: var(--t-meta); }
.cart-line .rm { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .2em; color: var(--graphite); text-transform: uppercase; transition: color .2s; }
.cart-line .rm:hover { color: var(--crimson-hot); }
.cart-line .line-price { font-family: var(--f-mono); font-size: var(--t-meta); color: var(--bone); }

.cart-summary { border: 1px solid var(--hairline); background: var(--vault); padding: var(--s-3); position: sticky; top: 6rem; }
.cart-summary .sum-row { display: flex; justify-content: space-between; padding: .7rem 0; border-bottom: 1px solid var(--hairline); font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .15em; text-transform: uppercase; color: var(--ash); }
.cart-summary .sum-row.total { color: var(--bone); font-size: .85rem; border-bottom: 0; padding-top: 1.2rem; }
.cart-summary .btn { width: 100%; justify-content: center; margin-top: var(--s-2); }
.cart-empty { text-align: center; padding: var(--s-5) 0; }
.cart-empty .t-jp { font-size: 4rem; color: var(--graphite); display: block; margin-bottom: var(--s-2); }
@media (max-width: 900px) { .cart-grid { grid-template-columns: 1fr; } .cart-summary { position: relative; top: 0; } }

/* ------------------------------------------------------------
   MARKS GALLERY (about / home)
   ------------------------------------------------------------ */
.marks-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-2); }
.mark-card {
  border: 1px solid var(--hairline); background: var(--vault);
  aspect-ratio: 1; display: grid; place-items: center; position: relative;
  overflow: hidden;
  transition: border-color .4s;
}
.mark-card:hover { border-color: var(--hairline-strong); }
.mark-card svg { width: 46%; transition: transform .7s var(--e-slow); }
.mark-card:hover svg { transform: scale(1.08) rotate(-2deg); }
.mark-card .mk-label { position: absolute; bottom: 1rem; left: 1.2rem; }
.mark-card .mk-idx { position: absolute; top: 1rem; right: 1.2rem; font-family: var(--f-mono); font-size: var(--t-micro); color: var(--graphite); letter-spacing: .3em; }
@media (max-width: 700px) { .marks-grid { grid-template-columns: 1fr; } }

/* ------------------------------------------------------------
   ACCESS / WAITLIST BLOCK
   ------------------------------------------------------------ */
.access {
  position: relative; overflow: hidden;
  background: var(--vault); border-block: 1px solid var(--hairline);
}
.access-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: var(--s-4); align-items: center; }
.access h2 { font-size: var(--t-h2); }
.access form { display: grid; gap: 1.4rem; }
.access .form-row { display: flex; gap: 1rem; align-items: flex-end; }
.access .form-row .field { flex: 1; }
.access-ok { display: none; font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .2em; color: var(--crimson-hot); text-transform: uppercase; }
.access.done form { display: none; }
.access.done .access-ok { display: block; }
@media (max-width: 860px) { .access-grid { grid-template-columns: 1fr; } .access .form-row { flex-direction: column; align-items: stretch; } }

/* ------------------------------------------------------------
   V3 — VIDEO HERO
   ------------------------------------------------------------ */
.hero-video-wrap { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-video {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
  opacity: .38; filter: saturate(.55) contrast(1.1) brightness(.7);
}
.hero-video-scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(10,10,10,.92) 0%, rgba(10,10,10,.55) 45%, rgba(10,10,10,.35) 100%),
    linear-gradient(180deg, rgba(10,10,10,.6) 0%, transparent 30%, transparent 60%, var(--void) 98%);
}
.hero-canvas {
  position: absolute; z-index: 2;
  right: 0; top: 0; width: min(48vw, 760px); height: 100%;
  display: block;
}
.hero-emblem-fallback {
  display: none;
  position: absolute; z-index: 2; right: 4vw; top: 50%; translate: 0 -50%;
  width: clamp(280px, 36vw, 620px);
}
@media (max-width: 860px) {
  .hero-canvas { width: 100vw; opacity: .5; }
}
/* ------------------------------------------------------------
   THE RELIC — real chrome-hannya mask
   ------------------------------------------------------------ */
.hero-relic {
  position: absolute; z-index: 2;
  right: clamp(-4vw, 2vw, 6vw); top: 50%; translate: 0 -50%;
  width: clamp(300px, 42vw, 720px);
  height: auto; pointer-events: none;
  filter:
    drop-shadow(0 0 60px rgba(225,29,42,.28))
    drop-shadow(0 30px 70px rgba(0,0,0,.75))
    contrast(1.05) saturate(1.05);
  animation: relicFloat 7s var(--e-slow, ease-in-out) infinite;
}
@keyframes relicFloat {
  0%,100% { transform: translateY(-1.2%) rotate(-.4deg); }
  50%     { transform: translateY(1.2%)  rotate(.4deg); }
}
.hero-relic::selection { background: transparent; }
@media (max-width: 860px) {
  .hero-relic {
    right: 50%; translate: 50% -50%; top: 42%;
    width: min(86vw, 460px); opacity: .32; z-index: 1;
  }
}
@media (prefers-reduced-motion: reduce) { .hero-relic { animation: none; } }

/* mask plates now hold the real PNG */
.mark-plate img { width: min(100%, 400px); height: auto;
  filter: drop-shadow(0 20px 44px rgba(0,0,0,.28)); }
.craft-mark img { width: min(100%, 380px); height: auto;
  filter: drop-shadow(0 0 46px rgba(225,29,42,.22)) drop-shadow(0 24px 50px rgba(0,0,0,.7)); }

.footage { position: relative; }
.footage-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--s-4); align-items: center; }
.monitor {
  position: relative; border: 1px solid var(--hairline-strong);
  background: #000; aspect-ratio: 16/9; overflow: hidden;
}
.monitor video { width: 100%; height: 100%; object-fit: cover; opacity: .8; filter: saturate(.7) contrast(1.15); }
.monitor::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: repeating-linear-gradient(0deg, transparent 0 2px, rgba(0,0,0,.18) 2px 3px);
}
.monitor .rec {
  position: absolute; top: .9rem; left: 1rem; display: flex; gap: .5rem; align-items: center;
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .3em; color: var(--bone);
}
.monitor .rec i { width: 9px; height: 9px; border-radius: 50%; background: var(--crimson-hot); animation: recBlink 1.4s steps(2) infinite; }
@keyframes recBlink { 50% { opacity: .15; } }
.monitor .mon-meta { position: absolute; bottom: .9rem; left: 1rem; right: 1rem; display: flex; justify-content: space-between; }
@media (max-width: 900px) { .footage-grid { grid-template-columns: 1fr; } }
.mark-card--paper { background: var(--paper); border-color: rgba(16,16,20,.2); }
.mark-card--paper svg { width: 62%; }
.mark-card--paper .mk-label { color: #33322e; font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .25em; }
.mark-card--paper .mk-idx { color: rgba(16,16,20,.45); }
.mark-card--paper:hover { border-color: var(--crimson); }
.drop-popup { position: fixed; inset: 0; z-index: 5500; display: grid; place-items: center; padding: 1.5rem; opacity: 0; pointer-events: none; transition: opacity .45s var(--e-out); }
.drop-popup.on { opacity: 1; pointer-events: auto; }
.dp-backdrop { position: absolute; inset: 0; background: rgba(6,6,8,.78); backdrop-filter: blur(6px); }
.dp-card {
  position: relative; width: min(560px, 100%);
  background: var(--vault); border: 1px solid var(--hairline-strong);
  border-top: 3px solid var(--crimson);
  padding: 2.4rem;
  transform: translateY(28px) scale(.97);
  transition: transform .5s var(--e-out);
  box-shadow: 0 40px 90px rgba(0,0,0,.7);
}
.drop-popup.on .dp-card { transform: none; }
.dp-x {
  position: absolute; top: .7rem; right: .9rem;
  font-size: 1.6rem; color: var(--graphite); line-height: 1; padding: .3rem .5rem;
  transition: color .25s;
}
.dp-x:hover { color: var(--crimson-hot); }
.dp-head { display: flex; gap: 1.2rem; align-items: center; margin-bottom: 1.2rem; }
.dp-head .dp-kanji { font-family: var(--f-jp); font-size: 3rem; color: var(--crimson); line-height: 1; }
.dp-head h3 { font-size: clamp(1.4rem, 3vw, 2rem); margin-top: .3rem; }
.dp-card p { color: var(--ash); font-size: .92rem; margin-bottom: 1.6rem; }
.dp-row { display: flex; gap: .8rem; margin-bottom: 1rem; }
.dp-row input {
  flex: 1; background: transparent; border: 0; border-bottom: 1px solid var(--hairline-strong);
  color: var(--bone); font-family: var(--f-body); font-size: 1rem; padding: .7rem 0; border-radius: 0;
}
.dp-row input:focus { outline: none; border-color: var(--crimson-hot); }
.dp-ok { font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .2em; color: var(--crimson-hot); text-transform: uppercase; margin-bottom: 1rem; }
@media (max-width: 560px) { .dp-row { flex-direction: column; } }
.wm-kanji {
  position: absolute; right: -2%; bottom: -12%;
  font-family: var(--f-jp); font-size: clamp(14rem, 30vw, 30rem);
  color: rgba(232,230,225,.025);
  user-select: none; pointer-events: none; line-height: 1;
}
/* V3 — RAIN FALLBACK + SIGNAL LOST */
.hero-rain { position: absolute; inset: 0; width: 100%; height: 100%; display: none; }
.hero-rain.on { display: block; }
.mon-lost {
  position: absolute; inset: 0; z-index: 2;
  display: grid; place-items: center;
  background:
    repeating-linear-gradient(0deg, rgba(232,230,225,.04) 0 1px, transparent 1px 3px),
    linear-gradient(#0c0c0e, #131316);
}
.mon-lost span {
  font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .3em;
  color: var(--ash); text-transform: uppercase;
  animation: flick 3s linear infinite;
}
/* ============ V4 — ART DIRECTION PASS ============ */
/* one deliberate overlap, controlled */
.hero-title { line-height: .96; }
.hero-title .row2 { display: block; margin-top: -.14em; margin-left: clamp(2.4rem, 10vw, 12rem); }
/* quiet the interface */
.scanlines { display: none !important; }
.artifact .xh { display: none; }
.artifact-stage svg.mark { width: 78%; }
.artifact-stage { aspect-ratio: 4/4.1; }
/* atmospheric figure */
.manifesto-grid--photo { grid-template-columns: .9fr 1.1fr; align-items: center; }
.atmos { position: relative; border: 1px solid var(--hairline); overflow: hidden; aspect-ratio: 4/5; background: var(--concrete); }
.atmos img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.6) contrast(1.08) brightness(.82); transition: transform 1.2s var(--e-slow); }
.atmos:hover img { transform: scale(1.03); }
.atmos figcaption { position: absolute; bottom: .9rem; left: 1rem; color: var(--bone); }
.atmos--lost img { display: none; }
.atmos--lost::before { content: '鬼'; position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--f-jp); font-size: 8rem; color: rgba(232,230,225,.06); }
@media (max-width: 860px) { .manifesto-grid--photo { grid-template-columns: 1fr; } }
/* drop grid — products loud */
.drop-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; gap: var(--s-2); }
.drop-grid .editorial-tile { grid-row: span 2; }
.drop-grid .artifact { display: flex; flex-direction: column; }
.drop-grid .artifact .artifact-stage { flex: 1; aspect-ratio: auto; min-height: 300px; }
.editorial-tile { position: relative; border: 1px solid var(--hairline); overflow: hidden; background: var(--concrete); margin: 0; }
.editorial-tile img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.55) contrast(1.1) brightness(.8); transition: transform 1.2s var(--e-slow); }
.editorial-tile:hover img { transform: scale(1.04); }
.editorial-tile figcaption { position: absolute; bottom: 1rem; left: 1.2rem; right: 1.2rem; display: flex; justify-content: space-between; gap: 1rem; }
.ed--lost img { display: none; }
.ed--lost::before { content: 'FIELD PLATE WITHHELD — 非公開'; position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--f-mono); font-size: .65rem; letter-spacing: .3em; color: var(--graphite); }
@media (max-width: 1080px) { .drop-grid { grid-template-columns: repeat(2, 1fr); } .drop-grid .editorial-tile { grid-row: span 1; aspect-ratio: 4/5; } }
@media (max-width: 620px) { .drop-grid { grid-template-columns: 1fr; } }
/* full-bleed footage */
.footage--bleed { padding: 0; border-block: 1px solid var(--hairline); }
.monitor--bleed { border: 0; aspect-ratio: 21/9; max-height: 82vh; width: 100%; }
.monitor--bleed .poster { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.6) contrast(1.12) brightness(.75); }
.monitor--bleed video { position: absolute; inset: 0; z-index: 1; }
.monitor--bleed .mon-lost { background: transparent; }
.monitor--bleed .mon-lost span { background: rgba(10,10,10,.65); padding: .5rem 1rem; border: 1px solid var(--hairline-strong); }
.monitor--bleed .rec, .monitor--bleed .mon-meta { z-index: 3; }
.monitor--bleed .rec { top: 1.4rem; left: var(--gutter); }
.monitor--bleed .mon-meta { bottom: 1.4rem; left: var(--gutter); right: var(--gutter); }
@media (max-width: 700px) { .monitor--bleed { aspect-ratio: 4/5; } }
/* archive route rail */
.route {
  position: fixed; right: 1.6rem; top: 50%; transform: translateY(-50%);
  z-index: 1200; display: grid; gap: 1.1rem; align-items: center;
}
.route-line { position: absolute; left: -.9rem; top: 0; bottom: 0; width: 1px; background: var(--hairline); }
.route-line i { position: absolute; top: 0; left: 0; width: 100%; height: 0%; background: var(--crimson-hot); transition: height .2s linear; }
.route-stop { display: flex; align-items: center; gap: .6rem; opacity: .45; transition: opacity .3s; }
.route-stop.on { opacity: 1; }
.route-stop b { font-family: var(--f-mono); font-weight: 400; font-size: var(--t-micro); letter-spacing: .2em; color: var(--ash); }
.route-stop.on b { color: var(--crimson-hot); }
.route-stop em { font-family: var(--f-mono); font-style: normal; font-size: var(--t-micro); letter-spacing: .2em; color: var(--graphite); text-transform: uppercase; max-width: 0; overflow: hidden; white-space: nowrap; transition: max-width .4s var(--e-out); }
.route-stop.on em, .route:hover .route-stop em { max-width: 140px; }
/* ============ V13 — EDITORIAL RESET ============ */
/* statement typography: grotesk with tension, Anton = wordmark only */
.t-state {
  font-family: var(--f-body); font-weight: 600;
  font-size: clamp(1.9rem, 4.2vw, 3.6rem);
  line-height: 1.06; letter-spacing: -0.02em;
  color: var(--ink);
}
.t-state--bone { color: var(--bone); }
/* hero v13: single wordmark + statement */
.hero--v13 .hero-word { font-size: clamp(3rem, 8.4vw, 8rem); line-height: .95; }
.hero--v13 .hero-state {
  font-family: var(--f-body); font-weight: 500;
  font-size: clamp(1.1rem, 1.8vw, 1.5rem); line-height: 1.4;
  color: var(--bone); margin-top: var(--s-3); max-width: 42ch;
}
.hero--v13 .hero-meta-l { bottom: 1.6rem; }
/* paper sections */
.section--paper { background: var(--paper); color: var(--ink); }
.section--paper-deep { background: #DEDBD2; border-top: 1px solid rgba(16,16,20,.12); }
.p-meta { font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .22em; text-transform: uppercase; color: #8E1B26; margin-bottom: 1.6rem; }
.p-body { color: #45443f; margin-top: 1.8rem; max-width: 54ch; font-size: 1.05rem; }
.p-micro { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .25em; text-transform: uppercase; color: #7a786f; }
.link-line--ink { color: var(--ink); }
.statement-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--s-5); align-items: center; }
.mark-plate { margin: 0; display: grid; gap: 1rem; justify-items: center; }
.mark-plate svg { width: min(100%, 380px); }
@media (max-width: 900px) { .statement-grid { grid-template-columns: 1fr; } }
/* plate grid: big illustrated products */
.plate-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1rem, 2.5vw, 2.4rem); margin-top: var(--s-4); }
.plate-card {
  position: relative; display: block;
  background: var(--paper);
  border: 1px solid rgba(16,16,20,.25);
  padding: clamp(1.2rem, 2.4vw, 2.2rem);
  transition: border-color .3s, box-shadow .4s var(--e-out);
}
.plate-card:hover { border-color: #8E1B26; box-shadow: 0 24px 60px rgba(16,16,20,.18); }
.plate-card svg.plate { width: 100%; height: auto; }
.plate-card .pl-row { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; margin-top: 1rem; border-top: 1px solid rgba(16,16,20,.16); padding-top: 1rem; }
.plate-card h3 { font-family: var(--f-body); font-weight: 600; font-size: clamp(1.1rem, 1.8vw, 1.5rem); letter-spacing: -.01em; color: var(--ink); }
.plate-card .pl-price { font-family: var(--f-mono); font-size: .85rem; color: #45443f; }
.plate-card .pl-ed { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .22em; text-transform: uppercase; color: #8E1B26; margin-top: .35rem; }
.plate-card .pl-no {
  position: absolute; top: 1rem; right: 1.2rem;
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .2em; color: #7a786f;
}
@media (max-width: 720px) { .plate-grid { grid-template-columns: 1fr; } }
.drop-head { max-width: 60ch; }
.drop-foot { margin-top: var(--s-3); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.field-still { position: relative; border-block: 1px solid var(--hairline); background: var(--void); }
.field-still img { width: 100%; max-height: 88vh; object-fit: cover; display: block; filter: saturate(.65) contrast(1.08) brightness(.85); }
.field-still .field-cap { position: absolute; bottom: 1.4rem; left: var(--gutter); right: var(--gutter); display: flex; justify-content: space-between; gap: 1rem; }
.craft-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: var(--s-5); align-items: center; }
.craft-mark svg { width: min(100%, 360px); filter: invert(.92) hue-rotate(180deg); }
@media (max-width: 900px) { .craft-grid { grid-template-columns: 1fr; } }
.route { display: none !important; }
/* ============================================================
   CURSED LOOKBOOK — neo-Tokyo photography + CRT / glitch  (v2)
   ============================================================ */
.lb-hero{position:relative;height:min(88svh,780px);overflow:hidden;display:grid;align-content:end;isolation:isolate;background:var(--void)}
.lb-hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.lb-hero-media video,.lb-hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.42;filter:saturate(.5) contrast(1.14) brightness(.5)}
.lb-hero-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.78) 0%,rgba(10,10,10,.32) 34%,rgba(10,10,10,.5) 62%,var(--void) 97%),radial-gradient(120% 80% at 12% 105%,rgba(176,21,34,.22),transparent 58%)}
.lb-hero .wrap{position:relative;z-index:3;padding-bottom:clamp(2rem,6vw,5rem)}
.lb-title{font-family:var(--f-display);text-transform:uppercase;font-size:clamp(2.6rem,9vw,8.5rem);line-height:.84;color:var(--bone);letter-spacing:-.01em;margin:.4rem 0;text-shadow:0 6px 40px rgba(0,0,0,.7)}
.lb-title .rd{color:var(--crimson-hot)}
.crt{position:relative}
.crt::before{content:'';position:absolute;inset:0;z-index:4;pointer-events:none;background:repeating-linear-gradient(180deg,rgba(0,0,0,0) 0 2px,rgba(0,0,0,.22) 2px 3px);mix-blend-mode:multiply;opacity:.55}
.warnbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;font-family:var(--f-mono);font-size:var(--t-micro);letter-spacing:.3em;text-transform:uppercase;color:var(--bone);padding:.7rem 0;border-block:1px solid var(--hairline)}
.warnbar .hz{height:14px;flex:1 1 120px;min-width:90px;background:repeating-linear-gradient(45deg,var(--crimson) 0 10px,#0a0a0a 10px 20px);opacity:.8}
.warnbar b{color:var(--crimson-hot);font-weight:400}
.kata-col{position:absolute;z-index:2;top:8%;bottom:8%;writing-mode:vertical-rl;font-family:var(--f-jp);font-weight:700;font-size:clamp(1rem,1.4vw,1.4rem);letter-spacing:.35em;color:rgba(232,230,225,.14);user-select:none;pointer-events:none}
.kata-col.left{left:clamp(.6rem,2vw,2rem)}
.kata-col.right{right:clamp(.6rem,2vw,2rem);color:rgba(176,21,34,.22)}
.lookbook{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(.6rem,1.4vw,1.1rem);margin-top:var(--s-3)}
.lb-plate{position:relative;overflow:hidden;background:#0d0d0f;border:1px solid var(--hairline)}
.lb-plate img,.lb-plate video{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.55) contrast(1.14) brightness(.72);transition:transform .9s var(--e-out),filter .6s}
.lb-plate:hover img,.lb-plate:hover video{transform:scale(1.05);filter:saturate(.7) contrast(1.16) brightness(.82)}
.lb-plate .lb-tag{position:absolute;left:.9rem;bottom:.8rem;z-index:6;font-family:var(--f-mono);font-size:var(--t-micro);letter-spacing:.24em;text-transform:uppercase;color:var(--bone);background:rgba(10,10,10,.55);padding:.3rem .6rem;backdrop-filter:blur(3px)}
.lb-plate .lb-no{position:absolute;right:.9rem;top:.8rem;z-index:6;font-family:var(--f-mono);font-size:var(--t-micro);letter-spacing:.2em;color:var(--crimson-hot)}
.col-7{grid-column:span 7}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-4{grid-column:span 4}.col-8{grid-column:span 8}.col-12{grid-column:span 12}
.tall{height:clamp(340px,42vw,560px)}.mid{height:clamp(240px,26vw,360px)}
@media(max-width:820px){.lookbook{grid-template-columns:repeat(6,1fr)}.col-7,.col-5,.col-6,.col-4,.col-8{grid-column:span 6}.tall,.mid{height:clamp(240px,60vw,360px)}}
.txmit{position:relative;overflow:hidden}
.txmit-bg{position:absolute;inset:0;z-index:0}
.txmit-bg img,.txmit-bg video{width:100%;height:100%;object-fit:cover;opacity:.28;filter:saturate(.45) contrast(1.15) brightness(.5)}
.txmit-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--void) 6%,rgba(10,10,10,.74) 55%,rgba(10,10,10,.5) 100%),radial-gradient(90% 70% at 100% 0,rgba(176,21,34,.16),transparent 55%)}
.txmit .wrap{position:relative;z-index:3}

/* ============================================================
   PRINTS — full-bleed campaign gallery (artwork by studio)
   ============================================================ */
.prints-hero{position:relative;height:min(90svh,860px);overflow:hidden;display:grid;align-content:end;isolation:isolate;background:#080809}
.prints-hero .pf{position:absolute;inset:0;z-index:0;background:#0b0b0d center/cover no-repeat}
.prints-hero .pf::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,8,9,.7) 0%,rgba(8,8,9,.15) 40%,rgba(8,8,9,.55) 72%,#080809 98%),radial-gradient(110% 80% at 90% 10%,rgba(176,21,34,.22),transparent 55%)}
.prints-hero .wrap{position:relative;z-index:3;padding-bottom:clamp(2rem,6vw,5rem)}
.prints-title{font-family:var(--f-display);text-transform:uppercase;font-size:clamp(2.6rem,10vw,9rem);line-height:.84;color:var(--bone);letter-spacing:-.01em;text-shadow:0 6px 40px rgba(0,0,0,.7)}
.prints-title .rd{color:var(--crimson-hot)}
.print-row{position:relative;overflow:hidden;border-bottom:1px solid var(--hairline);background:#0a0a0b}
.print-figure{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;
  background:repeating-linear-gradient(45deg,#0e0e10 0 22px,#0b0b0d 22px 44px)}
.print-figure img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.9) contrast(1.06) brightness(.94);transition:transform 1.1s var(--e-out)}
.print-row:hover .print-figure img{transform:scale(1.04)}
.print-figure.await::before{content:'AWAITING TRANSMISSION — 受信待ち';position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--f-mono);font-size:var(--t-meta);letter-spacing:.3em;color:rgba(232,230,225,.32);text-transform:uppercase}
.print-cap{position:absolute;left:0;right:0;bottom:0;z-index:4;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;
  padding:clamp(1rem,3vw,2.4rem);background:linear-gradient(0deg,rgba(8,8,9,.86),transparent)}
.print-cap h3{font-family:var(--f-display);text-transform:uppercase;font-size:clamp(1.4rem,3.4vw,2.8rem);color:var(--bone);line-height:.95}
.print-cap .pmeta{font-family:var(--f-mono);font-size:var(--t-micro);letter-spacing:.24em;text-transform:uppercase;color:var(--crimson-hot);text-align:right;white-space:nowrap}

/* product card photo */
.plate-card .pl-shot{aspect-ratio:4/5;overflow:hidden;background:var(--paper);display:grid;place-items:center}
.plate-card .pl-shot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--e-out)}
.plate-card:hover .pl-shot img{transform:scale(1.04)}

/* portrait campaign print — show whole image, matted dark */
.print-figure.portrait{aspect-ratio:auto;height:min(94svh,980px);background:#080809}
.print-figure.portrait img{object-fit:contain}
