:root{
  --bg:#080808;
  --bg-soft:#0f100d;
  --panel:#10110f;
  --panel-2:#141512;
  --text:#f3f3ec;
  --muted:#aab08b;
  --accent:#ecf2b6;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(236,242,182,.22);
  --shadow:0 24px 70px rgba(0,0,0,.36);
  --radius:30px;
  --max:1360px;
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
  background:#070707;
  overflow-x:hidden;
}

body{
  margin:0;
  background:radial-gradient(circle at top,#10110d 0%, #090909 40%, #070707 100%);
  color:var(--text);
  font-family:Inter,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}

.wrap{
  width:min(var(--max),calc(100% - 44px));
  margin:0 auto;
}

.pageShell{
  min-height:100vh;
  min-height:100dvh;
  position:relative;
  display:flex;
  flex-direction:column;
}

@keyframes pageIn{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}

#pjax-container{
  flex:1;
  animation:pageIn .75s cubic-bezier(.16,1,.3,1) both;
}

.pageShell:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.03) 0.6px, transparent 0.6px);
  background-size:18px 18px;
  opacity:.15;
  mix-blend-mode:soft-light;
}

.siteHeader{display:none}
.siteHeader.is-visible{display:none}

.siteHeaderInner{
  width:min(calc(var(--max) + 16px),calc(100% - 18px));
  margin:16px auto 0;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(9,9,9,.68);
  backdrop-filter:blur(14px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  box-shadow:var(--shadow);
}

.headerBrand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.headerMark{
  width:36px;
  height:36px;
  object-fit:contain;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.2));
}

.headerWordmark{
  display:flex;
  flex-direction:column;
  line-height:1;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.headerWordmark span{
  font-size:9px;
  color:var(--accent);
}

.headerWordmark strong{
  font-size:12px;
  font-weight:600;
}

.headerAction{
  display:flex;
  align-items:center;
  gap:12px;
}

.headerArchive,
.footerAction,
.mobilePanelLabel,
.detailKicker,
.heroSubtitle,
.heroScrollText,
.footerMeta,
.footerBrandText span,
.detailNumber,
.infoVisualCaption,
.infoPanelLead,
.adminEyebrow,
.adminPanelSubtle,
.tableCaption,
.toolPill,
.miniStat span{
  font-size:10px;
  letter-spacing:.3em;
  text-transform:uppercase;
}

.headerArchive{
  padding:0 2px;
  color:var(--accent);
}

.headerDot{
  width:4px;
  height:4px;
  border-radius:50%;
  background:var(--accent);
  opacity:.8;
}

.mobileToggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  color:var(--text);
  position:relative;
}

.mobileToggle span,
.mobileToggle span:before,
.mobileToggle span:after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:16px;
  height:1px;
  background:var(--text);
  transform:translate(-50%,-50%);
  transition:all .3s ease;
}

.mobileToggle span:before{margin-top:-5px}
.mobileToggle span:after{margin-top:5px}
.mobileToggle.is-open span{background:transparent}

.mobileToggle.is-open span:before{
  margin-top:0;
  transform:translate(-50%,-50%) rotate(45deg);
}

.mobileToggle.is-open span:after{
  margin-top:0;
  transform:translate(-50%,-50%) rotate(-45deg);
}

.mobilePanel{
  position:fixed;
  inset:0;
  background:rgba(8,8,8,.82);
  backdrop-filter:blur(14px);
  z-index:65;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
}

.mobilePanel.is-open{
  opacity:1;
  pointer-events:auto;
}

.mobilePanelInner{
  position:absolute;
  inset:auto 14px 14px 14px;
  padding:18px;
  border-radius:28px;
  border:1px solid var(--line);
  background:#0d0e0d;
  display:grid;
  gap:10px;
  transform:translateY(18px);
  transition:transform .35s ease;
}

.mobilePanel.is-open .mobilePanelInner{
  transform:translateY(0);
}

.mobilePanelHead{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-bottom:10px;
  border-bottom:1px solid var(--line);
}

.mobilePanelClose{
  background:none;
  border:0;
  color:var(--text);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:11px;
}

.mobileNavLink{
  display:flex;
  align-items:center;
  min-height:60px;
  padding:0 6px;
  border-bottom:1px solid rgba(255,255,255,.06);
  font-size:clamp(28px,8vw,46px);
  font-weight:300;
  letter-spacing:.04em;
  text-transform:uppercase;
}

/* HERO */
.hero{
  min-height:168vh;
  position:relative;
}

.heroSticky{
  position:sticky;
  top:0;
  min-height:100vh;
  display:grid;
  place-items:center;
  overflow:hidden;
}

.heroBackdrop,
.heroNoise{
  position:absolute;
  inset:0;
}

.heroBackdrop{
  background:
    radial-gradient(circle at 50% 18%, rgba(236,242,182,.08), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 35%),
    linear-gradient(180deg,#0b0b0b,#080808 60%,#070707);
}

.heroNoise{
  background-image:radial-gradient(rgba(255,255,255,.05) .6px, transparent .6px);
  background-size:14px 14px;
  opacity:.06;
  mix-blend-mode:screen;
}

.heroStage{
  position:relative;
  z-index:2;
  width:min(var(--max),calc(100% - 40px));
  margin:auto;
  display:grid;
  place-items:center;
  text-align:center;
  min-height:100vh;
}

.heroCenter{
  position:absolute;
  inset:0;
  z-index:3;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:18px;
  width:100%;
  height:100%;
  padding:0 20px;
}

.heroMarkWrap{
  height:auto;
  max-height:52vh;
  display:grid;
  place-items:center;
  opacity:calc(1 - (var(--hero-progress,0) * 1.35));
  transform:translateY(calc(var(--hero-progress,0) * -72px)) scale(calc(1 - (var(--hero-progress,0) * .16)));
  transition:opacity .1s linear;
}

.heroMark{
  width:min(62vw,980px);
  max-width:100%;
  max-height:52vh;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 28px 58px rgba(0,0,0,.46));
}

.heroWordmark{
  position:absolute;
  inset:auto 0 14vh;
  display:grid;
  gap:16px;
  opacity:clamp(0,calc((var(--hero-progress,0) - .12) * 2.6),1);
  transform:translateY(calc(56px - (var(--hero-progress,0) * 68px)));
}

.heroTitle{
  margin:0;
  display:flex;
  flex-direction:column;
  gap:4px;
  align-items:center;
  font-weight:300;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:clamp(56px,11vw,170px);
  line-height:.9;
}

.heroStudio{
  font-size:clamp(11px,1.2vw,14px);
  letter-spacing:.58em;
  color:var(--accent);
  padding-left:.55em;
}

.heroSubtitle{
  margin:0;
  color:#d6d9c0;
  opacity:.9;
}

/* DESKTOP SCROLL FIXED */
.heroScrollCue{
  position:static;
  display:grid;
  justify-items:center;
  gap:10px;
  background:none;
  border:0;
  color:#d5d8bf;
  opacity:clamp(.94, calc(1 - (var(--hero-progress,0) * 1.7)), 1);
  transition:transform .4s cubic-bezier(.16,1,.3,1), opacity .4s ease;
  cursor:pointer;
  z-index:20;
  margin-top:12px;
}

.heroScrollCue.is-hidden{
  opacity:0!important;
  pointer-events:none;
  transform:translateY(10px)!important;
}

.heroScrollCue:hover{
  transform:translateY(-2px);
}

.heroScrollText{
  color:#d7dbbf;
}

.heroScrollArrow{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(236,242,182,.34);
  position:relative;
  background:rgba(255,255,255,.02);
  box-shadow:0 16px 34px rgba(0,0,0,.22);
}

.heroScrollArrow:before,
.heroScrollArrow:after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  background:var(--accent);
  transform-origin:center;
}

.heroScrollArrow:before{
  width:1px;
  height:14px;
  transform:translate(-50%,-58%);
}

.heroScrollArrow:after{
  width:9px;
  height:9px;
  border-right:1px solid var(--accent);
  border-bottom:1px solid var(--accent);
  background:transparent;
  transform:translate(-50%,-12%) rotate(45deg);
}

.heroScrollCue .heroScrollArrow{
  animation:heroArrowFloat 1.8s ease-in-out infinite;
}

@keyframes heroArrowFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(6px)}
}

.heroSceneWords{
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:clamp(0,calc((var(--hero-progress,0) - .18) * 1.5),.18);
}

.heroSceneWords span{
  position:absolute;
  font-size:clamp(42px,10vw,132px);
  font-weight:300;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,.18);
}

.heroSceneWords span:nth-child(1){left:7%;top:18%}
.heroSceneWords span:nth-child(2){right:10%;top:35%}
.heroSceneWords span:nth-child(3){left:12%;bottom:18%}

/* GALLERY */
.galleryFlow{
  padding:0 0 72px;
  margin-top:-14vh;
  position:relative;
  z-index:4;
}

.flowLead{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:26px;
  align-items:end;
  margin-bottom:30px;
}

.flowLead h2,
.archiveHead h2,
.detailRelatedHead h2{
  margin:0;
  font-size:clamp(28px,4vw,56px);
  font-weight:300;
  line-height:.96;
  letter-spacing:.02em;
  text-transform:uppercase;
}

.flowLead p,
.archiveLead p,
.detailLead,
.detailStory,
.infoText,
.detailEditorialBlock p{
  margin:0;
  color:#d4d5ce;
  line-height:1.85;
  font-size:15px;
}

.flowCards{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:22px;
  align-items:start;
}

.flowCard{
  position:relative;
  border-radius:30px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.07);
  background:#0e0e0e;
  box-shadow:var(--shadow);
  transform:translateY(0);
  transition:transform .65s cubic-bezier(.16,1,.3,1), border-color .4s ease, box-shadow .65s cubic-bezier(.16,1,.3,1);
}

.flowCard:hover{
  transform:translateY(-10px) scale(1.013);
  border-color:var(--line-strong);
  box-shadow:0 48px 90px rgba(0,0,0,.6);
}

.flowCard.flowReveal:nth-child(1){transition-delay:0ms}
.flowCard.flowReveal:nth-child(2){transition-delay:90ms}
.flowCard.flowReveal:nth-child(3){transition-delay:180ms}
.flowCard.flowReveal:nth-child(4){transition-delay:270ms}
.flowCard.flowReveal:nth-child(5){transition-delay:340ms}
.flowCard.flowReveal:nth-child(6){transition-delay:410ms}
.flowCard.flowReveal:nth-child(7){transition-delay:480ms}
.flowCard.flowReveal:nth-child(8){transition-delay:540ms}
.flowCard.flowReveal.is-visible{transition-delay:0ms}

.flowCard img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio:4/5.3;
  filter:saturate(.94) contrast(1.02);
}

.flowCardMeta{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:14px;
  padding:12px 14px;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(8,8,8,.06),rgba(8,8,8,.62));
  backdrop-filter:blur(10px);
}

.flowCardMeta small{
  display:block;
  color:#d9dcc8;
  font-size:10px;
  letter-spacing:.26em;
  text-transform:uppercase;
  margin-bottom:8px;
}

.flowCardMeta strong{
  display:block;
  font-size:16px;
  font-weight:500;
}

.flowReveal{
  opacity:0;
  transform:translateY(52px) scale(.97);
  transition:opacity 1.1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1);
}

.flowReveal.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
}

.archiveStrip{padding:56px 0 94px}

.archivePanel,
.panel,
.loginBox,
.infoShell,
.archiveTile,
.stat,
.miniStat{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.archivePanel{
  padding:28px;
  border-radius:32px;
}

.archiveHead{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:24px;
}

.archiveHead h2{font-size:clamp(24px,3vw,42px)}

.archiveGrid,
.archiveListGrid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.archiveTile{
  display:block;
  border-radius:24px;
  overflow:hidden;
  transition:transform .65s cubic-bezier(.16,1,.3,1),border-color .4s ease,box-shadow .65s cubic-bezier(.16,1,.3,1);
}

.archiveTile:hover{
  transform:translateY(-7px) scale(1.016);
  border-color:var(--line-strong);
  box-shadow:0 32px 64px rgba(0,0,0,.52);
}

.archiveTile img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
}

.archiveTileCaption{
  display:grid;
  gap:8px;
  padding:14px 14px 16px;
}

.archiveTileCaption strong{
  font-weight:500;
  font-size:15px;
}

.archiveLead{
  padding:130px 0 28px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:16px;
  align-items:end;
}

.archiveLead h1{
  margin:0;
  font-size:clamp(38px,6vw,86px);
  font-weight:300;
  letter-spacing:.03em;
  text-transform:uppercase;
  line-height:.92;
}

.archiveList{
  padding-bottom:70px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:16px;
  align-items:start;
}

.indexList{display:grid;gap:12px}

.indexItem{
  display:grid;
  grid-template-columns:90px 1fr auto;
  gap:14px;
  align-items:center;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.02);
}

.indexThumb img{
  width:90px;
  height:90px;
  object-fit:cover;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
}

.indexMeta small{
  display:block;
  color:var(--muted);
  font-size:10px;
  letter-spacing:.26em;
  text-transform:uppercase;
  margin-bottom:8px;
}

.indexMeta strong{font-weight:500}

.detailPage{padding:118px 0 80px}

.detailHeader{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:24px;
  align-items:start;
}

.detailImageWrap{
  position:sticky;
  top:108px;
  border-radius:32px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#0d0d0d;
  box-shadow:var(--shadow);
}

.detailImageWrap img{
  width:100%;
  max-height:84vh;
  object-fit:contain;
  background:#0b0b0b;
}

.detailMeta{
  display:grid;
  gap:18px;
  padding:14px 0;
  align-content:start;
}

.detailTopline{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:center;
}

.detailMeta h1{
  margin:0;
  font-size:clamp(34px,5vw,74px);
  font-weight:300;
  line-height:.92;
  letter-spacing:.03em;
  text-transform:uppercase;
}

.detailLead{max-width:46ch}

.detailStory{
  padding:20px 22px;
  border-radius:26px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--line);
}

.detailZoomHint{
  position:absolute;
  right:18px;
  bottom:18px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(236,242,182,.18);
  background:rgba(8,8,8,.58);
  backdrop-filter:blur(10px);
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--accent);
}

.detailPanel{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 16px;
  margin:2px 0 8px;
  padding:22px;
  border-radius:28px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}

.detailPanel div:nth-child(odd){color:var(--muted)}
.detailPanel div:nth-child(even){font-size:15px}

.detailSplit{display:grid;gap:18px}

.detailEditorialBlock{
  padding:22px;
  border-radius:26px;
  border:1px solid rgba(236,242,182,.16);
  background:linear-gradient(180deg,rgba(236,242,182,.05),rgba(255,255,255,.02));
}

.detailEditorialBlock span{
  display:block;
  color:var(--accent);
  font-size:10px;
  letter-spacing:.34em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.detailNav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding-top:4px;
}

.detailRelatedWrap{padding-top:48px}

.detailRelatedHead{
  display:grid;
  gap:10px;
  margin-bottom:18px;
}

.ghostBtn,
.solidBtn,
.btn,
.btnAlt,
.btnTiny,
.toolPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid var(--line);
  font-size:11px;
  letter-spacing:.26em;
  text-transform:uppercase;
}

.ghostBtn,
.btnAlt,
.toolPill{
  background:rgba(255,255,255,.02);
  color:var(--text);
}

.solidBtn,
.btn{
  background:var(--accent);
  color:#090909;
  border-color:var(--accent);
}

.toolPill{
  min-height:36px;
  padding:0 12px;
  font-size:9px;
  color:var(--accent);
}

.infoOverlay{
  position:fixed;
  inset:0;
  z-index:70;
  background:rgba(6,6,6,.78);
  backdrop-filter:blur(14px);
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
}

.infoOverlay.is-open{
  opacity:1;
  pointer-events:auto;
}

.infoShell{
  position:absolute;
  right:0;
  top:0;
  bottom:0;
  width:min(820px,100%);
  padding:28px 24px 22px;
  display:grid;
  grid-template-rows:auto 1fr auto;
  transform:translateX(36px);
  transition:transform .42s cubic-bezier(.2,.7,.1,1);
  background:#0a0a0a;
  border-left:1px solid var(--line);
}

.infoOverlay.is-open .infoShell{
  transform:translateX(0);
}

.infoTop{
  display:flex;
  justify-content:space-between;
  align-items:start;
  gap:16px;
  margin-bottom:12px;
}

.infoHeadTitle{
  margin-top:8px;
  font-size:clamp(26px,4vw,50px);
  font-weight:300;
  letter-spacing:.02em;
  text-transform:uppercase;
  line-height:.95;
}

.infoClose{
  width:46px;
  height:46px;
  border-radius:50%;
  border:1px solid var(--line);
  background:transparent;
  color:var(--text);
}

.infoBody{
  overflow:auto;
  padding-right:6px;
  display:grid;
  gap:18px;
}

.infoVisualBlock{display:grid;gap:10px}

.infoPortrait{
  width:100%;
  max-height:38vh;
  object-fit:cover;
  border-radius:26px;
  border:1px solid var(--line);
  background:#111;
}

.infoPanel{
  display:grid;
  gap:16px;
  padding:12px 0;
}

.infoPanelLead{color:var(--accent)}
.infoText{white-space:pre-line}

.infoLinks{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  padding-top:16px;
  border-top:1px solid var(--line);
}

/* MUSIC */
.musicDock{
  position:fixed;
  left:18px;
  bottom:18px;
  z-index:69;
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 14px;
  border:1px solid rgba(236,242,182,.18);
  border-radius:999px;
  background:rgba(8,8,8,.84);
  backdrop-filter:blur(14px);
  box-shadow:0 20px 36px rgba(0,0,0,.28);
  max-width:min(calc(100vw - 36px), 680px);
  transition:bottom .2s ease, transform .2s ease;
}

.musicToggle{
  position:relative;
  width:52px;
  height:52px;
  border-radius:50%;
  border:1px solid rgba(236,242,182,.24);
  background:radial-gradient(circle at 35% 30%, rgba(255,255,255,.18), rgba(255,255,255,.03) 36%, rgba(0,0,0,.18) 100%);
  display:grid;
  place-items:center;
  color:var(--accent);
  cursor:pointer;
  overflow:hidden;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.03), 0 10px 26px rgba(0,0,0,.22);
}

.musicDisc{
  position:absolute;
  inset:3px;
  border-radius:50%;
  background-image:linear-gradient(rgba(0,0,0,.18),rgba(0,0,0,.18)), var(--cover-image, none);
  background-size:cover;
  background-position:center;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}

.musicDisc:before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background:repeating-radial-gradient(circle at center, transparent 0 6px, rgba(255,255,255,.06) 6px 7px, transparent 7px 11px);
}

.musicDisc:after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:12px;
  height:12px;
  border-radius:50%;
  background:#0b0b0b;
  box-shadow:0 0 0 3px rgba(236,242,182,.28);
  transform:translate(-50%,-50%);
}

.musicToggleState{
  position:relative;
  z-index:2;
  display:block;
  width:14px;
  height:14px;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.45));
}

.musicToggleState:before{
  content:"";
  position:absolute;
  left:3px;
  top:0;
  border-left:11px solid #f0f3d8;
  border-top:7px solid transparent;
  border-bottom:7px solid transparent;
  opacity:.96;
}

.musicDock.is-playing .musicDisc{
  animation:spinRecord 4.8s linear infinite;
}

.musicDock.is-playing .musicToggleState:before{
  display:none;
}

.musicDock.is-playing .musicToggleState:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,#f0f3d8 0 4px,transparent 4px 8px,#f0f3d8 8px 12px);
}

@keyframes spinRecord{
  from{transform:rotate(0)}
  to{transform:rotate(360deg)}
}

.musicMeta{
  display:grid;
  gap:2px;
  min-width:0;
}

.musicMeta small{
  font-size:9px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--muted);
}

.musicMeta strong{
  font-size:12px;
  white-space:nowrap;
  max-width:180px;
  overflow:hidden;
  text-overflow:ellipsis;
}

.musicVolume{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:110px;
}

.musicVolume span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  opacity:.85;
  box-shadow:0 0 0 6px rgba(236,242,182,.08);
}

.musicVolume input{
  appearance:none;
  -webkit-appearance:none;
  width:120px;
  height:4px;
  padding:0;
  border:none;
  border-radius:999px;
  background:rgba(236,242,182,.2);
  outline:none;
}

.musicVolume input::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:14px;
  height:14px;
  border-radius:50%;
  background:var(--accent);
  border:none;
  box-shadow:0 0 0 4px rgba(236,242,182,.12);
  cursor:pointer;
}

.musicVolume input::-moz-range-thumb{
  width:14px;
  height:14px;
  border-radius:50%;
  background:var(--accent);
  border:none;
  box-shadow:0 0 0 4px rgba(236,242,182,.12);
  cursor:pointer;
}

.footer{
  position:relative;
  padding:18px 0 22px;
  border-top:1px solid rgba(255,255,255,.06);
}

.footerInner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
}

.footerBrand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.footerBrand img{
  width:72px;
  height:72px;
  object-fit:contain;
  opacity:.98;
}

.footerBrandText{
  display:flex;
  flex-direction:column;
  line-height:1;
}

.footerBrandText strong{
  font-size:12px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.footerMeta{margin-top:6px;color:#bfc3a6}

.footerActions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.footerAction{color:var(--accent)}

.adminWrap{max-width:1380px;margin:18px auto 40px;padding:0 18px}
.adminHero{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;padding:8px 0 22px}
.adminHero h1{margin:8px 0 0;font-weight:300;letter-spacing:.04em;text-transform:uppercase;font-size:clamp(34px,5vw,64px);line-height:.94}
.adminTopNav{display:flex;gap:10px;flex-wrap:wrap}
.dash{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat,.miniStat{padding:18px;border-radius:24px}
.stat b{display:block;font-size:34px;font-weight:500;margin-top:10px}
.adminGrid{display:grid;grid-template-columns:1.08fr .92fr;gap:18px;margin-top:18px}
.panel{padding:24px;border-radius:30px}
.panelHead{display:flex;justify-content:space-between;align-items:end;gap:12px;margin-bottom:18px}
.panel h2{margin:0;font-size:24px;font-weight:400;letter-spacing:.01em}
.panelIntro{display:grid;gap:4px}
.tableWrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:14px 12px;border-bottom:1px solid rgba(255,255,255,.06);font-size:14px;vertical-align:top}
th{font-size:10px;color:var(--muted);letter-spacing:.24em;text-transform:uppercase;font-weight:500}
input,textarea,select{width:100%;padding:14px 15px;background:#0d0d0d;border:1px solid rgba(255,255,255,.1);color:#f1f1ed;border-radius:18px;outline:none;transition:border-color .25s ease, background .25s ease}
input:focus,textarea:focus,select:focus{border-color:rgba(236,242,182,.26);background:#101010}
textarea{min-height:150px;resize:vertical}
.btnTiny{min-height:38px;padding:0 14px;font-size:10px}
.loginPage{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top,rgba(236,242,182,.06),transparent 24%), #090909}
.loginBox{width:min(560px,100%);padding:32px;border-radius:32px;border:1px solid rgba(236,242,182,.12);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));box-shadow:0 32px 70px rgba(0,0,0,.34)}
.notice,.error{padding:14px 16px;border-radius:18px;margin-bottom:14px}.notice{background:#202412;border:1px solid rgba(236,242,182,.35);color:#eef4cd}.error{background:#2c1418;border:1px solid #643038;color:#ffd8df}
.fileHint{font-size:12px;color:var(--muted);margin-top:8px}
.checkboxRow{display:flex;gap:14px;flex-wrap:wrap}.checkboxRow label{display:flex;gap:8px;align-items:center;width:auto;color:#d9d9d2}
.formGrid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.adminShell{display:grid;gap:18px}
.adminToolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding:14px 18px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.02)}
.adminToolbarGroup{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.adminMediaPreview{display:grid;grid-template-columns:94px 1fr;gap:14px;align-items:center;padding:14px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.02);margin-bottom:14px}
.adminMediaPreview img{width:94px;height:94px;object-fit:cover;border-radius:18px;border:1px solid rgba(255,255,255,.08)}
.adminFormSection{display:grid;gap:12px;margin-top:12px}
.tableCaption{color:var(--accent)}
.techGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.miniStat b{display:block;font-size:24px;margin-top:8px}
.logCode{max-width:280px;overflow:auto;white-space:pre-wrap;word-break:break-word;font-size:12px;color:#dfe2cf}

/* ── Sortable drag-drop ─────────────────────────────────────────────────── */
.sortableGhost{opacity:.35;background:rgba(236,242,182,.06)!important}
.dragHandle:hover{color:var(--accent)!important}
tr[data-id]{transition:background .15s}

/* RESPONSIVE */
@media (max-width:1100px){
  .flowCards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .flowA,.flowB,.flowC,.flowD,.flowE,.flowF,.flowG,.flowH{grid-column:span 3;transform:none!important}
  .archiveGrid,.archiveListGrid{grid-template-columns:repeat(2,1fr)}
  .detailHeader,.flowLead,.archiveLead,.archiveList,.adminGrid,.techGrid{grid-template-columns:1fr}
  .detailImageWrap{position:static}
}

@media (max-width:820px){
  .footerTopButton{
    width:48px;
    height:48px;
    right:16px;
  }

  .siteHeaderInner{
    padding:10px 12px;
    margin-top:12px;
  }

  .headerArchive,
  .headerDot,
  .headerWordmark{
    display:none;
  }

  .mobileToggle{display:flex}

  .hero{
    min-height:100svh;
    min-height:100vh;
  }

  .heroSticky,
  .heroStage{
    min-height:100svh;
    min-height:100vh;
  }

  .heroCenter{
    gap:2px;
    padding:0 16px 8vh;
    justify-content:center;
    transform:none;
  }

  .heroMark{
    width:min(82vw,400px);
  }

  .heroWordmark{
    inset:auto 0 14vh;
    gap:10px;
  }

  .heroTitle{
    font-size:clamp(42px,12vw,92px);
  }

  .heroScrollCue{
    margin-top:-10px;
  }

  .archiveGrid,
  .archiveListGrid{
    grid-template-columns:1fr;
  }

  .flowA,.flowB,.flowC,.flowD,.flowE,.flowF,.flowG,.flowH{
    grid-column:auto;
  }

  .footerInner{
    align-items:flex-start;
    flex-direction:column;
  }

  .dash{
    grid-template-columns:1fr 1fr;
  }

  .formGrid2{
    grid-template-columns:1fr;
  }
}

@media (max-width:640px){
  .footerTopButton{
    position:fixed;
    right:14px;
    bottom:18px;
    top:auto;
    transform:none;
  }

  .footerTopButton:hover{
    transform:translateY(-2px);
  }

  .wrap{
    width:min(var(--max), calc(100% - 24px));
  }

  .hero{
    min-height:100svh;
    min-height:100vh;
  }

  .heroSticky,
  .heroStage{
    min-height:100svh;
    min-height:100vh;
  }

  .heroStage{
    width:min(var(--max),calc(100% - 24px));
  }

  .heroCenter{
    gap:2px;
    padding:0 16px 8vh;
    justify-content:center;
    transform:none;
  }

  .heroMarkWrap{
    height:auto;
    transform:translateY(calc(var(--hero-progress,0) * -20px)) scale(calc(1 - (var(--hero-progress,0) * .08)));
  }

  .heroMark{
    width:min(82vw,400px);
  }

  .heroScrollCue{
    margin-top:-8px;
    gap:8px;
  }

  .heroScrollText{
    font-size:10px;
    letter-spacing:.34em;
  }

  .heroScrollArrow{
    width:38px;
    height:38px;
  }

  .heroWordmark{
    opacity:clamp(0,calc((var(--hero-progress,0) - .14) * 3.2),1);
    transform:translateY(calc(28px - (var(--hero-progress,0) * 20px)));
    inset:auto 0 14vh;
    gap:12px;
    transition:opacity .55s ease, transform .65s cubic-bezier(.22,.61,.36,1);
  }

  .heroTitle{
    font-size:clamp(36px,11.2vw,70px);
  }

  .heroStudio{
    font-size:10px;
    letter-spacing:.5em;
  }

  .heroSubtitle{
    font-size:9px;
    line-height:1.9;
  }

  .heroSceneWords{
    display:none;
  }

  .galleryFlow{
    padding-top:0;
    margin-top:0;
  }

  .flowLead{
    margin-bottom:22px;
  }

  .flowCards{
    grid-template-columns:1fr;
    gap:22px;
    margin-top:0;
  }

  .flowCard{
    border-radius:24px;
  }

  .flowCard img{
    aspect-ratio:4/5.25;
  }

  .flowCardMeta{
    left:12px;
    right:12px;
    bottom:12px;
    padding:12px 14px;
    border-radius:18px;
  }

  .detailPage{
    padding-top:102px;
  }

  .detailPanel{
    grid-template-columns:1fr 1fr;
    padding:16px;
  }

  .infoShell{
    padding:20px 14px 18px;
  }

  .dash{
    grid-template-columns:1fr;
  }

  th,td{
    padding:12px 8px;
  }

  .musicDock{
    left:12px;
    bottom:14px;
    max-width:72px;
    padding:10px;
    border-radius:999px;
    justify-content:center;
  }

  .musicMeta,
  .musicVolume,
  .musicNext{
    display:none;
  }

  .musicToggle,
  .musicDisc{
    width:52px;
    height:52px;
  }
}

/* ── Mobile music mini popup ─────────────────────────────────── */
.musicMiniPop{display:none;}
.musicPanelOverlay{display:none;}

@keyframes miniPopIn{
  from{opacity:0;transform:translateY(10px) scale(.92)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes miniPopOut{
  from{opacity:1;transform:translateY(0) scale(1)}
  to{opacity:0;transform:translateY(8px) scale(.92)}
}

@media(max-width:600px){
  .musicMiniPop{
    display:none;
    position:fixed;
    bottom:82px;
    left:12px;
    z-index:68;
    background:rgba(14,14,14,.96);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border:1px solid rgba(236,242,182,.14);
    border-radius:14px;
    padding:8px;
  }
  .musicMiniPop.is-open{
    display:flex;
    animation:miniPopIn .22s cubic-bezier(.16,1,.3,1) both;
  }
  .musicMiniPop.is-closing{
    display:flex;
    animation:miniPopOut .16s ease-in both;
  }
  .musicMiniPop.is-open,
  .musicMiniPop.is-closing{
    flex-direction:row;
    gap:8px;
    align-items:center;
  }
  .musicMiniPlay{
    width:40px;height:40px;
    padding:0;
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
  }
  .musicMiniPlay .miniPauseIcon{ display:none; }
  .musicMiniPop.is-playing .miniPlayIcon{ display:none; }
  .musicMiniPop.is-playing .miniPauseIcon{ display:block; }
  .musicMiniNext{
    font-size:11px;
    letter-spacing:.22em;
    padding:9px 22px;
    border-radius:10px;
  }
  .musicPanelOverlay{
    display:block;
    position:fixed;
    inset:0;
    z-index:67;
    pointer-events:none;
  }
  .musicPanelOverlay.is-active{
    pointer-events:auto;
  }
}

.footerTopButton{
  position:fixed;
  right:24px;
  bottom:18px;
  top:auto;
  transform:none;
  width:54px;
  height:54px;
  border-radius:999px;
  border:1px solid rgba(236,242,182,.26);
  background:rgba(7,7,7,.84);
  display:grid;
  place-items:center;
  color:var(--accent);
  box-shadow:0 18px 42px rgba(0,0,0,.34);
  cursor:pointer;
  transition:transform .35s ease,border-color .35s ease,opacity .35s ease,bottom .2s ease;
  opacity:0;
  pointer-events:none;
  z-index:70;
}

.footerTopButton.is-visible{
  opacity:1;
  pointer-events:auto;
}

.footerTopButton:hover{
  transform:translateY(-3px);
  border-color:rgba(236,242,182,.46);
}

.footerTopButton span{
  position:relative;
  display:block;
  width:16px;
  height:16px;
}

.footerTopButton span:before,
.footerTopButton span:after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  transform-origin:center;
}

.footerTopButton span:before{
  width:1px;
  height:14px;
  background:var(--accent);
  transform:translate(-50%,-42%);
}

.footerTopButton span:after{
  width:9px;
  height:9px;
  border-left:1px solid var(--accent);
  border-top:1px solid var(--accent);
  transform:translate(-50%,-32%) rotate(45deg);
}

.archiveLeadActions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.lightboxOverlay{
  position:fixed;
  inset:0;
  z-index:120;
  background:rgba(5,5,5,.92);
  display:grid;
  place-items:center;
  padding:28px;
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease;
}

.lightboxOverlay.is-open{
  opacity:1;
  pointer-events:auto;
}

.lightboxImage{
  max-width:min(94vw,1600px);
  max-height:90vh;
  object-fit:contain;
  box-shadow:0 28px 70px rgba(0,0,0,.45);
}

.lightboxClose{
  position:absolute;
  right:18px;
  top:18px;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(10,10,10,.66);
  color:var(--text);
  font-size:20px;
}

@media (max-width:640px){
  .lightboxOverlay{
    padding:16px;
  }

  .detailZoomHint{
    right:12px;
    bottom:12px;
    font-size:9px;
    letter-spacing:.18em;
    padding:8px 10px;
  }
}
.pageSection{padding:0 0 72px}
.aboutPageGrid{display:grid;gap:22px}
.aboutBodyCard{padding:22px;border-radius:26px;background:rgba(255,255,255,.02);border:1px solid var(--line)}
.aboutBodyCard p{margin:0;color:#d4d5ce;line-height:1.9;font-size:15px}
.singleAboutVisual img{width:100%;border-radius:28px;border:1px solid var(--line);box-shadow:var(--shadow);max-height:76vh;object-fit:cover}
.carouselShell{position:relative;border-radius:28px;overflow:hidden;border:1px solid var(--line);background:#0c0c0c;box-shadow:var(--shadow)}
.carouselViewport{overflow:hidden}
.carouselTrack{display:flex;transition:transform .45s ease}
.carouselSlide{min-width:100%}
.carouselSlide img{width:100%;max-height:78vh;object-fit:cover;display:block}
.carouselNav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:rgba(7,7,7,.72);color:var(--text);font-size:28px;display:grid;place-items:center;z-index:4}
.carouselNav.prev{left:14px}.carouselNav.next{right:14px}
.referencesGrid{padding-bottom:72px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.referenceCard{display:block;border-radius:26px;overflow:hidden;border:1px solid var(--line);background:rgba(255,255,255,.02);box-shadow:var(--shadow);transition:transform .65s cubic-bezier(.16,1,.3,1),border-color .4s ease,box-shadow .65s cubic-bezier(.16,1,.3,1)}
.referenceCard:hover{transform:translateY(-8px) scale(1.012);border-color:var(--line-strong);box-shadow:0 40px 80px rgba(0,0,0,.55)}
.referenceCardImage{aspect-ratio:4/4.7;background:#0b0b0b}.referenceCardImage img{width:100%;height:100%;object-fit:cover}
.referenceCardBody{display:grid;gap:8px;padding:16px}.referenceCardBody small{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.referenceCardBody strong{font-size:18px;font-weight:500}.referenceCardBody span{color:#d4d5ce;font-size:14px}
.adminThumbStrip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}
.adminThumbCard{padding:10px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.02);display:grid;gap:8px}
.adminThumbCard img{width:100%;height:140px;object-fit:cover;border-radius:12px}
@media (max-width:1100px){.referencesGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.referencesGrid,.adminThumbStrip{grid-template-columns:1fr}.carouselNav{width:40px;height:40px;font-size:24px}.pageSection{padding-bottom:54px}}
@media (max-width:640px){
  .archiveLead{padding-top:96px}
  .archiveLeadActions{justify-content:flex-start}
  .detailPanel{grid-template-columns:1fr}
  .detailRelatedWrap{padding-top:32px}
  .footerBrand{gap:10px}
  .footerBrand img{width:56px;height:56px}
  .footerActions{gap:10px}
}
