
:root{--cpe-bg:#0b1020;--cpe-fg:#e8e2d8;--cpe-accent:#b03a3a;--cpe-shadow:rgba(0,0,0,.35);}

/* --- Cosmo Exhibit typography: "тихий шрифт" (никаких автозаглавных) --- */
.cpe-root, .cpe-root *{
  text-transform: none !important;
  letter-spacing: inherit;
}


/* Typography overrides via admin settings */
.cpe-exhibit-title{ font-family: var(--cpe-font-exhibit-title, inherit); font-weight: 600; font-size: var(--cpe-size-exhibit-title, clamp(22px, 3.2vw, 40px)); line-height: 1.15; margin: 0 0 10px 0; display: inline-block; transform: rotate(var(--cpe-rotate-exhibit-title, 0deg)); color: var(--cpe-color-exhibit-title, var(--cpe-fg, inherit)); }
.cpe-intro-line{ font-family: var(--cpe-font-exhibit-desc, inherit); color: var(--cpe-color-exhibit-desc, var(--cpe-fg, inherit)); }
.cpe-orbit-title{ font-family: var(--cpe-font-orbit-title, inherit); color: var(--cpe-color-orbit-title, var(--cpe-fg, inherit)); }
.cpe-orbit-sub{ font-family: var(--cpe-font-orbit-desc, inherit);  font-size:var(--cpe-size-orbit-desc, 16px); color: var(--cpe-color-orbit-desc, var(--cpe-fg, inherit)); }
.cpe-caption, .cpe-modal-caption, .cpe-modal-meta{ font-family: var(--cpe-font-postcard-desc, inherit); color: var(--cpe-color-postcard-desc, var(--cpe-fg, inherit)); }

/* Small visual polish: better wrapping on headings/long captions */
.cpe-exhibit-title, .cpe-orbit-title{ text-wrap: balance; }
.cpe-orbit-sub, .cpe-modal-text, .cpe-caption{ hyphens: auto; }
.cpe-modal-text{ font-size: var(--cpe-size-postcard-desc, clamp(14px, 1.15vw, 16px)); }

/* Theme-proof button reset (важно: многие темы перекрашивают <button>) */
.cpe-card{
  -webkit-appearance: none !important;
  appearance: none !important;
  background: rgba(255,255,255,.02) !important;
  color: var(--cpe-fg) !important;
  border: 1px solid rgba(232,226,216,.10) !important;
  font: inherit !important;
  line-height: inherit !important;
}

/* Кураторский "шёпот": подписи короче, тише */
.cpe-caption{
  text-transform: none !important;
  letter-spacing: .01em;
  font-weight: 400;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Убираем теги из карточки (они остаются в модалке) */
.cpe-card .cpe-pill.cpe-pill-tags{ display:none !important; }

/* Кнопка "Открыть" на карточке тоже убирается — кликается вся открытка */
.cpe-card .cpe-pill.cpe-pill-open{ display:none !important; }

/* Немного больше воздуха вокруг изображения */
.cpe-meta{ padding: 14px 16px 18px !important; }
.cpe-stage{background:var(--cpe-bg);color:var(--cpe-fg);min-height:80vh;border-radius:14px;overflow:hidden;position:relative;}
.cpe-stage.cpe-grain:before{content:"";position:absolute;inset:0;pointer-events:none;opacity: .16;mix-blend-mode:overlay;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
background-size:120px 120px;}
.cpe-stars{position:absolute;inset:0;pointer-events:none;opacity:.55;transition:transform .8s ease;}
.cpe-stars span{position:absolute;background:rgba(232,226,216,.9);border-radius:2px;box-shadow:0 0 8px rgba(232,226,216,.35);animation:cpe-tw 10s ease-in-out infinite;}
@keyframes cpe-tw{0%,100%{transform:translateY(0);opacity:.55}50%{transform:translateY(-6px);opacity:.95}}
.cpe-toolbar{position:fixed;top:12px;right:12px;display:flex;justify-content:flex-end;gap:10px;padding:0;margin:0;z-index:99999;pointer-events:auto}
.cpe-toolbar>*{pointer-events:auto}
.cpe-btn{background:rgba(255,255,255,.03);color:var(--cpe-fg);border:1px solid rgba(232,226,216,.18);border-radius:999px;padding:8px 12px;cursor:pointer;opacity:.92;backdrop-filter:blur(6px)}
.cpe-btn:hover{opacity:1}
.cpe-orbitnav{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;padding:14px 18px 0;opacity:.9}
.cpe-orbitnav a{color:var(--cpe-fg);text-decoration:none;border:1px solid rgba(232,226,216,.14);border-radius:999px;padding:7px 10px;font-size:12.5px;opacity:.72}
.cpe-orbitnav a:hover{opacity:.95;border-color:rgba(232,226,216,.22)}
.cpe-intro{min-height:78vh;display:flex;align-items:center;justify-content:center;padding:8vh 8vw}
.cpe-intro-inner{max-width:760px;line-height:1.85;letter-spacing:.02em;font-size:var(--cpe-size-exhibit-desc, clamp(16px,2vw,19px))}
.cpe-intro p{margin:0 0 18px 0;opacity:.92}
.cpe-intro .cpe-soft{opacity:.72}
.cpe-scrollhint{margin-top:26px;display:flex;gap:10px;align-items:center;opacity:.6;font-size:13px}
.cpe-dot{width:7px;height:7px;border:1px solid rgba(232,226,216,.6);border-radius:50%}
.cpe-orbit{padding:10vh 8vw 12vh;border-top:1px solid rgba(232,226,216,.08)}
.cpe-orbit-title{font-size:var(--cpe-size-orbit-title, clamp(20px,2.7vw,32px));letter-spacing:.04em;margin:0 0 10px}
.cpe-orbit-sub{margin:0 0 42px;opacity:.72;max-width:780px;line-height:1.78;font-size:var(--cpe-size-orbit-desc, 16px)}
.cpe-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:22px}
.cpe-card{grid-column:span 6;background:rgba(255,255,255,.02);border:1px solid rgba(232,226,216,.10);border-radius:16px;overflow:hidden;
box-shadow:0 16px 48px var(--cpe-shadow);transition:transform .8s ease,border-color .6s ease,box-shadow .6s ease;outline:none;padding:0;text-align:left}
@media (max-width:900px){.cpe-card{grid-column:span 12}}
.cpe-card:hover,.cpe-card:focus-visible{border-color: rgba(232,226,216,.70);box-shadow:0 22px 64px rgba(0,0,0,.45)}
.cpe-card img{width:100%;height:auto;display:block}
.cpe-meta{padding:18px 18px 22px}
.cpe-caption{margin:0 0 10px;font-size:var(--cpe-size-postcard-desc, 15px);line-height:1.65;opacity:.92}
.cpe-line{display:flex;flex-wrap:wrap;gap:10px 14px;align-items:baseline;opacity:.70;font-size:12.5px}
.cpe-pill{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border:1px solid rgba(232,226,216,.14);border-radius:999px;opacity:.85}
.cpe-accent{color:var(--cpe-accent)}
.cpe-modal{position:fixed;inset:0;background:rgba(3,5,10,.86);display:flex;align-items:center;justify-content:center;z-index:99999;padding:6vh 6vw;
opacity:0;pointer-events:none;transition:opacity .25s ease}
.cpe-modal[aria-hidden="false"]{opacity:1;pointer-events:auto}
.cpe-modal-inner{max-width:1000px;width:100%;background:rgba(10,14,26,.92);border:1px solid rgba(232,226,216,.14);border-radius:16px;overflow:hidden;
box-shadow:0 26px 90px rgba(0,0,0,.6);transform:translateY(10px) scale(.99);transition:transform .25s ease}
.cpe-modal[aria-hidden="false"] .cpe-modal-inner{transform:translateY(0) scale(1)}
.cpe-modal-top{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px 14px 14px 18px;border-bottom:1px solid rgba(232,226,216,.10)}
.cpe-modal-nav{display:flex;gap:10px}
.cpe-modal-body{padding:18px}
.cpe-modal-body img{width:100%;height:auto;display:block;border-radius:10px;border:1px solid rgba(232,226,216,.08)}
.cpe-modal-text{margin-top:14px;line-height:1.75;opacity:.86}
@media (prefers-reduced-motion:reduce){.cpe-stars span{animation:none}.cpe-modal,.cpe-modal-inner{transition:none}.cpe-card{transition:none}}


/* --- Curator mode 1.0.4 --- */
.cpe-grid{grid-template-columns:1fr; justify-items:center;}
.cpe-card{
  max-width:520px;
  background:transparent !important;
  border:none !important;
  box-shadow:0 30px 90px rgba(0,0,0,.45);
}
.cpe-card:first-child{
  max-width:620px;
}
.cpe-card img{
  border-radius:18px;
}
.cpe-meta{
  padding:14px 6px 0 !important;
  text-align:center;
}
.cpe-caption{
  white-space:normal;
  font-size:15px;
  margin-top:12px;
}
.cpe-line{display:none;}


/* --- Full width (full-bleed) stage: игнорируем контейнер темы --- */
.cpe-root{
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.cpe-stage{
  width: 100% !important;
  max-width: none !important;
  border-radius: 0 !important;
}


/* --- 1.0.6: тише подпись + очень медленное появление + микродрейф --- */

/* Подпись как шёпот */
.cpe-caption{
  font-size: 14px !important;
  opacity: .72 !important;
  letter-spacing: .03em !important;
  line-height: 1.65 !important;
}

/* Появление при прокрутке */
.cpe-imgwrap.cpe-imgwrap.cpe-imgwrap.cpe-reveal{
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 1.8s ease, transform 2.4s ease;
  will-change: opacity, transform;
}
.cpe-imgwrap.cpe-reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* Едва заметный дрейф открытки (1–2px) */
@keyframes cpe-drift{
  0%, 100% { transform: translate3d(0,0,0); }
  50%      { transform: translate3d(0,2px,0); }
}
.cpe-card img{
  animation: cpe-drift 18s ease-in-out infinite;
  will-change: transform;
}

/* Уважение к reduced motion */
@media (prefers-reduced-motion: reduce){
  .cpe-imgwrap.cpe-imgwrap.cpe-imgwrap.cpe-imgwrap.cpe-imgwrap.cpe-reveal{ transition:none !important; opacity:1 !important; transform:none !important; }
  .cpe-card img{ animation:none !important; }
}


/* --- 1.0.7 Asymmetric orbit layout --- */
.cpe-grid{
  grid-template-columns: 1fr;
}
.cpe-orbit{
  position: relative;
}
.cpe-card{
  position: relative;
  margin: 0 auto 18vh;
}
.cpe-card[data-shift="left"]{
  transform: translateX(-8vw);
}
.cpe-card[data-shift="right"]{
  transform: translateX(8vw);
}
.cpe-card[data-depth="far"]{
  opacity: .82;
  transform: scale(.92);
}
.cpe-caption{
  position: absolute;
  max-width: 260px;
}
.cpe-card[data-shift="left"] .cpe-caption{
  right: -300px;
  text-align: left;
}
.cpe-card[data-shift="right"] .cpe-caption{
  left: -300px;
  text-align: right;
}
@media (max-width: 900px){
  .cpe-card{
    transform: none !important;
    margin-bottom: 12vh;
  }
  .cpe-caption{
    position: static;
    margin-top: 14px;
    text-align: center;
  }
}


/* --- 1.0.8 Sticky sound control --- */
.cpe-toolbar{
  position: fixed !important;
  right: 22px;
  bottom: 22px;
  top: auto !important;
  z-index: 999999;
}
.cpe-btn{
  font-size: 14px;
  padding: 10px 16px;
}


/* --- 1.0.11: чуть ярче заголовок орбиты --- */
.cpe-orbit-title{
  opacity: .88;
  text-shadow: 0 0 18px rgba(232,226,216,.08);
}


/* --- 1.0.12: toolbar always visible/clickable --- */
.cpe-toolbar{
  pointer-events: auto !important;
  display: flex !important;
  align-items: center;
}
.cpe-toolbar .cpe-btn{ pointer-events:auto !important; }


/* --- 1.0.12: reveal guard --- */
.cpe-imgwrap{ opacity: 1; }
.cpe-imgwrap.cpe-reveal{ opacity: 0; }
.cpe-imgwrap.cpe-reveal.is-visible{ opacity: 1; }


/* --- 1.0.12: заголовок орбиты чуть ярче --- */
.cpe-orbit-title{ opacity: .92; }


/* --- 1.0.13 orbit title slightly brighter --- */
.cpe-orbit-title{opacity:.92;}

/* --- 1.0.13 collage/scatter layout (как на референсе) --- */
.cpe-orbit{padding: 56px 22px 64px;}
.cpe-orbit-title{font-size: var(--cpe-size-orbit-title, 44px); letter-spacing:.02em; text-align:center; margin: 0 0 10px;}
.cpe-orbit-sub{max-width: 860px; margin: 0 auto 26px; text-align:center; opacity:.78; line-height:1.7; font-size:var(--cpe-size-orbit-desc, 16px);}
.cpe-grid.cpe-scatter{
  position: relative;
  height: min(72vh, 720px);
  max-width: 1180px;
  margin: 0 auto;
}
.cpe-grid.cpe-scatter .cpe-card{
  position: absolute;
  left: 50%;
  top: 46%;
  transform: translate(-50%,-50%) translate(var(--cpe-x), var(--cpe-y)) rotate(var(--cpe-r)) scale(var(--cpe-s));
  background: transparent !important;
  border: none !important;
  box-shadow: 0 35px 90px rgba(0,0,0,.42);
  padding: 0;
  max-width: 420px;
}
.cpe-grid.cpe-scatter .cpe-card .cpe-imgwrap{
  border-radius: 16px;
  overflow: hidden;
}
.cpe-grid.cpe-scatter .cpe-card img{
  display:block;
  width: 100%;
  height: auto;
  border-radius: 16px;
  animation: cpe-drift 18s ease-in-out infinite;
}
.cpe-grid.cpe-scatter .cpe-card .cpe-caption{
  position: absolute;
  left: 50%;
  top: calc(100% + 18px);
  transform: translateX(-50%);
  width: 320px;
  text-align: center;
  font-size: 14px;
  opacity: .72;
  letter-spacing: .03em;
  line-height: 1.65;
  pointer-events: none;
}

/* Reveal (на карточке, но без конфликтов: используем opacity) */
.cpe-card.cpe-reveal{ opacity:0; transition: opacity 2.2s ease; }
.cpe-card.cpe-reveal.is-visible{ opacity:1; }

@media (max-width: 980px){
  .cpe-grid.cpe-scatter{
    height: auto;
    padding-bottom: 60px;
  }
  .cpe-grid.cpe-scatter .cpe-card{
    position: relative;
    left: auto; top: auto;
    transform: none;
    margin: 0 auto 54px;
    max-width: 520px;
  }
  .cpe-grid.cpe-scatter .cpe-card .cpe-caption{
    position: static;
    transform: none;
    width: auto;
    margin-top: 14px;
  }
}

/* Toolbar fixed */
.cpe-toolbar{
  position: fixed !important;
  right: 22px;
  bottom: 22px;
  z-index: 999999;
  display: flex !important;
  gap: 10px;
  pointer-events: auto !important;
}
.cpe-btn.cpe-sound-btn{
  font-size: 14px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(232,226,216,.06);
  border: 1px solid rgba(232,226,216,.16);
  color: var(--cpe-fg);
  backdrop-filter: blur(8px);
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .cpe-grid.cpe-scatter .cpe-card img{ animation:none !important; }
  .cpe-card.cpe-reveal{ transition:none !important; opacity:1 !important; }
}


/* --- 1.0.14 fixes: clickability + no accidental overlays --- */
.cpe-stars{ pointer-events:none !important; }
.cpe-grid.cpe-scatter{ height: min(78vh, 820px); }
.cpe-grid.cpe-scatter .cpe-card{ pointer-events:auto !important; cursor:pointer; }
.cpe-grid.cpe-scatter .cpe-card:focus{ outline: none; }
.cpe-grid.cpe-scatter .cpe-card:hover{ filter: brightness(1.02); }

/* modal should not block clicks when closed */
.cpe-modal{ pointer-events:none; }
.cpe-modal.is-open{ pointer-events:auto; }


/* --- 1.0.15: modal visible when opened via class --- */
.cpe-modal.is-open{ opacity:1 !important; pointer-events:auto !important; }
.cpe-modal.is-open .cpe-modal-panel,
.cpe-modal.is-open .cpe-modal-inner{ transform:translateY(0) scale(1) !important; }

/* --- 1.0.32: аккуратные «карточки» в модальном окне (по клику) --- */
.cpe-modal-backdrop{
  position:absolute;
  inset:0;
}
.cpe-modal{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:6vh 6vw;
}
.cpe-modal-panel{
  position:relative;
  /* 1.0.35: make opened postcard card ~2x smaller (less overwhelming) */
  width:min(520px, 92vw);
  max-height:88vh;
  /* Keep content scrollable if needed, but hide the visible scrollbar line */
  overflow:auto;
  scrollbar-width:none;           /* Firefox */
  -ms-overflow-style:none;        /* IE/Edge legacy */
  background:rgba(10,14,26,.94);
  border:1px solid rgba(232,226,216,.14);
  border-radius:18px;
  box-shadow:0 26px 90px rgba(0,0,0,.62);
  padding:18px;
  transform:translateY(10px) scale(.99);
  transition:transform .25s ease;
}

/* WebKit: hide scrollbar (Chrome/Safari) while preserving scroll */
.cpe-modal-panel::-webkit-scrollbar{
  width:0;
  height:0;
}
.cpe-modal-close{
  position:absolute;
  top:10px;
  right:10px;
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(232,226,216,.14);
  background:rgba(232,226,216,.06);
  color:var(--cpe-fg);
  backdrop-filter:blur(8px);
  cursor:pointer;
  line-height:1;
  font-size:20px;
}
.cpe-modal-close:hover{ background:rgba(232,226,216,.10); }
.cpe-modal-close:focus{ outline:none; box-shadow:0 0 0 3px rgba(232,226,216,.10); }

.cpe-modal-img{
  width:100%;
  height:auto;
  display:block;
  border-radius:14px;
  border:1px solid rgba(232,226,216,.10);
}
.cpe-modal-meta{font-size:var(--cpe-size-postcard-desc, 12.5px);
  margin-top:14px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.cpe-modal-caption{font-size:var(--cpe-size-postcard-desc, 14px);
  font-size:15px;
  line-height:1.75;
  opacity:.92;
}
.cpe-modal-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px 12px;
  opacity:.82;
}
.cpe-modal-pills .cpe-pill{
  background:rgba(232,226,216,.04);
}
.cpe-modal-nav{
  position:absolute;
  left:14px;
  top:14px;
  display:flex;
  gap:8px;
}
.cpe-modal-prev,
.cpe-modal-next{
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(232,226,216,.14);
  background:rgba(232,226,216,.06);
  color:var(--cpe-fg);
  backdrop-filter:blur(8px);
  cursor:pointer;
}
.cpe-modal-prev:hover,.cpe-modal-next:hover{ background:rgba(232,226,216,.10); }
.cpe-modal-prev:focus,.cpe-modal-next:focus{ outline:none; box-shadow:0 0 0 3px rgba(232,226,216,.10); }


/* --- 1.0.15: вступление — строки под строкой --- */
.cpe-intro{
  flex-direction: column;
  gap: 18px;
  text-align: center;
}
.cpe-intro-line{
  display: block;
  max-width: 900px;
  margin: 0 auto;
}


/* --- 1.0.17: sound button always visible --- */
.cpe-btn.cpe-sound-btn{
  appearance: none;
  -webkit-appearance: none;
  background: rgba(232,226,216,.06);
  border: 1px solid rgba(232,226,216,.16);
  color: var(--cpe-fg);
}
.cpe-btn.cpe-sound-btn:focus{ outline: none; box-shadow: 0 0 0 3px rgba(232,226,216,.08); }


/* --- 1.0.18: sound button higher + more noticeable --- */
.cpe-toolbar{
  right: 24px !important;
  bottom: 88px !important; /* подняли выше */
}
.cpe-btn.cpe-sound-btn{
  font-size: 15px !important;
  padding: 12px 18px !important;
  border-width: 1px !important;
  background: rgba(232,226,216,.10) !important;
  border: 1px solid rgba(232,226,216,.22) !important;
  box-shadow: 0 0 0 1px rgba(232,226,216,.06), 0 18px 60px rgba(0,0,0,.45);
  letter-spacing: .06em;
  text-transform: uppercase;
}
.cpe-btn.cpe-sound-btn.cpe-attn{
  animation: cpe-pulse 2.8s ease-in-out infinite;
}
@keyframes cpe-pulse{
  0%,100%{ transform: translateY(0); box-shadow: 0 0 0 1px rgba(232,226,216,.08), 0 18px 60px rgba(0,0,0,.45); }
  50%{ transform: translateY(-1px); box-shadow: 0 0 0 1px rgba(232,226,216,.14), 0 22px 70px rgba(0,0,0,.52); }
}


/* --- 1.0.20: scroll lock that restores position correctly --- */
body.cpe-lock{
  position: fixed;
  left: 0; right: 0;
  overflow: hidden;
  width: 100%;
}


/* --- 1.0.20: cards more neat --- */
.cpe-card{
  border-radius: 18px;
}
.cpe-card .cpe-imgwrap{
  border-radius: 18px;
  overflow: hidden;
  outline: 1px solid rgba(232,226,216,.10);
}
.cpe-card img{
  display:block;
  width:100%;
  height:auto;
  transform: translateZ(0);
}
.cpe-card{
  box-shadow: 0 28px 80px rgba(0,0,0,.40);
}


/* --- 1.0.21: themed background (retro-cosmo) --- */
.cpe-stage{
  background:
    radial-gradient(1200px 700px at 15% 20%, rgba(232,226,216,.06), transparent 60%),
    radial-gradient(900px 520px at 85% 30%, rgba(176,58,58,.07), transparent 62%),
    radial-gradient(900px 620px at 50% 85%, rgba(120,170,200,.06), transparent 66%),
    linear-gradient(180deg, rgba(9,12,22,1) 0%, rgba(11,16,32,1) 45%, rgba(7,9,18,1) 100%);
}
/* subtle vignette */
.cpe-stage:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: radial-gradient(1200px 800px at 50% 35%, transparent 55%, rgba(0,0,0,.38) 100%);
  opacity:.9;
}


/* --- 1.0.21: hover — gentle scale + whisper caption --- */
.cpe-card .cpe-caption{
  opacity: 0;
  transform: translateX(-50%) translateY(6px);
  transition: opacity .6s ease, transform .9s ease;
}
.cpe-card:hover{
  transform: translate(-50%,-50%) translate(var(--cpe-x), var(--cpe-y)) rotate(var(--cpe-r)) scale(calc(var(--cpe-s) * 1.035));
}
/* mobile: no hover */
@media (hover: hover){
  .cpe-card:hover .cpe-caption{
    opacity: .78;
    transform: translateX(-50%) translateY(0);
  }
}
@media (hover: none){
  .cpe-card .cpe-caption{ opacity: .72; transform: none; }
}


/* --- 1.0.22 FORCE theme override --- */
body .cpe-stage{
  background:
    radial-gradient(1100px 700px at 18% 22%, rgba(232,226,216,.07), transparent 60%),
    radial-gradient(900px 520px at 82% 28%, rgba(176,58,58,.08), transparent 62%),
    radial-gradient(900px 620px at 50% 82%, rgba(120,170,200,.07), transparent 66%),
    linear-gradient(180deg, #080b16 0%, #0b1020 45%, #070912 100%) !important;
}

body .cpe-card{
  outline: none !important;
}

@media (hover: hover){
  body .cpe-card:hover{
    transform:
      translate(-50%,-50%)
      translate(var(--cpe-x), var(--cpe-y))
      rotate(var(--cpe-r))
      scale(calc(var(--cpe-s) * 1.04)) !important;
  }
  body .cpe-card:hover .cpe-caption{
    opacity: .78 !important;
    transform: translateX(-50%) translateY(0) !important;
  }
}

body .cpe-card .cpe-caption{
  opacity: 0 !important;
  transition: opacity .6s ease, transform .9s ease !important;
}


/* --- 1.0.23: remove postcard outline completely --- */
body .cpe-card,
body .cpe-card:focus,
body .cpe-card:focus-visible{
  outline: none !important;
  box-shadow: none !important; /* prevent theme focus ring */
}

body .cpe-card .cpe-imgwrap{
  outline: none !important;
  border: 0 !important;
  box-shadow: 0 28px 80px rgba(0,0,0,.40) !important; /* keep only depth shadow */
  background: transparent !important;
}

/* if theme adds border to images */
body .cpe-card img{
  border: 0 !important;
  outline: none !important;
}

/* hover keeps no outline */
@media (hover: hover){
  body .cpe-card:hover .cpe-imgwrap{
    outline: none !important;
    border: 0 !important;
  }
}


/* --- 1.0.24: whisper caption reveal (robust) --- */
body .cpe-card .cpe-caption{
  display: block !important;
  opacity: 0 !important;
  transform: translateX(-50%) translateY(8px) !important;
  transition: opacity .7s ease, transform 1.1s ease !important;
  pointer-events: none !important;
}

/* Hover & keyboard focus */
@media (hover: hover){
  body .cpe-card:hover .cpe-caption,
  body .cpe-card:focus .cpe-caption,
  body .cpe-card:focus-visible .cpe-caption{
    opacity: .78 !important;
    transform: translateX(-50%) translateY(0) !important;
  }
}

/* Touch devices: keep visible so it isn't lost */
@media (hover: none){
  body .cpe-card .cpe-caption{
    opacity: .72 !important;
    transform: translateX(-50%) translateY(0) !important;
  }
}


/* --- 1.0.25: ensure whisper caption can appear outside the card --- */
body .cpe-card{
  overflow: visible !important; /* some themes set button{overflow:hidden} */
}
body .cpe-card .cpe-caption{
  z-index: 5 !important;
}


/* --- 1.0.28: orbit titles a touch brighter --- */
body .cpe-orbit-title{
  opacity: .96 !important;
  text-shadow: 0 0 22px rgba(232,226,216,.10);
}

/* --- 1.0.28: cards more neat/readable --- */
body .cpe-grid.cpe-scatter .cpe-card{
  max-width: 380px;
  box-shadow: 0 22px 70px rgba(0,0,0,.38) !important;
}

body .cpe-grid.cpe-scatter .cpe-card .cpe-imgwrap{
  border-radius: 18px !important;
  overflow: hidden !important;
  outline: none !important;
  border: 0 !important;
  box-shadow: none !important;
}

body .cpe-grid.cpe-scatter .cpe-card img{
  border-radius: 18px !important;
}

/* caption: readable whisper plaque */
body .cpe-grid.cpe-scatter .cpe-card .cpe-caption{
  /* аккуратнее и читабельнее: компактная табличка вместо «капсулы» */
  width: min(340px, 84vw);
  max-width: 84vw;
  padding: 10px 12px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(0,0,0,.54), rgba(0,0,0,.38));
  border: 1px solid rgba(232,226,216,.14);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-size: 12.8px;
  letter-spacing: .02em;
  line-height: 1.45;
  text-shadow: 0 1px 18px rgba(0,0,0,.55);
  text-align: center;
  hyphens: auto;
  word-break: break-word;
  opacity: 0; /* will reveal on hover via whisper rules */
}


@media (max-width: 980px){
  body .cpe-grid.cpe-scatter .cpe-card{
    max-width: 520px;
  }
  body .cpe-grid.cpe-scatter .cpe-card .cpe-caption{
    width: auto;
    border-radius: 14px;
    padding: 10px 12px;
    background: linear-gradient(180deg, rgba(0,0,0,.52), rgba(0,0,0,.34));
  }
}


/* --- 1.0.30: more air between cards --- */
body .cpe-grid.cpe-scatter{
  min-height: 92vh;
}


/* --- 1.0.31 strict no-overlap scatter fixes --- */
.cpe-stage{
  overflow-x: hidden !important;
  overflow-y: visible !important; /* allow captions below scatter to be visible */
}
.cpe-grid.cpe-scatter{
  overflow: visible !important;
  padding-bottom: 140px; /* extra room for captions */
}
.cpe-grid.cpe-scatter .cpe-caption{
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  width: min(340px, 84vw) !important;
  max-width: 84vw !important;
}

/* --- 1.0.34: subtle orbit doodles (monochrome, sparse) --- */
.cpe-orbit{ position: relative; }
.cpe-orbit-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
}
.cpe-orbit > *:not(.cpe-orbit-bg){ position: relative; z-index: 1; }

.cpe-doodle{
  position:absolute;
  /* 1.0.35: a bit more visible so they actually read as background accents */
  width: clamp(70px, 9vw, 128px);
  height: clamp(70px, 9vw, 128px);
  background-repeat:no-repeat;
  background-size:contain;
  background-position:center;
  opacity: .16;
  color: rgba(232,226,216,.70);
  filter: none;
  transform:
    translate(-50%, -50%)
    translate(var(--cpe-ox, 0px), var(--cpe-oy, 0px))
    rotate(var(--cpe-or, 0deg))
    scale(var(--cpe-ds, 1));
  will-change: transform;
}
.cpe-doodle svg{ width:100%; height:100%; display:block; }
@media (prefers-reduced-motion: reduce){
  .cpe-doodle{ transform: translate(-50%, -50%) scale(var(--cpe-ds, 1)); }
}

/* --- 1.0.37: push orbit title/description higher; more gap to postcards --- */
body .cpe-orbit-title{ margin-bottom: 14px !important; }
body .cpe-orbit-sub{ margin-bottom: 68px !important; }
body .cpe-grid.cpe-scatter{ margin-top: 12px !important; }


/* === FIX: Prevent rotated exhibition title overlapping description === */
.cpe-exhibit-title {
    margin-bottom: 24px;
    display: inline-block;
}

.cpe-exhibit-description {
    margin-top: 12px;
}


/* === FIX: hide theme/WordPress page title on exhibit pages === */
body.cpe-hide-wp-title .entry-title,
body.cpe-hide-wp-title .wp-block-post-title,
body.cpe-hide-wp-title .page-title,
body.cpe-hide-wp-title h1.entry-title,
body.cpe-hide-wp-title h1.page-title,
body.cpe-hide-wp-title header.entry-header h1,
body.cpe-hide-wp-title .post-title,
body.cpe-hide-wp-title .single-title {
  display: none !important;
}


/* Theme-specific: Pochtovoe Lab outputs page title inside article.prose > h1 */
body.cpe-hide-wp-title article.prose > h1,
body.cpe-hide-wp-title .prose > h1 {
  display: none !important;
}
