/* Idyllic Visions — Card Explorer
   Self-contained styles. Scoped under #idyllic-card-explorer to avoid theme clashes.
   Palette + floating-card + lightbox aesthetic ported from the idyllicx prototype. */

#idyllic-card-explorer{
  --ice-bone:#F5F1E8;
  --ice-bone-2:#EDE7D9;
  --ice-ink:#16130E;
  --ice-ink-soft:#3A352C;
  --ice-gold:#B0863C;
  --ice-gold-deep:#8A6526;
  --ice-line:rgba(22,19,14,.14);
  --ice-serif:Georgia,'Times New Roman',serif;
  --ice-sans:system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--ice-bone);
  color:var(--ice-ink);
  font-family:var(--ice-sans);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  border-radius:14px;
  padding:26px 24px 40px;
  box-sizing:border-box;
}
#idyllic-card-explorer *{box-sizing:border-box}
#idyllic-card-explorer img{display:block;max-width:100%}

/* ---- intro / heading ---- */
#idyllic-card-explorer .ice-intro{max-width:760px;margin:0 auto 22px;text-align:center}
#idyllic-card-explorer .ice-eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ice-gold-deep);font-weight:600;margin-bottom:8px;
}
#idyllic-card-explorer .ice-intro h2{
  font-family:var(--ice-serif);font-weight:500;
  font-size:clamp(22px,3.2vw,34px);line-height:1.08;margin:0 0 8px;
}
#idyllic-card-explorer .ice-intro p{
  font-size:15px;color:var(--ice-ink-soft);margin:0 auto;max-width:54ch;
}

/* ---- deck selector ---- */
#idyllic-card-explorer .ice-decks{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px;
  margin:22px auto 6px;max-width:900px;
}
#idyllic-card-explorer .ice-deck-btn{
  font-family:var(--ice-sans);font-size:13px;font-weight:600;letter-spacing:.02em;
  padding:10px 18px;border-radius:40px;cursor:pointer;
  border:1px solid var(--ice-line);background:#fff;color:var(--ice-ink);
  transition:.2s;line-height:1.2;
}
#idyllic-card-explorer .ice-deck-btn:hover{border-color:var(--ice-gold);color:var(--ice-gold-deep)}
#idyllic-card-explorer .ice-deck-btn.sel{
  background:var(--ice-ink);border-color:var(--ice-ink);color:var(--ice-bone);
}
#idyllic-card-explorer .ice-deck-btn .ice-deck-n{
  opacity:.6;font-weight:500;margin-left:6px;font-size:11px;
}

/* ---- selected-deck title row ---- */
#idyllic-card-explorer .ice-deck-head{
  text-align:center;margin:26px 0 4px;
}
#idyllic-card-explorer .ice-deck-head h3{
  font-family:var(--ice-serif);font-weight:500;
  font-size:clamp(20px,2.6vw,28px);line-height:1.06;margin:0;
}
#idyllic-card-explorer .ice-deck-head .ice-hint{
  font-size:12.5px;color:var(--ice-ink-soft);letter-spacing:.04em;margin-top:6px;
}

/* ---- floating card grid (ported .ecard) ---- */
#idyllic-card-explorer .ice-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));
  gap:22px 16px;max-width:1180px;margin:22px auto 0;
}
#idyllic-card-explorer .ecard{position:relative;aspect-ratio:2/3;cursor:pointer}
#idyllic-card-explorer .ecard-inner{
  position:relative;width:100%;height:100%;border-radius:7px;overflow:hidden;background:#fff;
  box-shadow:0 10px 24px -12px rgba(0,0,0,.5);
  animation:ice-floaty var(--d,6s) ease-in-out var(--delay,0s) infinite;
  transition:box-shadow .35s;will-change:transform;
}
#idyllic-card-explorer .ecard-inner img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
#idyllic-card-explorer .ecard:hover{z-index:4}
#idyllic-card-explorer .ecard:hover .ecard-inner{box-shadow:0 22px 44px -14px rgba(0,0,0,.6)}
#idyllic-card-explorer .ecard:hover img{transform:scale(1.06)}
#idyllic-card-explorer .ecard-n{
  position:absolute;top:6px;left:6px;z-index:2;background:rgba(245,241,232,.92);
  font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;letter-spacing:.04em;color:var(--ice-ink);
}
@keyframes ice-floaty{
  0%,100%{transform:translateY(0) rotate(var(--rot,0deg))}
  50%{transform:translateY(-13px) rotate(calc(var(--rot,0deg) * -1))}
}
@media(prefers-reduced-motion:reduce){#idyllic-card-explorer .ecard-inner{animation:none}}

/* ---- lightbox (ported .lb) ---- */
.ice-lb{
  display:none;position:fixed;inset:0;z-index:99999;
  background:rgba(14,12,20,.92);align-items:center;justify-content:center;
  text-align:center;padding:30px;
  font-family:system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
.ice-lb.on{display:flex}
.ice-lb *{box-sizing:border-box}
.ice-lb-card{width:min(360px,84vw);aspect-ratio:2/3;perspective:1600px;cursor:pointer;position:relative}
.ice-lb-inner{
  position:relative;width:100%;height:100%;
  transition:transform .7s cubic-bezier(.4,.2,.2,1);transform-style:preserve-3d;
}
.ice-lb-card.flipped .ice-lb-inner{transform:rotateY(180deg)}
.ice-lb-face{
  position:absolute;inset:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;
  border-radius:14px;overflow:hidden;box-shadow:0 30px 70px -20px rgba(0,0,0,.8);
}
.ice-lb-front img{width:100%;height:100%;object-fit:cover}
.ice-lb-back{
  transform:rotateY(180deg);background:#F5F1E8;color:#16130E;
  padding:30px 26px;display:flex;flex-direction:column;overflow-y:auto;text-align:left;
}
.ice-lb-back .ice-eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#8A6526;font-weight:600;
}
.ice-lb-back h3{font-family:Georgia,'Times New Roman',serif;font-weight:500;font-size:25px;margin:8px 0 6px;line-height:1.1}
.ice-lb-back .ice-kw{font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:#8A6526;margin-bottom:14px;font-weight:600}
.ice-lb-back p{font-size:14px;line-height:1.62;color:#3A352C;margin:0}
.ice-lb-hint{position:absolute;bottom:-30px;left:0;right:0;text-align:center;color:rgba(245,241,232,.7);font-size:12px;letter-spacing:.08em}
.ice-lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(245,241,232,.12);border:1px solid rgba(245,241,232,.3);color:#fff;
  width:48px;height:48px;border-radius:50%;font-size:24px;line-height:1;cursor:pointer;transition:.2s;
}
.ice-lb-nav:hover{background:rgba(245,241,232,.25)}
.ice-lb-prev{left:22px}.ice-lb-next{right:22px}
.ice-lb-x{position:absolute;top:20px;right:24px;background:none;border:0;color:#fff;font-size:36px;line-height:1;cursor:pointer}
@media(max-width:620px){
  .ice-lb-nav{display:none}
  #idyllic-card-explorer .ice-grid{grid-template-columns:repeat(auto-fill,minmax(98px,1fr));gap:18px 12px}
}
