﻿/* Exotaria Â· India layer â€” premium dark, high-contrast, saturated.
   Overrides main.css.
   ============================================================ */
:root {
  /* Warm-black canvas, not pitch â€” has saffron/brown undertone */
  --c-bg: #0E0906;
  --c-bg-2: #18110C;
  --c-bg-3: #221912;
  --c-bg-4: #2D2218;

  /* Text â€” pushed brighter than before for contrast */
  --c-bone: #F6EAD0;
  --c-bone-dim: #C9B89A;
  --c-mute: #8E7B5F;
  --c-line: #3A2E22;
  --c-line-soft: #2A2018;

  /* Saturated accents */
  --c-saffron: #FF8B1F;
  --c-marigold: #FFB243;
  --c-maroon: #C72D3E;
  --c-peacock: #2BB5C8;
  --c-gold: #E8B548;
  --c-india-green: #3DA84A;
  --c-ivory: #F6EAD0;

  --c-copper: var(--c-saffron);
  --c-copper-soft: var(--c-marigold);
  --c-blood: var(--c-maroon);
  --c-moss: var(--c-peacock);
}

/* -------- Base canvas + subtle vignette + grain -------- */
html, body { background: var(--c-bg); color: var(--c-bone); }
body {
  background:
    radial-gradient(900px 600px at 78% 8%, rgba(255,139,31,0.16), transparent 55%),
    radial-gradient(700px 500px at 5% 95%, rgba(43,181,200,0.10), transparent 60%),
    radial-gradient(circle at 50% 50%, transparent 40%, rgba(0,0,0,0.55) 100%),
    var(--c-bg);
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.96 0 0 0 0 0.91 0 0 0 0 0.81 0 0 0 0.045 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: overlay;
  opacity: 0.5;
}
::selection { background: var(--c-saffron); color: var(--c-bg); }

/* -------- Cursor: warm ivory on dark -------- */
.cursor {
  background: var(--c-marigold);
  mix-blend-mode: normal;
  box-shadow: 0 0 12px var(--c-saffron);
}
.cursor.is-hover { background: var(--c-saffron); box-shadow: 0 0 18px var(--c-saffron); }
.cursor-ring { border-color: rgba(246,234,208,0.45); }
.cursor-ring.is-hover { border-color: var(--c-saffron); }

/* -------- Nav -------- */
.nav { padding: 26px var(--rail); }
.nav.is-scrolled {
  background: rgba(14,9,6,0.86);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border-bottom: 1px solid var(--c-line);
  padding: 16px var(--rail);
}
.nav-logo {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: 20px;
  letter-spacing: 0.32em;
  color: var(--c-bone);
}
.nav-logo span { color: var(--c-saffron); font-weight: 400; }
.nav-links a {
  color: var(--c-bone-dim);
  font-weight: 400;
}
.nav-links a:hover, .nav-links a.is-active { color: var(--c-bone); }
.nav-links a::after { background: var(--c-saffron); }
.cart-button {
  border-color: var(--c-line);
  color: var(--c-bone);
  font-weight: 400;
}
.cart-button:hover {
  border-color: var(--c-saffron);
  background: rgba(255,139,31,0.08);
}
.cart-button .dot {
  background: var(--c-saffron);
  box-shadow: 0 0 12px var(--c-saffron);
}

/* -------- Typography refinements -------- */
.display { font-weight: 300; letter-spacing: -0.02em; }
.display em {
  font-family: "Fraunces", serif;
  font-style: italic;
  font-weight: 400;
  color: var(--c-saffron);
}
.devanagari { font-family: "Tiro Devanagari Hindi", "Fraunces", serif; }
.eyebrow {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--c-bone-dim);
}
.kicker {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--c-saffron);
}

/* -------- HERO: cinematic, model-dominant -------- */
.hero {
  position: relative;
  min-height: 100vh;
  padding: 0;
  display: block;
  overflow: hidden;
}
.hero-bg, .hero-marquee, .hero-figure { display: none; }
.hero-stage {
  position: relative;
  height: 100vh;
  min-height: 720px;
  width: 100%;
}
.hero-stage canvas {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  cursor: grab;
  z-index: 1;
}
.hero-stage canvas:active { cursor: grabbing; }

/* radial glow stage lighting that pulses with the model */
.hero-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 50% 55%, rgba(255,139,31,0.22) 0%, rgba(255,139,31,0.08) 35%, transparent 65%),
    radial-gradient(40% 35% at 80% 30%, rgba(199,45,62,0.16) 0%, transparent 55%),
    radial-gradient(35% 30% at 15% 75%, rgba(43,181,200,0.14) 0%, transparent 60%);
  z-index: 0;
  pointer-events: none;
  animation: stage-breath 8s ease-in-out infinite alternate;
}
@keyframes stage-breath {
  0%   { opacity: 0.85; transform: scale(1); }
  100% { opacity: 1; transform: scale(1.06); }
}

/* corner field-guide ticks */
.hero-stage::after {
  content: "";
  position: absolute;
  inset: 60px var(--rail);
  border: 1px solid transparent;
  background:
    linear-gradient(to right, rgba(246,234,208,0.18) 28px, transparent 28px) top left / 100% 1px no-repeat,
    linear-gradient(to right, rgba(246,234,208,0.18) 28px, transparent 28px) bottom left / 100% 1px no-repeat,
    linear-gradient(to bottom, rgba(246,234,208,0.18) 28px, transparent 28px) top left / 1px 100% no-repeat,
    linear-gradient(to bottom, rgba(246,234,208,0.18) 28px, transparent 28px) top right / 1px 100% no-repeat,
    linear-gradient(to left, rgba(246,234,208,0.18) 28px, transparent 28px) top right / 100% 1px no-repeat,
    linear-gradient(to left, rgba(246,234,208,0.18) 28px, transparent 28px) bottom right / 100% 1px no-repeat,
    linear-gradient(to bottom, rgba(246,234,208,0.18) 28px, transparent 28px) bottom left / 1px 100% no-repeat,
    linear-gradient(to bottom, rgba(246,234,208,0.18) 28px, transparent 28px) bottom right / 1px 100% no-repeat;
  pointer-events: none;
  z-index: 2;
}

/* hero text overlays */
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: 120px var(--rail) 60px;
}
.hero-overlay > * { pointer-events: auto; }
.hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 32px;
}
.hero-top-meta {
  text-align: right;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--c-bone-dim);
  line-height: 1.8;
}
.hero-top-meta b { color: var(--c-saffron); font-weight: 500; display: block; }

.hero-center {
  align-self: end;
  max-width: 760px;
}
.hero-center .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px;
}
.hero-center .eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--c-saffron);
  display: inline-block;
}
.hero h1 {
  font-size: clamp(64px, 11vw, 192px);
  line-height: 0.92;
  margin: 0;
  font-weight: 300;
  letter-spacing: -0.03em;
}
.hero h1 .line { display: block; overflow: hidden; }
.hero h1 .line > span { display: block; transform: translateY(110%); }
.hero-sub {
  margin-top: 36px;
  max-width: 520px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--c-bone);
}
.hero-sub b { color: var(--c-saffron); font-weight: 500; }

.hero-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  flex-wrap: wrap;
}
.hero-cta { display: flex; gap: 14px; }
.hero-scroll {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--c-bone-dim);
}
.hero-scroll i {
  display: inline-block;
  width: 32px; height: 1px;
  background: var(--c-saffron);
  animation: scroll-arrow 2.4s ease-in-out infinite;
  transform-origin: left center;
}
@keyframes scroll-arrow {
  0%, 100% { transform: scaleX(0.3); }
  50%      { transform: scaleX(1); }
}

/* 3D loader chrome */
.snake-stage-loader {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 16px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--c-bone-dim);
  pointer-events: none;
  transition: opacity .8s var(--ease);
  z-index: 4;
}
.hero-stage.loaded .snake-stage-loader,
.snake-stage.loaded .snake-stage-loader { opacity: 0; }
.snake-stage-loader .bar {
  width: 180px;
  height: 1px;
  background: var(--c-line);
  position: relative;
  overflow: hidden;
}
.snake-stage-loader .bar i {
  position: absolute;
  inset: 0;
  background: var(--c-saffron);
  transform-origin: left;
  transform: scaleX(0);
  transition: transform .4s linear;
}
.snake-stage-loader .err { color: var(--c-maroon); }

@media (max-width: 980px) {
  .hero-stage { min-height: 580px; }
  .hero h1 { font-size: clamp(56px, 14vw, 100px); }
  .hero-overlay { padding: 100px var(--rail) 40px; }
  .hero-top-meta { display: none; }
  .hero-bottom { flex-direction: column; align-items: flex-start; }
}

/* -------- Section chrome -------- */
.section { padding: 120px 0; position: relative; z-index: 2; }
.section-head { margin-bottom: 60px; }
.section-title { font-size: clamp(40px, 6vw, 84px); }
.section-lead { color: var(--c-bone); }

/* -------- Cards -------- */
.grid { background: var(--c-line); border-color: var(--c-line); }
.card {
  background: var(--c-bg-2);
  min-height: 480px;
  transition: background .5s var(--ease), transform .5s var(--ease);
}
.card:hover { background: var(--c-bg-3); }
.card::before {
  background: radial-gradient(60% 50% at 50% 40%, rgba(255,139,31,0.20), transparent 65%);
}
.card-head { color: var(--c-bone-dim); }
.card-tag {
  color: var(--c-saffron);
  border-color: var(--c-saffron);
  background: rgba(255,139,31,0.06);
}
.card-name { color: var(--c-bone); }
.card-morph { color: var(--c-bone-dim); font-style: italic; }
.card-price { color: var(--c-bone); }
.card-price small { color: var(--c-bone-dim); }
.card:hover .card-name { color: var(--c-marigold); }

.card-art {
  background:
    repeating-linear-gradient(45deg, rgba(255,139,31,0.04) 0 2px, transparent 2px 14px),
    var(--c-bg-3);
  border: 1px solid var(--c-line);
  border-radius: 4px;
  overflow: hidden;
}
.card-art .plate-frame {
  border: 0;
  background: linear-gradient(135deg, rgba(255,139,31,0.06), transparent 55%);
}

/* -------- Buttons -------- */
.btn {
  background: var(--c-saffron);
  color: var(--c-bg);
  font-weight: 500;
  letter-spacing: 0.14em;
}
.btn::before { background: var(--c-marigold); }
.btn:hover { color: var(--c-bg); }
.btn.ghost {
  background: transparent;
  color: var(--c-bone);
  border: 1px solid var(--c-bone);
}
.btn.ghost::before { background: var(--c-bone); }
.btn.ghost:hover { color: var(--c-bg); }

/* -------- Promise strip -------- */
.promise {
  background: var(--c-line);
  border-color: var(--c-line);
}
.promise > div { background: var(--c-bg-2); }
.promise .num { color: var(--c-saffron); }
.promise h3 { color: var(--c-bone); }
.promise p { color: var(--c-bone-dim); }

/* -------- Split sections -------- */
.split-text h2 { color: var(--c-bone); }
.split-text p { color: var(--c-bone-dim); }
.split-figure {
  border-color: var(--c-line);
  background:
    repeating-linear-gradient(45deg, rgba(255,139,31,0.04) 0 2px, transparent 2px 14px),
    var(--c-bg-2);
}

/* -------- Footer -------- */
footer {
  background: var(--c-bg-2);
  border-top: 1px solid var(--c-line);
  color: var(--c-bone);
  position: relative;
  z-index: 2;
}
.foot-grid h4 {
  color: var(--c-saffron);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.28em;
}
.foot-grid a { color: var(--c-bone); }
.foot-grid a:hover { color: var(--c-saffron); }
.foot-brand p { color: var(--c-bone-dim); }
.foot-brand .display em { color: var(--c-saffron); }
.foot-bottom { color: var(--c-bone-dim); border-color: var(--c-line); }

/* -------- Cart drawer -------- */
.drawer {
  background: var(--c-bg-2);
  border-color: var(--c-line);
}
.drawer-head, .drawer-foot, .drawer-item { border-color: var(--c-line); }
.drawer-head h3 { color: var(--c-bone); }
.drawer-close { border-color: var(--c-line); color: var(--c-bone); }
.drawer-close:hover { border-color: var(--c-saffron); background: rgba(255,139,31,0.1); }
.drawer-empty .display { color: var(--c-bone); }
.drawer-empty p { color: var(--c-bone-dim); }
.drawer-item .mini-plate { border-color: var(--c-line); background: var(--c-bg-3); }
.drawer-item .name { color: var(--c-bone); }
.drawer-item .morph { color: var(--c-bone-dim); }
.drawer-item .price { color: var(--c-bone); }
.drawer-item .remove { color: var(--c-bone-dim); }
.drawer-item .remove:hover { color: var(--c-maroon); }
.drawer-total { color: var(--c-bone-dim); }
.drawer-total.grand b { color: var(--c-bone); }
.drawer-scrim { background: rgba(0,0,0,0.7); }

/* -------- Deposit emphasis -------- */
.deposit-line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 10px 0;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.deposit-line.lead {
  color: var(--c-saffron);
  border-top: 1px solid var(--c-saffron);
  border-bottom: 1px solid var(--c-line);
  padding: 14px 0;
}
.deposit-line.lead b {
  font-family: var(--f-display);
  font-size: 26px;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--c-saffron);
  font-weight: 400;
}
.deposit-line.balance { color: var(--c-bone-dim); font-size: 10px; }
.deposit-note {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-bone-dim);
  margin-top: 10px;
  line-height: 1.8;
}
.deposit-note b { color: var(--c-saffron); font-weight: 500; }

/* -------- Shop / filter chrome -------- */
.shop-head h1 { color: var(--c-bone); }
.shop-head p { color: var(--c-bone-dim); }
.filter-bar {
  background: rgba(14,9,6,0.92);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-color: var(--c-line);
}
.filter-bar .label { color: var(--c-bone-dim); }
.filter-chip { color: var(--c-bone-dim); border-color: var(--c-line); }
.filter-chip:hover { color: var(--c-bone); border-color: var(--c-bone-dim); }
.filter-chip.is-active {
  color: var(--c-bg);
  background: var(--c-saffron);
  border-color: var(--c-saffron);
}
.filter-bar .count { color: var(--c-bone-dim); }

/* -------- Detail page -------- */
.detail-figure {
  background:
    repeating-linear-gradient(45deg, rgba(255,139,31,0.04) 0 2px, transparent 2px 14px),
    var(--c-bg-3);
  border-color: var(--c-line);
}
.detail-figure .plate-tag { color: var(--c-bone-dim); }
.detail-figure .plate-tag b { color: var(--c-saffron); }
.detail-figure .specimen-id { color: var(--c-mute); }
.detail-body .scientific { color: var(--c-marigold); }
.detail-body h1 { color: var(--c-bone); }
.detail-body .morph { color: var(--c-bone-dim); }
.detail-body .bio { color: var(--c-bone); border-bottom-color: var(--c-line); }
.specs { background: var(--c-line); border-color: var(--c-line); }
.specs > div { background: var(--c-bg-2); }
.specs .k { color: var(--c-bone-dim); }
.specs .v { color: var(--c-bone); }
.bars .lab { color: var(--c-bone-dim); }
.bar i { background: var(--c-line); }
.bar i.on { background: var(--c-saffron); }
.detail-price { color: var(--c-bone); }
.detail-price small { color: var(--c-bone-dim); }
.stock-pill { border-color: var(--c-line); color: var(--c-bone-dim); }
.stock-pill .dot { background: var(--c-india-green); box-shadow: 0 0 10px var(--c-india-green); }
.stock-pill.low .dot { background: var(--c-saffron); box-shadow: 0 0 10px var(--c-saffron); }

/* -------- Forms -------- */
.field label { color: var(--c-bone-dim); }
.field input, .field select, .field textarea {
  background: var(--c-bg-2);
  border-color: var(--c-line);
  color: var(--c-bone);
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--c-saffron);
  outline: none;
}
.checkout legend { color: var(--c-saffron); }
.checkout-sum {
  background: var(--c-bg-2);
  border-color: var(--c-line);
}
.checkout-sum h3 { color: var(--c-bone-dim); }
.checkout-totals { border-color: var(--c-line); }

/* -------- Modal (auth) -------- */
.modal-scrim { background: rgba(0,0,0,0.78); }
.modal { background: var(--c-bg-2); border-color: var(--c-line); }
.modal h2 { color: var(--c-bone); }
.modal p.sub, .modal .hint { color: var(--c-bone-dim); }
.modal .hint b { color: var(--c-saffron); }
.modal .auth-tabs { border-color: var(--c-line); }
.modal .auth-tabs button { color: var(--c-bone-dim); }
.modal .auth-tabs button.on { color: var(--c-saffron); border-color: var(--c-saffron); }
.modal .role-pick button {
  color: var(--c-bone-dim);
  border-color: var(--c-line);
}
.modal .role-pick button.on {
  color: var(--c-bg);
  background: var(--c-saffron);
  border-color: var(--c-saffron);
}
.modal-close { border-color: var(--c-line); color: var(--c-bone); }
.modal::before {
  background: linear-gradient(90deg, var(--c-saffron), var(--c-maroon), var(--c-peacock), var(--c-saffron));
}

/* -------- PARIVESH badge / non-venom pill -------- */
.parivesh-badge {
  border-color: var(--c-india-green);
  background: rgba(61,168,74,0.12);
  color: var(--c-bone);
}
.parivesh-badge .seal { background: var(--c-india-green); }
.parivesh-badge b { color: var(--c-india-green); }
.non-venom-pill {
  border-color: var(--c-line);
  color: var(--c-bone-dim);
}
.non-venom-pill::before { background: var(--c-india-green); }

/* -------- Category strip -------- */
.cat-strip {
  border-color: var(--c-line);
  background: var(--c-bg-2);
}
.cat-strip a {
  color: var(--c-bone-dim);
  border-left-color: var(--c-line);
}
.cat-strip a small { color: var(--c-saffron); }
.cat-strip a:hover, .cat-strip a.on {
  color: var(--c-bone);
  background: rgba(255,139,31,0.06);
}
.cat-strip a.on::after { background: var(--c-saffron); }

/* -------- Variation chips -------- */
.var-chip-large { border-color: var(--c-line); background: var(--c-bg-2); }
.var-chip-large.on {
  border-color: var(--c-saffron);
  background: rgba(255,139,31,0.10);
}
.var-chip-large .label { color: var(--c-bone); }
.var-chip-large .v-price { color: var(--c-saffron); }
.var-chip-large .v-stock { color: var(--c-mute); }
.var-chip-large .swatch { background: var(--c-bg); }
.var-chip { border-color: transparent; }
.var-chip.on { border-color: var(--c-saffron); box-shadow: 0 0 12px rgba(255,139,31,0.5); }

/* -------- India tri-ribbon -------- */
.india-strip { height: 3px; position: relative; z-index: 2; }
.india-strip i:nth-child(1) { background: var(--c-saffron); }
.india-strip i:nth-child(2) { background: #F6EAD0; }
.india-strip i:nth-child(3) { background: var(--c-india-green); }

/* -------- Auth nav slot -------- */
.auth-btn { color: var(--c-bone-dim); border-color: var(--c-line); }
.auth-btn:hover { color: var(--c-saffron); border-color: var(--c-saffron); }
.auth-btn .ring { background: var(--c-india-green); box-shadow: 0 0 10px var(--c-india-green); }
.you-pill {
  border-color: var(--c-saffron);
  background: rgba(255,139,31,0.10);
}
.you-pill .av {
  background: linear-gradient(135deg, var(--c-saffron), var(--c-maroon));
  color: var(--c-bg);
}
.you-pill .who-text { color: var(--c-bone); }
.you-pill .who-text small { color: var(--c-saffron); }
.you-pill .logout { border-color: rgba(255,139,31,0.3); color: var(--c-bone-dim); }
.you-pill .logout:hover { color: var(--c-saffron); }

/* -------- Admin -------- */
.admin-side h4 { color: var(--c-saffron); }
.admin-side li button { color: var(--c-bone-dim); }
.admin-side li button:hover { color: var(--c-bone); }
.admin-side li button.on {
  color: var(--c-saffron);
  border-color: var(--c-saffron);
  background: rgba(255,139,31,0.08);
}
.admin-side .who {
  border-color: var(--c-line);
  background: var(--c-bg-2);
  color: var(--c-bone-dim);
}
.admin-side .who b { color: var(--c-saffron); }
.admin-main h1 { color: var(--c-bone); }
.admin-main .sub { color: var(--c-bone-dim); }
.admin-grid { background: var(--c-line); border-color: var(--c-line); }
.admin-grid > div { background: var(--c-bg-2); color: var(--c-bone-dim); }
.admin-grid .kpi b { color: var(--c-saffron); }
.admin-form legend { color: var(--c-saffron); }
.admin-form .upload { border-color: var(--c-line); }
.admin-form .upload:hover { border-color: var(--c-saffron); background: rgba(255,139,31,0.04); }
.admin-form .upload p { color: var(--c-bone-dim); }
.admin-form .upload-prev .pp { background: var(--c-bg-2); border-color: var(--c-line); }
.admin-list { border-color: var(--c-line); }
.admin-list-row { border-color: var(--c-line); }
.admin-list-row .mp { background: var(--c-bg-2); border-color: var(--c-line); }
.admin-list-row .name { color: var(--c-bone); }
.admin-list-row .meta { color: var(--c-bone-dim); }
.admin-list-row .price-cell { color: var(--c-saffron); }
.admin-list-row .stock-cell { color: var(--c-bone-dim); }
.admin-list-row .del { color: var(--c-bone-dim); }
.admin-list-row .del:hover { color: var(--c-maroon); }

/* -------- Split CTA footer -------- */
.footer-split {
  background: var(--c-bg-2);
  border-top-color: var(--c-line);
}
.footer-cta-split {
  border-bottom-color: var(--c-line);
}
.footer-cta {
  background:
    linear-gradient(140deg, rgba(255,139,31,0.03), transparent 40%),
    var(--c-bg-2);
  border-left-color: var(--c-line);
}
.footer-cta:hover {
  background:
    linear-gradient(140deg, rgba(255,139,31,0.14), rgba(199,45,62,0.07) 55%, transparent 90%),
    var(--c-bg-3);
}
.footer-cta h3 { color: var(--c-bone); }
.footer-cta p { color: var(--c-bone-dim); }
.footer-cta .arr { color: var(--c-saffron); }
.footer-split .foot-bottom {
  border-top: 0;
  color: var(--c-bone-dim);
}

/* -------- Lightbox -------- */
.img-lightbox {
  background:
    radial-gradient(80% 65% at 50% 50%, rgba(255,139,31,0.06), transparent 70%),
    rgba(4, 3, 2, 0.95);
}
.img-lightbox .top,
.img-lightbox .bottom {
  border-color: var(--c-line);
  color: var(--c-bone-dim);
}
.img-lightbox .close,
.img-lightbox .lb-nav {
  border-color: var(--c-line);
  color: var(--c-bone);
}
.img-lightbox .close:hover,
.img-lightbox .lb-nav:hover {
  border-color: var(--c-saffron);
  background: rgba(255,139,31,0.08);
}

/* hide previous decorative chrome */
.tilak-band, .petals, .feature-strip, .intro-overlay, .mandala { display: none !important; }

/* ============================================================
   3D nav logo
   ============================================================ */
.nav-logo.has-3d {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 0;
  font-size: 18px;
  letter-spacing: 0.36em;
}
.logo-stage {
  width: 56px;
  height: 36px;
  position: relative;
  flex: 0 0 56px;
}
.logo-stage canvas {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
}
.logo-stage .snake-stage-loader { display: none; }
.nav-logo.has-3d .wordmark {
  font-family: var(--f-display);
  font-weight: 400;
  letter-spacing: 0.36em;
  color: var(--c-bone);
}
.nav-logo.has-3d .wordmark span { color: var(--c-saffron); }
@media (max-width: 720px) {
  .logo-stage { display: none; }
}

/* ============================================================
   Hero — botanical plate behind the 3D python
   ============================================================ */
.hero-plate-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.hero-plate-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../plate-wordmark.jpg");
  background-size: cover;
  background-position: center 35%;
  filter: contrast(0.92) brightness(0.55) saturate(0.9);
  opacity: 0.78;
  transform: scale(1.04);
  animation: plate-drift 28s ease-in-out infinite alternate;
}
.hero-plate-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(70% 60% at 50% 50%, transparent 0%, rgba(14,9,6,0.55) 65%, rgba(14,9,6,0.95) 100%),
    linear-gradient(180deg, rgba(14,9,6,0.6) 0%, rgba(14,9,6,0.15) 35%, rgba(14,9,6,0.15) 65%, rgba(14,9,6,0.85) 100%);
}
@keyframes plate-drift {
  0%   { transform: scale(1.04) translate3d(0, 0, 0); }
  100% { transform: scale(1.08) translate3d(-1.5%, -1%, 0); }
}

/* ============================================================
   Specimen-plate gallery
   ============================================================ */
.plate-section {
  position: relative;
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 60px;
  padding: 120px var(--rail);
  overflow: hidden;
  background: var(--c-bg);
}
.plate-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../plate-detail.jpg");
  background-size: cover;
  background-position: center;
  filter: contrast(0.95) saturate(0.95) brightness(0.62);
  opacity: 0.72;
  z-index: 0;
}
.plate-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(80% 70% at 50% 50%, transparent 0%, rgba(14,9,6,0.55) 75%, rgba(14,9,6,0.95) 100%),
    linear-gradient(180deg, rgba(14,9,6,0.5) 0%, transparent 18%, transparent 82%, rgba(14,9,6,0.7) 100%);
  z-index: 1;
  pointer-events: none;
}
.plate-section.flip {
  grid-template-columns: 1fr 1fr;
}
.plate-section.flip .plate-stage { order: 2; }
.plate-section.flip .plate-text  { order: 1; }

.plate-text {
  position: relative;
  z-index: 3;
  max-width: 480px;
  color: var(--c-ivory);
}
.plate-text .latin {
  font-family: var(--f-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(20px, 2vw, 28px);
  color: var(--c-marigold);
  margin-bottom: 12px;
  letter-spacing: 0.01em;
}
.plate-text h2 {
  font-family: var(--f-display);
  font-weight: 300;
  font-size: clamp(56px, 7vw, 112px);
  line-height: 0.92;
  letter-spacing: -0.02em;
  margin-bottom: 18px;
  color: var(--c-bone);
  text-shadow: 0 4px 30px rgba(14,9,6,0.6);
}
.plate-text h2 em { font-style: italic; color: var(--c-saffron); font-weight: 400; }
.plate-text .body {
  font-size: 16px;
  line-height: 1.65;
  color: var(--c-bone);
  margin-bottom: 24px;
  text-shadow: 0 2px 14px rgba(14,9,6,0.5);
}
.plate-text .specs-row {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 36px;
  margin: 20px 0 28px;
  padding: 20px 0;
  border-top: 1px solid rgba(214,194,160,0.35);
  border-bottom: 1px solid rgba(214,194,160,0.35);
}
.plate-text .specs-row .k {
  display: block;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--c-marigold);
  margin-bottom: 6px;
}
.plate-text .specs-row .v {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 22px;
  color: var(--c-bone);
  font-weight: 300;
}
.plate-text .plate-cta {
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
}
.plate-text .plate-cta .price {
  font-family: var(--f-mono);
  font-size: 13px;
  letter-spacing: 0.14em;
  color: var(--c-marigold);
}
.plate-text .plate-cta .price b {
  display: block;
  font-family: var(--f-display);
  font-size: 30px;
  color: var(--c-saffron);
  font-weight: 400;
  letter-spacing: -0.01em;
}
.plate-text .plate-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--c-marigold);
  margin-bottom: 28px;
}
.plate-text .plate-eyebrow::before {
  content: "";
  width: 36px; height: 1px;
  background: var(--c-marigold);
}

.plate-stage {
  position: relative;
  width: 100%;
  height: min(72vh, 680px);
  z-index: 3;
}
.plate-stage canvas {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  cursor: grab;
}
.plate-stage canvas:active { cursor: grabbing; }
.plate-stage::before {
  content: "";
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,139,31,0.30) 0%, rgba(255,139,31,0.08) 40%, transparent 70%);
  filter: blur(40px);
  z-index: 0;
  pointer-events: none;
}
.plate-stage .specimen-frame {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
}
.plate-stage .specimen-frame .corner {
  position: absolute;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(214,194,160,0.45);
}
.plate-stage .specimen-frame .corner.tl { top: 0; left: 0; border-right: 0; border-bottom: 0; }
.plate-stage .specimen-frame .corner.tr { top: 0; right: 0; border-left: 0; border-bottom: 0; }
.plate-stage .specimen-frame .corner.bl { bottom: 0; left: 0; border-right: 0; border-top: 0; }
.plate-stage .specimen-frame .corner.br { bottom: 0; right: 0; border-left: 0; border-top: 0; }
.plate-stage .plate-tag {
  position: absolute;
  bottom: 16px; left: 16px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--c-bone-dim);
  z-index: 5;
}
.plate-stage .plate-tag b { color: var(--c-marigold); display: block; }

.plate-section .snake-stage-loader {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 12px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--c-bone-dim);
  transition: opacity .6s var(--ease);
  pointer-events: none;
  z-index: 6;
}
.plate-stage.loaded .snake-stage-loader { opacity: 0; }
.plate-section .snake-stage-loader .bar {
  width: 120px; height: 1px;
  background: rgba(214,194,160,0.35);
  position: relative; overflow: hidden;
}
.plate-section .snake-stage-loader .bar i {
  position: absolute; inset: 0;
  background: var(--c-marigold);
  transform-origin: left;
  transform: scaleX(0);
  transition: transform .4s linear;
}

@media (max-width: 980px) {
  .plate-section, .plate-section.flip {
    grid-template-columns: 1fr;
    padding: 80px var(--rail);
  }
  .plate-section.flip .plate-stage,
  .plate-section.flip .plate-text { order: unset; }
  .plate-stage { height: 60vh; }
}

/* "The Curator's Plates" intro band */
.plates-intro {
  position: relative;
  z-index: 2;
  padding: 100px var(--rail) 40px;
  text-align: center;
  background: var(--c-bg);
}
.plates-intro .kicker { color: var(--c-marigold); margin-bottom: 18px; display: inline-block; }
.plates-intro h2 {
  font-family: var(--f-display);
  font-weight: 300;
  font-size: clamp(40px, 5vw, 84px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--c-bone);
  max-width: 14ch;
  margin: 0 auto 18px;
}
.plates-intro h2 em { font-style: italic; color: var(--c-saffron); font-weight: 400; }
.plates-intro p {
  color: var(--c-bone-dim);
  font-size: 16px;
  max-width: 50ch;
  margin: 0 auto;
  line-height: 1.6;
}

