/* =========================
   ARTWORK CARDS
   ========================= */
.sidebar .artwork-card {
  width: 100%; max-width: 320px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: 0 4px 10px var(--shadow);
  overflow: hidden; position: relative; cursor: pointer;
  transition: transform .2s ease-in-out; margin-bottom: 20px;
}
.artwork-card:hover { transform: translateY(-5px); }
.artwork-card { transition: transform .2s ease-in-out, box-shadow .2s ease-in-out; }
.artwork-card img { width: 100%; height: 200px; object-fit: cover; display: block; }
.artwork-title {
  font-size: 1.1rem !important; line-height: 1.2 !important; font-weight: bold;
  position: absolute; top: -14px; left: -14px;
  width: fit-content; max-width: 232px; display: inline-block;
  background: rgba(0,0,0,.6); color: #fff !important;
  padding: 5px 8px; border-radius: 5px;
}
.artwork-artist {
  font-size: .9rem; font-weight: bold;
  position: absolute; bottom: 6px; right: 6px;
  width: fit-content; max-width: 228px; display: inline-block;
  text-align: right; background: rgba(0,0,0,.6); color: #fff !important;
  padding: 5px 8px; border-radius: 5px;
}
.artwork-card-content { padding: 10px 10px 2px 10px; position: relative; background: transparent; }
.artwork-description {
  font-family: 'Source Sans Pro', sans-serif; font-size: .9rem; color: var(--text); margin: -3px 0 5px;
  line-height: 1.2;
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3;
  overflow: hidden; text-overflow: ellipsis; position: relative;
}
.artwork-description > * { display: inline; margin: 0; padding: 0; }
.artwork-description br { display: none; }
.artwork-description::after {
  content: ""; position: absolute; right: 0; bottom: 0; left: 0;
  height: 0.4em; background: linear-gradient(transparent, var(--card)); pointer-events: none;
}
.arrow-indicator { position: absolute; bottom: 10px; right: 10px; font-size: 1.2rem; color: var(--brand); transition: transform .2s ease-in-out; }
.artwork-card:hover .arrow-indicator { transform: translateX(2px); }
.artwork-card a { color: inherit; text-decoration: none; }

/* Grid card variant */
.grid-cards .artwork-card {
  width: 100%; background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: 0 4px 10px var(--shadow);
  height: 200px !important; overflow: hidden; position: relative;
  cursor: pointer; transition: transform .2s ease-in-out; container-type: inline-size;
}
.grid-cards .artwork-title {
  font-size: 1.1rem !important; line-height: 1.2 !important; font-weight: bold;
  position: absolute; top: 6px; left: 6px;
  width: fit-content; max-width: calc(100% - 12px); white-space: normal; text-align: left !important;
  background: rgba(0,0,0,.6); color: #fff !important; padding: 5px 8px; border-radius: 5px;
}
.sidebar .artwork-card { max-width: 320px; }

/* Title/artist overlays in artworks panel and artist grid */
.artwork-title {
  font-size: 1.1rem !important; line-height: 1.2 !important; font-weight: bold;
  position: absolute; top: 6px; left: 6px;
  width: fit-content; max-width: calc(100% - 12px) !important;
  white-space: normal; text-align: left;
  background: rgba(0,0,0,.6); color: #fff !important; padding: 5px 8px; border-radius: 5px;
}
.artwork-artist {
  font-size: .9rem !important; font-weight: bold;
  position: absolute; bottom: 6px; right: 6px;
  width: fit-content; max-width: calc(100% - 12px) !important;
  white-space: normal; text-align: right;
  background: rgba(0,0,0,.6); color: #fff !important; padding: 5px 8px; border-radius: 5px;
}

/* Container query: hide labels when card is very narrow */
@container (max-width: 130px) {
  .artwork-card .artwork-title,
  .artwork-card .artwork-artist { display: none !important; }
}
@container (max-width: 120px) {
  .city-button span { display: none !important; }
}

/* Full artwork page description */
.artwork-container .artwork-description,
.artwork-details .artwork-description { display: block; -webkit-line-clamp: initial; -webkit-box-orient: initial; overflow: visible; }
.artwork-container .artwork-description ul,
.artwork-container .artwork-description ol,
.artwork-details ul,
.artwork-details ol { list-style: disc outside; padding-left: 1.25rem; margin: .5rem 0; }
.artwork-container .artwork-description li,
.artwork-details li { display: list-item !important; margin: .25rem 0; line-height: 1.6; }

/* Credit badge */
.artwork-credit-badge {
  position: absolute; top: 6px; right: 6px;
  width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; z-index: 2; box-shadow: 0 1px 4px rgba(0,0,0,0.35);
}
.artwork-credit-collaboration { background: rgba(80, 80, 90, 0.85); color: #fff; }
.artwork-credit-collective { background: rgba(215, 21, 58, 0.85); color: #fff; }
.artwork-credit-line {
  font-size: .9rem; font-style: italic;
  font-family: 'Source Sans Pro', sans-serif; color: var(--muted);
  margin: 0 0 4px; line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.artwork-card-content:has(.artwork-credit-line) .artwork-description { -webkit-line-clamp: 2; }

/* =========================
   ARTWORK PAGE (MAIN)
   ========================= */
.artwork-images img {
  max-width: 600px; height: auto; border-radius: 8px; object-fit: cover;
  margin: 2px 0; display: block; box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}
.artwork-container { max-width: 900px; margin: auto 0px; padding: 20px; background: transparent; overflow: hidden; flex: 3; }
.artwork-header { margin-bottom: 20px; }
.artwork-header h1 { font-size: 2rem; font-weight: 700; margin: 0; color: var(--text); }
.artwork-header p { font-size: 1.2rem; font-weight: 600; margin: 5px 0 0; color: var(--brand); }
.artwork-content { margin: 20px 0 100px; }
.artwork-content img { width: 100%; max-width: 800px; margin: 10px 0; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
.artwork-details { margin-top: 20px; }
.artwork-details p { margin: 10px 0; line-height: 1.5; font-size: 1rem; color: var(--text); }
.artwork-details strong { color: var(--text); }

.content-container { display: flex; flex-direction: row; max-width: 1200px; margin: 100px auto; padding: 20px; gap: 20px; }
@media (max-width: 768px) {
  .content-container { flex-direction: column; gap: 10px; }
  .artwork-container { flex: none; }
  .side-panel { position: relative; max-height: none; top: auto; }
}

/* Side panel */
.side-panel {
  top: 100px; flex: 1; background: transparent; padding: 20px;
  border-radius: 0; position: sticky; top: 100px;
  max-height: calc(100vh - 140px);
  overflow-y: auto; scrollbar-width: none; -ms-overflow-style: none;
}
.side-panel::-webkit-scrollbar { display: none; }
.thumbnail-container { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; margin-bottom: 40px; }
.thumbnail-container img { width: 90px; height: 90px; object-fit: cover; border-radius: 2px; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease; }
.thumbnail-container img:hover { transform: scale(1.05); }
.side-panel-details p { font-size: 1rem; margin: 5px 0; color: var(--text); display: flex; align-items: center; padding: 6px; }
.side-panel-details a { text-decoration: none; color: var(--text); transition: color .3s ease; }
.side-panel-details a:hover { color: var(--brand); }
.side-panel-details i { width: 20px; height: 20px; display: flex; justify-content: center; margin-right: 16px; color: var(--muted); font-size: 24px; flex-shrink: 0; }
#main-image { max-width: 100%; height: auto; border-radius: 8px; box-shadow: 0 4px 6px rgba(0,0,0,0.1); }

@media (min-width: 768px) {
  .side-panel { position: sticky; top: 100px; flex: 0 0 320px; width: 320px; max-width: 320px; }
  .side-panel > * { max-width: 320px; margin-left: 0px; margin-right: 0px; }
  .side-panel .thumbnail-container { display: grid; grid-template-columns: repeat(3, 90px); gap: 6px; justify-content: center; width: max-content; }
  .side-panel .thumbnail-container img { width: 90px; height: 90px; object-fit: cover; }
}
@media (max-width: 768px) {
  .side-panel { width: 100%; max-width: none; }
}

.bottom-panel { flex: 1; background: transparent; border-radius: 0; padding-top: 30px; top: 100px; font-size: .8em; color: var(--muted); }

/* Chronology strip */
.chron-strip { margin: 16px 0; font-size: 0.8em; }
.chron-label { font-size: 0.75em; text-transform: uppercase; letter-spacing: 0.08em; opacity: 0.5; margin-bottom: 6px; }
.chron-row { display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: stretch; border: 1px solid rgba(128,128,128,0.25); border-radius: 6px; overflow: hidden; }
.chron-cell { padding: 8px 6px; text-align: center; border-right: 1px solid rgba(128,128,128,0.2); box-sizing: border-box; display: flex; flex-direction: column; align-items: stretch; justify-content: flex-start; }
.chron-cell:last-child { border-right: none; }
.chron-cell--current { background: rgba(128,128,128,0.08); }
.chron-empty { margin: auto 0; }
.chron-title a { color: inherit; text-decoration: underline; text-underline-offset: 2px; }
.chron-title strong { display: block; }
.chron-year { opacity: 0.6; font-size: 0.9em; margin-top: 2px; }
.chron-empty { opacity: 0.3; text-align: center; }
.chron-item { width: 100%; }
.chron-item + .chron-item { border-top: 1px solid rgba(128,128,128,0.2); margin-top: 6px; padding-top: 6px; }
.chron-thumb {
  width: 64px; height: 64px; border-radius: 50%;
  background-position: center; background-size: 200%;
  background-blend-mode: overlay; background-color: rgba(255,255,255,0.05);
  box-shadow: inset 2px 2px 4px rgba(255,255,255,0.6), inset -2px -2px 4px rgba(0,0,0,0.4), 0 4px 8px rgba(0,0,0,0.3), 0 0 10px rgba(255,255,255,0.2);
  border: 1.5px solid rgba(0,0,0,0.1); outline: 1px solid rgba(255,255,255,0.2); outline-offset: -2px; margin: 0 auto 6px;
}

/* Mobile thumbs under main image */
.mobile-thumbs { display: none; margin: 0px; gap: 2px; justify-content: center; }
.mobile-thumbs img { width: 64px; height: 64px; object-fit: cover; border-radius: 4px; box-shadow: 0 2px 4px rgba(0,0,0,0.08); cursor: pointer; transition: transform .15s ease; }
.mobile-thumbs img:hover { transform: scale(1.05); }
@media (max-width: 768px) {
  .mobile-thumbs { display: flex; flex-wrap: wrap; justify-content: center; align-content: flex-start; row-gap: 2px; column-gap: 2px; }
  .mobile-thumbs img { display: block; margin: 0; }
  .side-panel .thumbnail-container { display: none !important; }
}