/* =============================================
   THE VAULT v2 — Public CSS
   css/public.css
   ============================================= */

/* ══════════════════════════════════════════════
   SITE NAV (overlaid on hero)
══════════════════════════════════════════════ */
.site-nav{
  position:absolute;top:0;left:0;right:0;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 2rem;
  background:linear-gradient(180deg,rgba(10,10,15,.9) 0%,rgba(10,10,15,0) 100%);
}
.nav-links{display:flex;align-items:center;gap:1rem}
.nav-link{font-size:.85rem;color:rgba(255,255,255,.6);transition:color .2s;font-weight:500}
.nav-link:hover,.nav-link.active{color:var(--accent)}
.admin-link{
  padding:.35rem .85rem;border:1px solid rgba(232,184,75,.35);border-radius:var(--r-sm);
  color:var(--accent);font-size:.78rem;transition:all .2s;
}
.admin-link:hover{background:rgba(232,184,75,.1)}

/* ══════════════════════════════════════════════
   HERO BANNER SLIDER
══════════════════════════════════════════════ */
.hero-banner{
  position:relative;width:100%;height:100svh;max-height:680px;min-height:420px;
  overflow:hidden;background:var(--bg);
}

/* ── Slide Track ── */
.slider-track{position:relative;width:100%;height:100%}

/* ── Individual Slides ── */
.slide{
  position:absolute;inset:0;display:flex;align-items:center;
  opacity:0;transition:opacity .9s ease;pointer-events:none;
}
.slide.active{opacity:1;pointer-events:auto}

/* ── Slide backgrounds ── */
.slide-bg{position:absolute;inset:0;z-index:0}

.slide-1 .slide-bg{
  background:
    radial-gradient(ellipse 70% 80% at 80% 50%,rgba(232,184,75,.12) 0%,transparent 60%),
    radial-gradient(ellipse 50% 60% at 20% 80%,rgba(91,143,232,.1) 0%,transparent 50%),
    url('/uploads/slide1.jpg');
  background-size: cover;
  background-position: center;
}
.slide-2 .slide-bg{
  background:
    radial-gradient(ellipse 60% 70% at 75% 40%,rgba(224,82,82,.14) 0%,transparent 60%),
    radial-gradient(ellipse 40% 50% at 10% 70%,rgba(160,125,232,.1) 0%,transparent 50%),
     url('/uploads/slide2.jpg');
  background-size: cover;
  background-position: center;
}
.slide-3 .slide-bg{
  background:
    radial-gradient(ellipse 65% 75% at 70% 45%,rgba(91,143,232,.14) 0%,transparent 60%),
    radial-gradient(ellipse 45% 55% at 15% 75%,rgba(75,184,160,.1) 0%,transparent 50%),
    url('/uploads/slide3.jpg');
  background-size: cover;
  background-position: center;
}
.slide-4 .slide-bg{
  background:
    radial-gradient(ellipse 60% 70% at 72% 42%,rgba(107,196,122,.12) 0%,transparent 60%),
    radial-gradient(ellipse 40% 50% at 12% 72%,rgba(232,184,75,.1) 0%,transparent 50%),
 url('/uploads/slide4.jpg');
  background-size: cover;
  background-position: center;
}

/* Decorative grid overlay */
.slide-bg::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);
  background-size:60px 60px;
}

/* ── Slide Content ── */
.slide-content{
  position:relative;z-index:2;padding:0 2rem;
  max-width:var(--max-w);margin:0 auto;width:100%;
  padding-top:80px;
}
.slide-eyebrow{
  font-size:.82rem;text-transform:uppercase;letter-spacing:3px;
  color:var(--accent);font-weight:600;margin-bottom:.5rem;
  opacity:0;transform:translateY(10px);
  transition:opacity .7s ease .15s,transform .7s ease .15s;
}
.slide.active .slide-eyebrow{opacity:1;transform:translateY(0)}

.slide-title{
  font-family:var(--font-d);font-size:clamp(3.5rem,10vw,7.5rem);
  letter-spacing:3px;line-height:.95;color:var(--text);
  text-shadow:0 2px 40px rgba(0,0,0,.4);
  opacity:0;transform:translateY(16px);
  transition:opacity .7s ease .3s,transform .7s ease .3s;
}
.slide.active .slide-title{opacity:1;transform:translateY(0)}
.slide-title em{color:var(--accent);font-style:normal;
  text-shadow:0 0 40px rgba(232,184,75,.3)}

.slide-sub{
  max-width:520px;font-size:clamp(.9rem,2vw,1.1rem);color:rgba(240,237,232,.65);
  line-height:1.6;margin:.9rem 0 1.75rem;font-weight:300;
  opacity:0;transform:translateY(12px);
  transition:opacity .7s ease .45s,transform .7s ease .45s;
}
.slide.active .slide-sub{opacity:1;transform:translateY(0)}

.slide-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.75rem;border-radius:var(--r-sm);
  background:var(--accent);color:#0a0a0f;font-weight:700;
  font-size:.95rem;transition:all .2s;letter-spacing:.3px;
  opacity:0;transform:translateY(10px);
  transition:opacity .7s ease .6s,transform .7s ease .6s,background .2s,box-shadow .2s;
}
.slide.active .slide-cta{opacity:1;transform:translateY(0)}
.slide-cta:hover{background:#f0c860;box-shadow:0 4px 24px rgba(232,184,75,.35)}

/* ── Slider Controls ── */
.slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(10,10,15,.55);border:1px solid rgba(255,255,255,.1);
  color:var(--text);width:44px;height:44px;border-radius:50%;
  cursor:pointer;font-size:1.6rem;display:flex;align-items:center;justify-content:center;
  transition:all .2s;z-index:5;backdrop-filter:blur(4px);line-height:1;
}
.slider-btn:hover{background:rgba(232,184,75,.2);border-color:var(--accent);color:var(--accent)}
.slider-prev{left:1.25rem}
.slider-next{right:1.25rem}

.slider-dots{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  display:flex;gap:.5rem;z-index:5;
}
.slider-dot{
  width:8px;height:8px;border-radius:50%;border:none;
  background:rgba(255,255,255,.3);cursor:pointer;
  transition:all .3s;padding:0;
}
.slider-dot.active{background:var(--accent);width:24px;border-radius:4px}

/* ── Scroll indicator ── */
.hero-banner::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:80px;
  background:linear-gradient(0deg,var(--bg) 0%,transparent 100%);
  z-index:3;pointer-events:none;
}

/* ══════════════════════════════════════════════
   SEARCH SECTION
══════════════════════════════════════════════ */
.search-section{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:1.5rem 0 0;position:sticky;top:0;z-index:50;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}

/* ══════════════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════════════ */
.public-view main.container{padding-top:1.5rem}

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media(max-width:768px){
  .site-nav{padding:1rem 1rem}
  .slide-content{padding:0 1.25rem;padding-top:70px}
  .slider-btn{width:36px;height:36px;font-size:1.3rem}
  .slider-prev{left:.6rem}
  .slider-next{right:.6rem}
  .hero-banner{max-height:560px;min-height:380px}
  .nav-links{gap:.6rem}
  .admin-link{padding:.3rem .65rem;font-size:.72rem}
}

@media(max-width:480px){
  .hero-banner{max-height:480px;min-height:360px}
  .slide-content{padding-top:65px}
  .slide-sub{display:none}
  .slide-cta{padding:.65rem 1.25rem;font-size:.88rem}
}

/* ══════════════════════════════════════════════
   COLLECTION COUNTER STRIP
══════════════════════════════════════════════ */
.counter-strip {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 2.5rem 0;
  position: relative;
  overflow: hidden;
}

/* subtle pink glow behind the strip */
.counter-strip::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 120% at 50% 50%, rgba(224,125,160,.07) 0%, transparent 70%);
  pointer-events: none;
}

.counter-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.counter-card {
  background: var(--surface);
  padding: 1.75rem 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  position: relative;
  transition: background .25s;
}

.counter-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 20%; right: 20%;
  height: 2px;
  background: var(--pink);
  border-radius: 2px 2px 0 0;
  transform: scaleX(0);
  transition: transform .4s cubic-bezier(.16,1,.3,1);
}

.counter-card:hover { background: var(--surface2); }
.counter-card:hover::after { transform: scaleX(1); }

.counter-icon {
  font-size: 1.6rem;
  line-height: 1;
  margin-bottom: .1rem;
  filter: drop-shadow(0 0 8px rgba(224,125,160,.4));
}

.counter-number {
  font-family: var(--font-d);
  font-size: clamp(2rem, 4vw, 3.2rem);
  letter-spacing: 2px;
  line-height: 1;
  color: var(--pink);
  text-shadow: 0 0 30px rgba(224,125,160,.35);
  /* number animates via JS */
  transition: color .3s;
}

.counter-label {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--muted);
  font-weight: 600;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .counter-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 560px) {
  .counter-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .counter-card { padding: 1.25rem .75rem; }
  .counter-number { font-size: 2.2rem; }
}

@media (max-width: 360px) {
  .counter-grid { grid-template-columns: 1fr 1fr; }
}

/* ══════════════════════════════════════════════
   SLIDER VIDEO & IFRAME MEDIA
══════════════════════════════════════════════ */

/* Local video fills the slide background */
.slide-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  pointer-events: none;
}

/* Iframe embeds (YouTube, Vimeo, etc) */
.slide-iframe {
  position: absolute;
  /* Oversized to hide controls and letterboxing */
  top: -10%;
  left: -10%;
  width: 120%;
  height: 120%;
  z-index: 0;
  pointer-events: none;
  border: none;
}

/* Overlay so slide-bg gradient still sits on top of video */
.slide-bg {
  z-index: 1;
}
.slide-content {
  z-index: 2;
}

/* ══════════════════════════════════════════════
   ANIMATED SEARCH BOX
══════════════════════════════════════════════ */

/* Hero search wrapper — gives it breathing room and a label */
.search-hero {
  padding: 1.5rem 0 0;
}

.search-hero-label {
  font-family: var(--font-d);
  font-size: 1.1rem;
  letter-spacing: 2px;
  color: var(--muted);
  margin-bottom: .6rem;
  text-transform: uppercase;
}

/* Enhanced search bar */
.search-bar-hero {
  position: relative;
  /* overflow must NOT be hidden — it clips the glow */
  overflow: visible;
  border: 1.5px solid var(--border);
  padding: .85rem 1.1rem;
  border-radius: 12px;
  animation: searchPulse 2.8s ease-in-out infinite;
}

@keyframes searchPulse {
  0%   {
    border-color: rgba(224,125,160,.25);
    box-shadow: 0 0 0px 0px rgba(224,125,160,0),
                inset 0 0 0px 0px rgba(224,125,160,0);
  }
  50%  {
    border-color: rgba(224,125,160,.9);
    box-shadow: 0 0 18px 4px rgba(224,125,160,.35),
                0 0 40px 8px rgba(224,125,160,.12),
                inset 0 0 12px 0px rgba(224,125,160,.08);
  }
  100% {
    border-color: rgba(224,125,160,.25);
    box-shadow: 0 0 0px 0px rgba(224,125,160,0),
                inset 0 0 0px 0px rgba(224,125,160,0);
  }
}

/* Focused state — solid gold glow, pulse paused */
.search-bar-hero.search-focused {
  animation: none;
  border-color: var(--accent) !important;
  box-shadow:
    0 0 0 3px rgba(232,184,75,.2),
    0 0 24px 6px rgba(232,184,75,.15),
    inset 0 0 12px 0px rgba(232,184,75,.05) !important;
}

/* Make the search icon and text bigger for hero bar */
.search-bar-hero .search-icon {
  width: 22px;
  height: 22px;
  color: var(--pink);
  flex-shrink: 0;
}

.search-bar-hero input {
  font-size: 1.05rem;
}

/* Shimmer sweep — clipped inside the bar via its own overflow */
.search-shimmer {
  position: absolute;
  inset: -2px; /* cover the border */
  overflow: hidden;
  border-radius: 12px;
  pointer-events: none;
  z-index: 0;
}
.search-shimmer::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 20%,
    rgba(224,125,160,.13) 45%,
    rgba(255,180,210,.18) 50%,
    rgba(224,125,160,.13) 55%,
    transparent 80%
  );
  background-size: 200% 100%;
  background-position: 200% 0;
}

/* Trigger shimmer via JS class */
.search-bar-hero.shimmer-go .search-shimmer::after {
  animation: shimmerSweep 1s ease forwards;
}

@keyframes shimmerSweep {
  from { background-position: 200% 0; }
  to   { background-position: -100% 0; }
}

/* Keep input above shimmer */
.search-bar-hero .search-input-wrap {
  position: relative;
  z-index: 1;
}

/* Placeholder fade transition */
.search-bar-hero input.ph-fade {
  opacity: 0;
  transition: opacity .28s;
}

/* Quick-search hint tags below the bar */
.search-hints {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .4rem;
  margin-top: .65rem;
  padding-bottom: .75rem;
}

.search-hint-label {
  font-size: .72rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
  margin-right: .2rem;
}

.search-hint-tag {
  font-family: var(--font-b);
  font-size: .75rem;
  padding: .22rem .7rem;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--surface2);
  color: var(--muted);
  cursor: pointer;
  transition: all .2s;
}

.search-hint-tag:hover {
  border-color: var(--pink);
  color: var(--pink);
  background: rgba(224,125,160,.08);
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .search-bar-hero { padding: .7rem .85rem; }
  .search-bar-hero input { font-size: .95rem; }
  .search-hints { gap: .3rem; }
  .search-hint-tag { font-size: .7rem; padding: .18rem .55rem; }
}
