:root{
  --bg:#f7f8fa; --card:#fff; --text:#111827; --muted:#6b7280; --ring:#e5e7eb;
  --chip:#eef2ff; --chip-text:#3730a3; --shadow:0 6px 24px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.06);
  --radius:16px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font:16px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--text);background:var(--bg)}

.topbar{position:sticky;top:0;z-index:10;background:linear-gradient(180deg,#fff,rgba(255,255,255,.92));
  border-bottom:1px solid var(--ring);padding:12px clamp(12px,3vw,28px);display:flex;gap:16px;align-items:center;justify-content:space-between}
.topbar h1{font-size:20px;margin:0;letter-spacing:.2px}
.controls{display:flex;gap:10px;align-items:center}
.controls input,.controls select{border:1px solid var(--ring);background:#fff;color:var(--text);
  padding:10px 12px;border-radius:10px;min-width:240px;box-shadow:inset 0 1px 0 rgba(0,0,0,.02)}
.controls select{min-width:170px}

.gallery{padding:clamp(14px,3vw,28px);display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:clamp(14px,2.4vw,24px)}
.card{background:var(--card);border:1px solid var(--ring);border-radius:var(--radius);box-shadow:var(--shadow);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .08s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.10),0 4px 12px rgba(0,0,0,.06)}

.media{background:#fff;aspect-ratio:16/11;display:flex;align-items:center;justify-content:center;overflow:hidden}
.media img{width:100%;height:100%;object-fit:contain}

.body{padding:14px 16px 10px;display:grid;gap:10px}
.title{margin:0;font-weight:700;font-size:18px;letter-spacing:.2px}
.meta{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--chip);color:var(--chip-text);
  padding:6px 10px;border-radius:999px;font-size:12.5px;font-weight:600;text-decoration:none}
.chip.muted{background:#f3f4f6;color:#374151}
.summary{color:var(--muted);font-size:14px}
.thumbstrip{display:flex;gap:6px;overflow:auto;padding-bottom:6px}
.thumbstrip img{width:26px;height:26px;object-fit:contain;border-radius:6px;border:1px solid var(--ring);background:#fff}

.empty{text-align:center;color:var(--muted);padding:40px;font-size:15px}

/* --- Carousel --- */
.crsl { position: relative; border-bottom: 1px solid rgba(0,0,0,.06); }

.crsl-viewport{
  position: relative;
  width: 100%;
  /* keep whatever height/ratio you were using; here’s a safe default: */
  aspect-ratio: 16 / 9;           /* or use a fixed height if you prefer */
  background: #f7f7f7;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-top-left-radius: 14px;
  border-top-right-radius: 14px;
}

.crsl-img{
  width: 100%;
  height: 100%;
  object-fit: contain;             /* <— fits image in the box */
  object-position: center;         /* <— center it */
  display: block;
  pointer-events: none;
}

.crsl-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.15);
  background: rgba(255,255,255,.9);
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .08s ease, background .15s ease;
}
.crsl-nav:hover{ background:#fff; transform: translateY(-50%) scale(1.04); }
.crsl-nav:active{ transform: translateY(-50%) scale(0.98); }

.crsl-nav.prev{ left: 10px; }
.crsl-nav.next{ right: 10px; }

/* Hide the dots (we’re using arrows only) */
.crsl-dots{ display: none !important; }
