:root {
  --bg: #0b0b0b;
  --fg: #e6e1d8;
  --dim: #4a4a4a;
  --dimmer: #2a2a2a;
  --neon: #b8f400;
  --neon-lo: rgba(184,244,0,0.07);
  --hot: #ff2d2d;
  --display: 'Syne', sans-serif;
  --mono: 'Inconsolata', monospace;
  --serif: 'Instrument Serif', serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--mono);
  overflow-x: hidden;
}
::selection { background: var(--neon); color: var(--bg); }
a { color: inherit; text-decoration: none; }

/* RTL */
body.rtl { direction: rtl; }
body.rtl .opening-right { text-align: left; }
body.rtl .drop-row-status { text-align: left; }
body.rtl .foot-right { text-align: left; }
body.rtl .drop-row:hover { padding-left: 0; padding-right: 16px; }
body.rtl .nav { right: auto; left: 0; }
body.rtl .flip-corner { right: auto; left: 48px; }

/* GRAIN */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 10000;
}

/* LANG SWITCHER */
.lang-switcher { position: relative; }
.lang-current {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--dim);
  background: none;
  border: 1px solid var(--dimmer);
  padding: 4px 10px;
  cursor: pointer;
  transition: all 0.3s;
}
.lang-current:hover { color: var(--fg); border-color: var(--dim); }
.lang-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 8px;
  background: var(--bg);
  border: 1px solid var(--dimmer);
  min-width: 180px;
  z-index: 10001;
}
body.rtl .lang-dropdown { right: auto; left: 0; }
.lang-dropdown.open { display: block; }
.lang-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--dim);
  letter-spacing: 0.1em;
  transition: all 0.2s;
  cursor: pointer;
}
.lang-option:hover { background: var(--neon-lo); color: var(--fg); }
.lang-option.active { color: var(--neon); }
.lang-option span { opacity: 0.5; font-size: 10px; }

/* NAV */
.nav {
  position: fixed;
  top: 0; right: 0;
  z-index: 9999;
  padding: 24px 32px;
  display: flex;
  gap: 24px;
  align-items: center;
}
.nav a {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--dim);
  transition: color 0.4s;
}
.nav a:hover { color: var(--fg); }

/* OPENING */
.opening {
  height: 100vh;
  display: grid;
  grid-template-rows: 1fr auto;
  padding: 0 48px 48px;
  position: relative;
}
.opening-center {
  display: flex;
  align-items: center;
  justify-content: center;
}
.opening-mark {
  font-family: 'Jura', sans-serif;
  font-weight: 500;
  font-size: clamp(60px, 28vw, 460px);
  line-height: 0.85;
  letter-spacing: -0.01em;
  color: var(--fg);
  position: relative;
  cursor: default;
  user-select: none;
  white-space: nowrap;
  animation: landIn 1.2s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.opening-mark .esc {
  color: var(--neon);
  display: inline-block;
  animation: escBlink 4s ease-in-out infinite 2s;
}
.opening-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  opacity: 0;
  animation: fadeIn 1s ease-out 1.5s both;
}
.opening-left {
  font-size: 11px;
  color: var(--dim);
  letter-spacing: 0.1em;
  line-height: 1.8;
}
.opening-right {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(16px, 2vw, 22px);
  color: var(--dim);
  max-width: 380px;
  text-align: right;
  line-height: 1.5;
}

/* FLIP */
.flip {
  min-height: 100vh;
  background: var(--neon);
  background-image: radial-gradient(circle, rgba(0,0,0,0.12) 0.8px, transparent 0.8px);
  background-size: 20px 20px;
  color: var(--bg);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 80px 48px;
  position: relative;
  overflow: hidden;
}
.flip-big {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(24px, 4.5vw, 65px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  max-width: 1100px;
  margin-bottom: 48px;
}
.flip-origin-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  opacity: 0.4;
  margin-bottom: 12px;
}
.flip-small {
  font-family: var(--mono);
  font-size: 13px;
  line-height: 2;
  max-width: 520px;
  opacity: 0.6;
  cursor: pointer;
  transition: opacity 0.3s;
}
.flip-small:hover { opacity: 1; }
.flip-small-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-bottom: 1px solid currentColor;
  opacity: 0;
  transition: opacity 0.4s;
}
.flip-small:hover .flip-small-link { opacity: 0.6; }
.flip-corner {
  position: absolute;
  bottom: 48px;
  right: 48px;
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(100px, 15vw, 250px);
  opacity: 0.08;
  line-height: 1;
  user-select: none;
}

/* DROPS */
.drops { padding: 120px 48px; }
.drop-row {
  border-top: 1px solid var(--dimmer);
  padding: 40px 0;
  display: grid;
  grid-template-columns: 200px 1fr 120px;
  gap: 40px;
  align-items: start;
  cursor: pointer;
  transition: all 0.4s;
}
.drop-row:last-child { border-bottom: 1px solid var(--dimmer); }
.drop-row:hover { padding-left: 16px; border-color: var(--dim); }
.drop-row-coming { cursor: default; opacity: 0.5; }
.drop-row-coming:hover { padding-left: 0; border-color: var(--dimmer); }
.drop-row-coming:hover .drop-row-name { color: inherit; }
.drop-row-coming:hover .drop-row-desc { color: var(--dim); }
.drop-row:hover .drop-row-name { color: var(--neon); }
.drop-row-name {
  font-family: var(--display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.01em;
  transition: color 0.4s;
}
.drop-row-name span { color: var(--neon); }
.drop-row-desc {
  font-family: var(--serif);
  font-style: italic;
  font-size: 17px;
  line-height: 1.6;
  color: var(--dim);
  transition: color 0.4s;
}
.drop-row:hover .drop-row-desc { color: var(--fg); }
.drop-row-status {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--dim);
  text-align: right;
  padding-top: 6px;
}
.drop-row-status.live { color: var(--neon); }

/* JACKET */
.jacket {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 80vh;
}
.jacket-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 80px 48px;
  text-align: center;
  transition: all 0.6s;
  cursor: default;
}
.jacket-outside { background: var(--fg); color: var(--bg); }
.jacket-inside { background: var(--bg); color: var(--fg); }
.jacket-symbol {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(80px, 12vw, 180px);
  line-height: 1;
  margin-bottom: 32px;
}
.jacket-inside .jacket-symbol { color: var(--neon); }
.jacket-time {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  opacity: 0.4;
  margin-bottom: 24px;
}
.jacket-list {
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  line-height: 2.2;
  opacity: 0.6;
}

/* OBJECTS */
.objects { padding: 120px 48px; }
.objects-title {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(48px, 8vw, 120px);
  letter-spacing: -0.03em;
  line-height: 1;
  margin-bottom: 64px;
}
.objects-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2px;
}
.obj {
  aspect-ratio: 1;
  border: 1px solid var(--dimmer);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.4s;
  position: relative;
}
.obj:hover { border-color: var(--neon); background: var(--neon-lo); }
.obj-mark {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(24px, 3vw, 44px);
  transition: color 0.4s;
}
.obj:hover .obj-mark { color: var(--neon); }
.obj-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--dim);
  margin-top: 12px;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity 0.4s;
}
.obj:hover .obj-label { opacity: 1; }

/* HIDDEN THING */
.hidden-thing { padding: 60px 48px; display: flex; justify-content: center; }
.hidden-thing-box {
  max-width: 600px;
  text-align: center;
  border: 1px dashed transparent;
  padding: 60px;
  transition: border-color 3s ease;
}
.hidden-thing-box:hover { border-color: var(--dimmer); }
.hidden-thing-box p {
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  line-height: 2;
  color: var(--bg);
  transition: color 5s ease;
}
.hidden-thing-box:hover p { color: var(--dim); }

/* CAPTURE */
.capture {
  padding: 120px 48px;
  background: var(--hot);
  color: var(--fg);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.capture-title {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(32px, 6vw, 80px);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: 20px;
  max-width: 700px;
}
.capture-sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: 17px;
  opacity: 0.7;
  margin-bottom: 48px;
  max-width: 400px;
  line-height: 1.6;
}
.capture-form { display: flex; gap: 0; width: 100%; max-width: 460px; }
.capture-input {
  flex: 1;
  font-family: var(--mono);
  font-size: 13px;
  padding: 18px 20px;
  border: 2px solid var(--fg);
  background: transparent;
  color: var(--fg);
  outline: none;
}
.capture-input::placeholder { color: rgba(230,225,216,0.4); }
.capture-btn {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: 14px;
  padding: 18px 28px;
  border: 2px solid var(--fg);
  border-left: none;
  background: var(--fg);
  color: var(--hot);
  cursor: pointer;
  transition: all 0.3s;
  letter-spacing: 0.05em;
}
.capture-btn:hover { background: var(--bg); color: var(--fg); border-color: var(--bg); }
.capture-note {
  margin-top: 20px;
  font-family: var(--mono);
  font-size: 10px;
  opacity: 0.4;
  letter-spacing: 0.05em;
}

/* FOOTER */
footer {
  padding: 48px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  border-top: 1px solid var(--dimmer);
}
.foot-left {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--dim);
  line-height: 2;
  letter-spacing: 0.05em;
}
.foot-left strong {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: var(--fg);
  display: block;
  margin-bottom: 8px;
}
.foot-left strong span { color: var(--neon); }
.foot-right {
  text-align: right;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--dim);
  line-height: 2;
  letter-spacing: 0.05em;
}
.foot-right a { display: block; transition: color 0.3s; }
.foot-right a:hover { color: var(--neon); }

/* TERMS LINK */
.terms-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 9px;
  letter-spacing: 0.1em;
  color: var(--dim);
  transition: color 0.3s;
}
.terms-link:hover { color: var(--neon); }

/* GLITCH */
.glitch { position: relative; display: inline-block; cursor: default; animation: glitchTrigger 6s infinite; }
.glitch::before, .glitch::after { content: attr(data-text); position: absolute; top: 0; left: 0; width: 100%; overflow: hidden; opacity: 0; }
.glitch::before { color: var(--neon); animation: glitchTop 6s infinite; }
.glitch::after { color: var(--hot); animation: glitchBottom 6s infinite; }
.flip .glitch::before { color: var(--bg); }
.flip .glitch::after { color: var(--hot); }
.glitch:hover { animation: glitchHoverTrigger 0.3s steps(2) infinite; }
.glitch:hover::before { animation: glitchHoverTop 0.3s steps(2) infinite; }
.glitch:hover::after { animation: glitchHoverBottom 0.3s steps(2) infinite; }

@keyframes glitchTrigger { 0%,90%,100%{transform:none}92%{transform:skewX(-2deg)}94%{transform:skewX(3deg)}96%{transform:skewX(-1deg)}98%{transform:none} }
@keyframes glitchTop { 0%,90%,100%{opacity:0;clip-path:none}91%{opacity:.8;clip-path:inset(0 0 60% 0);transform:translateX(-4px)}93%{opacity:.8;clip-path:inset(0 0 40% 0);transform:translateX(3px)}95%{opacity:.8;clip-path:inset(20% 0 50% 0);transform:translateX(-2px)}97%{opacity:0} }
@keyframes glitchBottom { 0%,90%,100%{opacity:0;clip-path:none}92%{opacity:.8;clip-path:inset(60% 0 0 0);transform:translateX(4px)}94%{opacity:.8;clip-path:inset(50% 0 0 0);transform:translateX(-3px)}96%{opacity:.8;clip-path:inset(40% 0 0 0);transform:translateX(2px)}98%{opacity:0} }
@keyframes glitchHoverTrigger { 0%{transform:skewX(-3deg)}50%{transform:skewX(2deg)}100%{transform:skewX(-1deg)} }
@keyframes glitchHoverTop { 0%{opacity:.8;clip-path:inset(0 0 55% 0);transform:translateX(-5px)}50%{opacity:.8;clip-path:inset(10% 0 40% 0);transform:translateX(4px)}100%{opacity:.8;clip-path:inset(0 0 60% 0);transform:translateX(-3px)} }
@keyframes glitchHoverBottom { 0%{opacity:.8;clip-path:inset(55% 0 0 0);transform:translateX(5px)}50%{opacity:.8;clip-path:inset(45% 0 0 0);transform:translateX(-4px)}100%{opacity:.8;clip-path:inset(50% 0 0 0);transform:translateX(3px)} }

@keyframes landIn { 0%{opacity:0;transform:translateY(60px) scale(.95)}100%{opacity:1;transform:translateY(0) scale(1)} }
@keyframes fadeIn { from{opacity:0}to{opacity:1} }
@keyframes escBlink { 0%,100%{opacity:1}50%{opacity:.3} }

.reveal { opacity: 0; transform: translateY(30px); transition: all 0.7s cubic-bezier(0.22, 1, 0.36, 1); }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* === STORY PAGE === */
.story-page { min-height: 100vh; padding: 0; }
.story-hero {
  min-height: 60vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 80px 48px;
  background: var(--neon);
  color: var(--bg);
  position: relative;
  overflow: hidden;
}
.story-hero-bg {
  position: absolute;
  inset: 0;
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: 30vw;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.06;
  user-select: none;
}
.story-hero-intro {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(14px, 1.5vw, 18px);
  color: rgba(0,0,0,0.5);
  margin-bottom: 20px;
  position: relative;
}
.story-hero-category {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  opacity: 0.5;
  margin-bottom: 16px;
  position: relative;
}
.story-hero-title {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 5vw, 56px);
  line-height: 1.15;
  max-width: 900px;
  position: relative;
}
.story-hero-hook {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(16px, 2vw, 20px);
  line-height: 1.6;
  max-width: 700px;
  margin-top: 24px;
  opacity: 0.7;
  position: relative;
}

.story-content { padding: 80px 48px; max-width: 900px; margin: 0 auto; }

.story-chapter { margin-bottom: 80px; }
.story-chapter-num {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--neon);
  text-transform: uppercase;
  margin-bottom: 16px;
}
.story-chapter-heading {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(22px, 3vw, 36px);
  line-height: 1.2;
  margin-bottom: 24px;
}
.story-chapter-text {
  font-family: var(--serif);
  font-size: 18px;
  line-height: 2;
  color: rgba(230,225,216,0.8);
}
.story-chapter-text p { margin-bottom: 20px; }

.story-image-real {
  width: 100%;
  aspect-ratio: 16/9;
  margin: 32px 0;
  border-radius: 4px;
  overflow: hidden;
}
.story-image-real img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.45) saturate(0.8);
  transition: filter 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.story-image-real:hover img {
  filter: brightness(1) saturate(1);
}
.story-image-real.story-image-wide { aspect-ratio: 21/9; }
.story-image-real.story-image-square { aspect-ratio: 1; max-width: 400px; margin-left: auto; margin-right: auto; }

.story-image-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: var(--dimmer);
  border: 1px dashed var(--dim);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 32px 0;
  border-radius: 4px;
}
.story-image-placeholder span {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--dim);
  letter-spacing: 0.1em;
  text-align: center;
  padding: 20px;
}

.story-image-wide { aspect-ratio: 21/9; }
.story-image-square { aspect-ratio: 1; max-width: 400px; margin-left: auto; margin-right: auto; }

.story-pullquote {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(20px, 3vw, 32px);
  line-height: 1.3;
  color: var(--neon);
  border-left: 3px solid var(--neon);
  padding-left: 24px;
  margin: 48px 0;
}

.story-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--dim);
  padding: 48px 0;
  transition: color 0.3s;
}
.story-back:hover { color: var(--neon); }

/* === TERMS PAGE === */
.terms-page { min-height: 100vh; padding: 120px 48px 80px; max-width: 800px; margin: 0 auto; }
.terms-page h1 {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 4vw, 48px);
  margin-bottom: 8px;
}
.terms-page .terms-updated {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--dim);
  letter-spacing: 0.1em;
  margin-bottom: 48px;
}
.terms-page h2 {
  font-family: 'Jura', sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: var(--neon);
  margin: 40px 0 16px;
}
.terms-page p, .terms-page li {
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.8;
  color: rgba(230,225,216,0.7);
  margin-bottom: 12px;
}
.terms-page ul { padding-left: 24px; }
body.rtl .terms-page ul { padding-left: 0; padding-right: 24px; }

/* RESPONSIVE */
@media (max-width: 800px) {
  .opening { padding: 0 24px 24px; }
  .opening-bottom { flex-direction: column; gap: 20px; align-items: flex-start; }
  .opening-right { text-align: left; }
  .flip { padding: 60px 24px; }
  .drops { padding: 60px 24px; }
  .drop-row { grid-template-columns: 1fr; gap: 12px; }
  .drop-row-status { text-align: left; }
  .jacket { grid-template-columns: 1fr; }
  .objects { padding: 60px 24px; }
  .objects-row { grid-template-columns: repeat(3, 1fr); }
  .hidden-thing { padding: 80px 24px; }
  .capture { padding: 80px 24px; }
  .capture-form { flex-direction: column; }
  .capture-btn { border-left: 2px solid var(--fg); border-top: none; }
  footer { flex-direction: column; gap: 24px; align-items: flex-start; padding: 32px 24px; }
  .foot-right { text-align: left; }
  .nav { padding: 16px 24px; }
  .story-hero { padding: 60px 24px; min-height: 50vh; }
  .story-content { padding: 48px 24px; }
  .terms-page { padding: 80px 24px 48px; }
}
