/* ===========================================================
   mujun.work — Editorial honeycomb of contradictions
   Palette: cosmic teal / atomic orange / nebula violet /
            signal pink / star cream / deep space / honeycomb gold
   =========================================================== */

:root {
  --c-violet:   #6B3A8A;
  --c-pink:     #E84878;
  --c-deep:     #0D1A2E;
  --c-orange:   #E87830;
  --c-gold:     #D4B050;
  --c-teal:     #1A5C5A;
  --c-cream:    #FAF5E8;

  --hex-clip: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);

  --font-display: "Poiret One", "Nunito Sans", system-ui, sans-serif;
  --font-body: "Nunito Sans", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--c-deep);
  color: var(--c-cream);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.75;
  font-size: clamp(14px, 1vw, 16px);
  overflow-x: hidden;
  scroll-behavior: smooth;
}

img, svg { display: block; max-width: 100%; }

/* ============== OPENING HIVE ============== */
.hive {
  position: relative;
  min-height: 100vh;
  width: 100%;
  display: grid;
  place-items: center;
  background: radial-gradient(ellipse at center, #11203a 0%, var(--c-deep) 65%);
  overflow: hidden;
  padding: 4rem 1rem;
}

.hive-network {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.hive-network .net-edges path {
  stroke-dasharray: 400;
  stroke-dashoffset: 400;
  animation: draw-line 1800ms ease-out forwards;
  animation-delay: 1400ms;
}

@keyframes draw-line {
  to { stroke-dashoffset: 0; }
}

.honeycomb {
  position: relative;
  width: min(880px, 92vw);
  height: min(640px, 80vh);
  z-index: 2;
  animation: hive-settle 600ms ease-out 2000ms both;
  transform-origin: center;
}

@keyframes hive-settle {
  from { transform: rotate(0deg); }
  to   { transform: rotate(0.5deg); }
}

.hex {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 180px;
  height: 208px;
  clip-path: var(--hex-clip);
  transform: translate(calc(-50% + var(--x) * 140px), calc(-50% + var(--y) * 122px))
             scale(0);
  opacity: 0;
  transition: transform 400ms ease, box-shadow 400ms ease;
  animation: hex-bloom 700ms cubic-bezier(.2,.9,.3,1) forwards;
}

.hex-r1 { width: 150px; height: 174px; animation-delay: 1000ms; }
.hex-r2 { width: 130px; height: 150px; animation-delay: 1300ms; opacity: .85; }

@keyframes hex-bloom {
  0%   { transform: translate(calc(-50% + var(--x) * 140px), calc(-50% + var(--y) * 122px)) scale(0); opacity: 0; }
  60%  { opacity: 1; }
  100% { transform: translate(calc(-50% + var(--x) * 140px), calc(-50% + var(--y) * 122px)) scale(1); opacity: 1; }
}

.hex-r1 {
  animation-name: hex-bloom-r1;
}
@keyframes hex-bloom-r1 {
  0%   { transform: translate(calc(-50% + var(--x) * 110px), calc(-50% + var(--y) * 96px)) scale(0); opacity: 0; }
  60%  { opacity: 1; }
  100% { transform: translate(calc(-50% + var(--x) * 110px), calc(-50% + var(--y) * 96px)) scale(1); opacity: 1; }
}
.hex-r1 { transform: translate(calc(-50% + var(--x) * 110px), calc(-50% + var(--y) * 96px)) scale(0); }

.hex-r2 {
  animation-name: hex-bloom-r2;
}
@keyframes hex-bloom-r2 {
  0%   { transform: translate(calc(-50% + var(--x) * 220px), calc(-50% + var(--y) * 192px)) scale(0); opacity: 0; }
  60%  { opacity: .85; }
  100% { transform: translate(calc(-50% + var(--x) * 220px), calc(-50% + var(--y) * 192px)) scale(1); opacity: .85; }
}
.hex-r2 { transform: translate(calc(-50% + var(--x) * 220px), calc(-50% + var(--y) * 192px)) scale(0); }

.c-violet { background: var(--c-violet); }
.c-pink   { background: var(--c-pink); }
.c-orange { background: var(--c-orange); }
.c-gold   { background: var(--c-gold); }
.c-teal   { background: var(--c-teal); }
.c-deep   { background: #2a3a52; }

/* central hex */
.hex-center {
  width: 320px;
  height: 370px;
  background: var(--c-deep);
  border: 0;
  outline: 1px solid var(--c-gold);
  outline-offset: -8px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 1.5rem;
  transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  animation: hex-center-in 800ms cubic-bezier(.2,.9,.3,1) 200ms forwards;
}

@keyframes hex-center-in {
  0%   { transform: translate(-50%, -50%) scale(0); opacity: 0; }
  100% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
}

.hex-center-inner {
  display: grid;
  gap: .6rem;
  padding: 0 1.5rem;
}

.kanji {
  font-family: var(--font-display);
  font-size: clamp(38px, 5vw, 64px);
  color: var(--c-gold);
  letter-spacing: 0.12em;
  line-height: 1;
}

.title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 56px);
  letter-spacing: 0.06em;
  color: var(--c-cream);
  font-weight: 400;
}

.subtitle {
  font-family: var(--font-body);
  font-size: clamp(11px, 1vw, 13px);
  color: var(--c-gold);
  font-style: italic;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.hive-footer {
  position: absolute;
  bottom: 1.6rem;
  left: 0;
  right: 0;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  padding: 0 clamp(1rem, 4vw, 3rem);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-gold);
  opacity: 0;
  animation: fade-in 700ms ease 2400ms forwards;
}

.editorial-meta { font-style: italic; font-weight: 300; }

@keyframes fade-in { to { opacity: 1; } }

/* ============== SECTION MARKERS ============== */
.comb-section {
  position: relative;
  padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 4vw, 3rem) clamp(4rem, 8vw, 6rem);
}

.comb-section[data-section="2"] { background: linear-gradient(180deg, var(--c-deep) 0%, #11243a 100%); }
.comb-section[data-section="3"] { background: linear-gradient(180deg, #11243a 0%, var(--c-deep) 100%); }

.section-marker {
  display: flex;
  align-items: center;
  gap: 1.4rem;
  max-width: 1240px;
  margin: 0 auto clamp(2rem, 4vw, 3.4rem);
  padding: 0 1rem;
}

.folio {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 44px);
  color: var(--c-gold);
  letter-spacing: 0.05em;
}

.section-rule {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--c-gold) 0%, transparent 100%);
  position: relative;
}

.section-rule::before,
.section-rule::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 8px;
  height: 8px;
  background: var(--c-gold);
  transform: translateY(-50%) rotate(45deg);
}
.section-rule::before { left: 0; }
.section-rule::after  { left: 18px; opacity: .55; }

.section-label {
  font-family: var(--font-display);
  font-size: clamp(14px, 1.4vw, 20px);
  color: var(--c-cream);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* ============== COMB GRID ============== */
.comb-grid {
  position: relative;
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 0 1rem;
}

.comb-grid::before {
  content: "";
  position: absolute;
  inset: -2rem;
  background-image:
    linear-gradient(60deg, transparent 49.5%, rgba(212,176,80,0.08) 49.5%, rgba(212,176,80,0.08) 50.5%, transparent 50.5%),
    linear-gradient(-60deg, transparent 49.5%, rgba(212,176,80,0.08) 49.5%, rgba(212,176,80,0.08) 50.5%, transparent 50.5%);
  background-size: 80px 138px;
  pointer-events: none;
  z-index: 0;
  opacity: .35;
}

.comb-grid > .comb-cell:nth-child(3n+2) {
  transform: translateY(60px);
}

.comb-cell {
  position: relative;
  aspect-ratio: 1 / 1.155;
  clip-path: var(--hex-clip);
  background: var(--c-deep);
  outline: 1px solid var(--c-gold);
  outline-offset: -8px;
  padding: 18% 20% 16%;
  display: grid;
  align-content: center;
  text-align: center;
  gap: 0.6rem;
  cursor: pointer;
  transition: transform 320ms cubic-bezier(.2,.9,.3,1), filter 400ms ease, opacity 400ms ease;
  filter: blur(4px);
  opacity: 0.4;
  z-index: 1;
}

.comb-cell.is-visible {
  filter: blur(0);
  opacity: 1;
}

.comb-cell:hover {
  transform: scale(1.05);
}

.comb-grid > .comb-cell:nth-child(3n+2):hover {
  transform: translateY(60px) scale(1.05);
}

.comb-cell::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(232,120,48,0) 0%, rgba(232,120,48,0) 70%, rgba(232,120,48,0.15) 100%);
  opacity: 0;
  transition: opacity 320ms ease;
  pointer-events: none;
}

.comb-cell:hover::before { opacity: 1; }

.cell-illust {
  width: 56px;
  height: 56px;
  margin: 0 auto;
  filter: drop-shadow(0 0 12px rgba(212,176,80,0.18));
}

.cell-illust svg { width: 100%; height: 100%; }

.cell-title {
  font-family: var(--font-display);
  font-size: clamp(15px, 1.5vw, 22px);
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--c-cream);
  line-height: 1.2;
}

.cell-text {
  font-size: clamp(11px, 0.92vw, 13px);
  font-weight: 300;
  color: var(--c-cream);
  opacity: 0.86;
  line-height: 1.55;
}

.cell-tag {
  font-family: var(--font-body);
  font-size: 10px;
  font-style: italic;
  font-weight: 300;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--c-gold);
}

/* accent border colors per cell */
.comb-cell:nth-child(6n+1) { outline-color: var(--c-orange); }
.comb-cell:nth-child(6n+2) { outline-color: var(--c-pink); }
.comb-cell:nth-child(6n+3) { outline-color: var(--c-violet); }
.comb-cell:nth-child(6n+4) { outline-color: var(--c-teal); }
.comb-cell:nth-child(6n+5) { outline-color: var(--c-gold); }
.comb-cell:nth-child(6n+6) { outline-color: var(--c-cream); }

/* ============== EDITORIAL SPREAD ============== */
.spread {
  position: relative;
  width: 100%;
  min-height: 80vh;
  background: var(--c-deep);
  display: grid;
  place-items: center;
  overflow: hidden;
  padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 4vw, 4rem);
}

.spread-alt { background: linear-gradient(135deg, #1a0e2e 0%, var(--c-deep) 100%); }

.spread-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  filter: blur(3px);
  opacity: 0.85;
  transform: translateY(0);
  transition: transform 600ms ease;
}

.spread-bg svg { width: 100%; height: 100%; }

.spread-content {
  position: relative;
  z-index: 2;
  max-width: 980px;
  text-align: center;
  display: grid;
  gap: 1.3rem;
  padding: 0 1rem;
}

.spread-folio {
  font-family: var(--font-display);
  font-size: clamp(12px, 1.2vw, 16px);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--c-gold);
}

.spread-headline {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(48px, 9vw, 132px);
  line-height: 0.96;
  letter-spacing: 0.02em;
  color: var(--c-cream);
  position: relative;
  transition: -webkit-text-stroke 320ms ease, color 320ms ease;
  -webkit-text-stroke: 0 transparent;
}

.spread-headline:hover {
  color: transparent;
  -webkit-text-stroke: 1px var(--c-gold);
}

.spread-deck {
  font-family: var(--font-body);
  font-size: clamp(15px, 1.4vw, 19px);
  font-weight: 300;
  font-style: italic;
  color: var(--c-cream);
  opacity: 0.92;
  max-width: 720px;
  margin: 0 auto;
  line-height: 1.7;
}

.spread-attribution {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--c-gold);
}

/* ============== CONNECTION WEB FOOTER ============== */
.connection-web {
  position: relative;
  background: linear-gradient(180deg, var(--c-deep) 0%, #050b18 100%);
  padding: clamp(5rem, 9vw, 8rem) clamp(1rem, 4vw, 3rem) 3rem;
  overflow: hidden;
}

.web-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  gap: 2.4rem;
  text-align: center;
}

.web-folio {
  font-family: var(--font-display);
  font-size: clamp(12px, 1.2vw, 16px);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--c-gold);
}

.web-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(34px, 5vw, 64px);
  letter-spacing: 0.02em;
  color: var(--c-cream);
  line-height: 1.1;
}

.web-deck {
  font-family: var(--font-body);
  font-size: clamp(14px, 1.2vw, 17px);
  font-weight: 300;
  font-style: italic;
  color: var(--c-cream);
  opacity: 0.86;
  max-width: 720px;
  margin: 0 auto;
  line-height: 1.7;
}

.web-svg {
  width: 100%;
  height: auto;
  max-height: 60vh;
}

.web-edges path {
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
  transition: stroke-dashoffset 1200ms ease, opacity 320ms ease, stroke-width 320ms ease;
}

.web-edges path.is-drawn { stroke-dashoffset: 0; }

.web-edges path.is-active {
  opacity: 1 !important;
  stroke-width: 2;
  filter: drop-shadow(0 0 6px var(--c-gold));
}

.web-nodes g {
  cursor: pointer;
  transition: transform 320ms ease;
  transform-box: fill-box;
  transform-origin: center;
}

.web-nodes g:hover {
  transform: scale(1.18);
}

.web-footer {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  align-items: center;
  margin-top: 1.6rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(212,176,80,0.25);
}

.web-footer .meta {
  font-size: 11px;
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--c-gold);
}

/* ============== RESPONSIVE ============== */
@media (max-width: 900px) {
  .comb-grid { grid-template-columns: repeat(2, 1fr); }
  .comb-grid > .comb-cell:nth-child(3n+2) { transform: translateY(0); }
  .comb-grid > .comb-cell:nth-child(2n):not(:nth-child(3n+2)) { transform: translateY(48px); }
  .comb-grid > .comb-cell:nth-child(2n):not(:nth-child(3n+2)):hover { transform: translateY(48px) scale(1.05); }
  .hex { width: 130px; height: 150px; }
  .hex-r1 { width: 110px; height: 127px; }
  .hex-r2 { width: 90px; height: 104px; }
  .hex-center { width: 240px; height: 277px; }
}

@media (max-width: 560px) {
  .comb-grid { grid-template-columns: 1fr; gap: 16px; }
  .comb-grid > .comb-cell { transform: none !important; aspect-ratio: 1.1 / 1; padding: 12% 16%; }
  .comb-grid > .comb-cell:hover { transform: scale(1.03) !important; }
  .hive-footer { flex-direction: column; gap: .5rem; align-items: center; text-align: center; }
  .hex-center { width: 200px; height: 230px; }
  .kanji { font-size: 36px; }
  .title { font-size: 26px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
