
/* Charter webfonts */
@font-face { font-family:'Charter Web'; src:url('../fonts/Charter-Regular.woff') format('woff'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Charter Web'; src:url('../fonts/Charter-Italic.woff') format('woff'); font-weight:400; font-style:italic; font-display:swap; }
@font-face { font-family:'Charter Web'; src:url('../fonts/Charter-Bold.woff') format('woff'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'Charter Web'; src:url('../fonts/Charter-BoldItalic.woff') format('woff'); font-weight:700; font-style:italic; font-display:swap; }

/* === Surface tokens === */
.cv-surface{--text:#2f2f2f;--surface:#f2dbb3;--panel:#ecdcbc;--panel-strong:#f1e3c8;--border:#d2bfa0}
.cv-surface,.cv-surface .wp-site-blocks{background:var(--surface);color:var(--text);font-family:'Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
html,body.cv-surface{background:var(--surface)}

/* === Shell + typography === */
.cv-shell{max-width:1240px;margin:0 auto;padding:28px 20px 64px}
.cv-h1,.cv-h2{font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;color:var(--text);letter-spacing:.1px}
.cv-h1{font-size:42px;line-height:1.1;font-weight:700;margin:0 0 6px}
.cv-h2{font-size:22px;font-weight:700;margin:16px 0 12px}

/* === Topbar + logo === */
.cv-topbar{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;margin-bottom:65px}
.cv-brand{display:inline-flex;align-items:center;text-decoration:none}
.cv-logo-img{height:100px;width:auto;display:block}
@media (max-width:760px){.cv-logo-img{height:80px}}

/* === Controls + search === */
.cv-controls{display:grid;grid-auto-flow:column;gap:10px;justify-content:end;align-items:center}
.cv-input,.cv-select{background:var(--panel-strong);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:10px;font-size:14px;outline:none}
.cv-input--lg{min-width:clamp(300px,55vw,760px);height:56px;border-radius:999px;font-size:16px;padding-left:44px;padding-right:44px;text-align:center}
.cv-searchwrap{position:relative}
.cv-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);font-size:18px;opacity:.9;pointer-events:none}

/* === Toolbar + folder/sort controls === */
.cv-toolbar{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:16px;margin:6px 0 20px}
.cv-toolbar-controls{display:flex;align-items:baseline;gap:0}
.cv-label{font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;font-size:20px;font-weight:700;margin-right:5px}
.cv-select+.cv-label{margin-left:24px}

/* === Collection grid === */
.cv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.cv-card{display:flex;flex-direction:column;color:inherit;background:var(--panel-strong);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease}
.cv-cardlink{display:block;color:inherit;text-decoration:none}
.cv-metalink{display:block}
.cv-thumbwrap{position:relative;aspect-ratio:1/1;overflow:hidden;flex-shrink:0;background:#e6cda0}
.cv-thumbwrap > .cv-cardlink{position:absolute;inset:0;display:block}
.cv-thumbwrap > .cv-cardlink img{width:100%;height:100%;object-fit:cover;display:block}

/* === WhoSampled badge === */
.cv-sample-badge{
  position:absolute;
  left:0;
  top:0;
  z-index:3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px;
  background:#d17d34;
  color:#f2dbb3;
  text-decoration:none;
  border-radius:0 0 8px 0;
}
.cv-sample-badge:hover{transform:translateY(-1px)}
.cv-thumbwrap img.cv-sample-ico{width:22px !important;height:22px !important;object-fit:contain !important;display:block;}
.cv-sample-badge:focus{outline:2px solid rgba(47,47,47,.55);outline-offset:2px}
/* Icon is a media-library PNG; sizing handled by .cv-sample-ico */

/* === Card metadata === */
.cv-meta{padding:10px 12px 12px}
.cv-title{font-weight:700;font-size:15px;line-height:1.25;margin-bottom:4px;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cv-artist{font-size:12px;color:#4c4c4c;white-space:normal;overflow:visible;word-break:break-word}

/* === Album hero layout === */
.cv-hero{display:grid;grid-template-columns:384px 1fr;gap:36px;margin-bottom:30px}
.cv-coverwrap{position:static;top:auto;align-self:start}
.cv-cover{width:100%;height:auto;display:block;border-radius:8px;border:1px solid var(--border);background:var(--panel-strong);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.cv-artistline{font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;color:#3a3a3a;margin:0 0 20px;font-size:28px;font-weight:400}
.cv-details{display:grid;grid-template-columns:1fr;gap:8px;color:var(--text)}
.cv-group{margin-bottom:15px}

/* === Details grid === */
.cv-detail{display:grid;grid-template-columns:240px 1fr;gap:10px;align-items:baseline}
.cv-dt{font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;font-weight:700;font-size:20px;white-space:nowrap}
.cv-dd{font-family:'Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-weight:400;font-size:20px}
.cv-details .cv-group{margin-bottom:24px}
.cv-linkico{width:18px;height:18px;display:inline-block;vertical-align:-2px;margin-left:8px;margin-right:0;flex-shrink:0}
.cv-dt .cv-dt-link{display:inline-flex;align-items:center;text-decoration:underline;color:var(--text);font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;font-weight:700}
.cv-dt .cv-dt-link .cv-linkico{width:18px;height:18px;margin-left:8px;margin-right:0;flex-shrink:0}

/* === Album summary === */
.cv-summary-wide{margin:30px 0 40px;background:var(--panel-strong);border:1px solid var(--border);border-radius:10px;padding:14px}
.cv-summary-wide h2{margin:0 0 6px;font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;font-size:22px;font-weight:700;color:#2f2f2f}
.cv-summary-wide p{margin:0;font-size:14px;line-height:1.55;color:#3a3a3a}

/* === Tracklist === */
.cv-tracklist{list-style:none;margin:0;padding:0;border-top:1px solid var(--border)}
.cv-track{display:grid;grid-template-columns:1fr;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);background:rgba(0,0,0,.05)}
.cv-track:nth-child(even){background:transparent}
.cv-vsep{align-self:stretch;width:1px;background:var(--border)}
.cv-pos{font-variant-numeric:tabular-nums;font-weight:700;font-size:20px;color:#2f2f2f;padding-left:25px;padding-right:0}
.cv-name{font-size:20px;font-weight:400;color:#2f2f2f}
.cv-dur{text-align:right;font-size:20px;color:#2f2f2f;padding-right:25px}
.cv-ico-col{display:flex;align-items:center;justify-content:center;padding:0 8px}
.cv-runtime{text-align:right;margin-top:25px;font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;font-size:20px;font-weight:700;color:#2f2f2f;padding-right:25px}

/* === Chip sections === */
.cv-section{margin-top:35px}
.cv-section h3{font-family:'Charter Web', Charter, Georgia, 'Times New Roman', serif;font-size:20px;font-weight:700;margin:0 0 10px}
.cv-chiplist{display:flex;flex-wrap:wrap;gap:10px}
.cv-chiplink,.cv-chiptext{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:var(--panel-strong);border:1px solid var(--border);font-size:12px;color:var(--text);text-decoration:none}
.cv-wiki-chip{display:inline-flex;align-items:center}
.cv-wiki-chip .cv-chiplink{word-break:break-all}

/* === Complimentary albums === */
.cv-comps-section{margin-top:40px}
.cv-comps-wrap{position:relative}
.cv-comps{overflow-x:auto;display:grid;grid-auto-flow:column;gap:14px;grid-auto-columns:160px;padding-bottom:6px;scroll-snap-type:x mandatory;scrollbar-width:none}
.cv-comps::-webkit-scrollbar{display:none}
.cv-comp{scroll-snap-align:start;display:block;color:inherit;text-decoration:none;background:var(--panel-strong);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.cv-comp img{width:100%;object-fit:cover;display:block}
.cv-comp .cv-comp-meta{padding:8px}
.cv-comp-title{font-size:12px;font-weight:700;line-height:1.25}
.cv-comp-artist{font-size:11px;color:#4c4c4c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cv-comp-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border:1px solid var(--border);background:var(--panel-strong);border-radius:999px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.95;box-shadow:0 4px 10px rgba(0,0,0,.08);z-index:2}
.cv-comp-prev{left:-4px}
.cv-comp-next{right:-4px}
.cv-comp-nav svg{width:22px;height:22px;fill:#2f2f2f}

/* === Divider + footer === */
.cv-hr{border:0;border-top:1px solid #000;margin:70px 0}
.cv-footer{max-width:1240px;margin:70px auto 40px;padding:12px 20px;text-align:center;color:var(--text);font-size:16px;border-top:none}

/* === Track row grid === */
article.cv-album section.cv-tracks .cv-track-main,
section.cv-tracks .cv-track-main{
  display:grid;
  grid-template-columns: 100px 1fr 65px;
  align-items:center;
  column-gap:.5rem;
}

.cv-name{padding:0 8px}

article.cv-album section.cv-tracks .cv-dur{
  text-align:right;
  padding-right:25px;
}
article.cv-album section.cv-tracks .cv-runtime{
  text-align:right;
  padding-right:25px;
  margin-right:0;
}

/* === Spotify track link === */
.cv-track-link{
  color:inherit;
  text-decoration:underline;
  text-underline-offset:2px;
  text-decoration-color:rgba(47,47,47,.45);
}
.cv-track-link:hover{
  text-decoration-color:rgba(47,47,47,.9);
}

/* === Album summary + chip polish === */
article.cv-album .cv-summary-wide{
  padding: 30px;
  margin: 40px 0 40px;
}
article.cv-album .cv-section .cv-h3{ margin-bottom: 15px; }

article.cv-album .cv-chiplink,
article.cv-album .cv-chiptext,
article.cv-album .cv-wikilink .cv-chiplink,
article.cv-album .cv-wikilink .cv-chiptext{
  padding: 14px 25px;
  border-radius: 10px;
}

/* === Chip title case === */
article.cv-album .cv-chiplist .cv-chiptext,
article.cv-album .cv-chiplist .cv-chiplink { text-transform: capitalize; }

/* === Album details label/value columns === */
article.cv-album .cv-details .cv-detail {
  display: grid;
  grid-template-columns: 150px 1fr;
}

/* === External links spacing === */
body .cv-infoblock .cv-details .cv-group.cv-links {
  margin: 20px 0 0 0 !important;
}

/* === Complimentary albums 5-wide grid === */
.cv-comps.cv-grid-5{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}
.cv-comps.cv-grid-5 {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  grid-auto-flow: row !important;
  gap: 14px !important;
  overflow: visible !important;
  white-space: normal !important;
}
.cv-comps.cv-grid-5 > * {
  width: auto !important;
  flex: none !important;
  display: block !important;
}
.cv-comp{display:block;background:#ead6b6;border-radius:12px;overflow:hidden;text-decoration:none;color:inherit}
.cv-comp img{width:100%;display:block;aspect-ratio:1/1;object-fit:cover}
.cv-comp-meta{padding:10px 12px}
.cv-comps-actions{margin-top:12px}
.cv-comps-actions { margin-top: 14px; }
.cv-comps-wrap, .cv-comps-track, .cv-comp-nav, .cv-comp-prev, .cv-comp-next {
  display: none !important;
}
.cv-btn{border:1px solid #2f2f2f;background:transparent;padding:8px 12px;border-radius:8px;cursor:pointer}

/* === Artist discography box === */
article.cv-album .cv-artist-discography .cv-discog-box{
  max-width: none !important;
  width: fit-content;
  display: inline-block;
  padding-left: 18px;
  padding-right: 18px;
}

/* ===========================================
   Responsive — tablet (≤760px)
   =========================================== */
@media (max-width:760px){

  /* Shell */
  .cv-shell{padding:20px 16px 48px}

  /* Topbar: stack logo above search, centered */
  .cv-topbar{grid-template-columns:1fr;gap:12px;margin-bottom:28px;justify-items:center}
  .cv-logo-img{height:70px;width:auto;max-width:260px}
  .cv-controls{justify-content:stretch;width:100%}
  .cv-searchwrap{width:100%}
  .cv-input--lg{min-width:unset;width:100%;box-sizing:border-box}

  /* Toolbar: stack heading above controls; each label+select pair gets its own full-width row */
  .cv-toolbar{grid-template-columns:1fr;gap:8px;margin-bottom:26px}
  .cv-toolbar-controls{display:grid;grid-template-columns:auto 1fr;gap:8px 10px;width:100%}
  .cv-select+.cv-label{margin-left:0}
  .cv-toolbar-controls .cv-select{width:100%}
  .cv-label{font-size:16px}

  /* Typography */
  .cv-h1{font-size:30px}
  .cv-h2{font-size:19px}
  .cv-artistline{font-size:22px;margin-bottom:16px}

  /* Album hero: stack cover above info */
  .cv-hero{grid-template-columns:1fr;gap:20px;margin-bottom:20px}

  /* Album details: tighter label column */
  .cv-detail{grid-template-columns:110px 1fr}
  article.cv-album .cv-details .cv-detail{grid-template-columns:110px 1fr}
  .cv-dt,.cv-dd{font-size:17px}

  /* Tracklist: shrink fixed columns */
  article.cv-album section.cv-tracks .cv-track-main,
  section.cv-tracks .cv-track-main{grid-template-columns:60px 1fr 50px}
  .cv-pos{font-size:16px;padding-left:14px}
  .cv-name{font-size:16px}
  .cv-dur{font-size:16px;padding-right:14px}
  .cv-runtime{font-size:16px;padding-right:14px;margin-top:16px}

  /* Album chips */
  article.cv-album .cv-chiplink,
  article.cv-album .cv-chiptext,
  article.cv-album .cv-wikilink .cv-chiplink,
  article.cv-album .cv-wikilink .cv-chiptext{padding:10px 16px}

  /* Album summary */
  article.cv-album .cv-summary-wide{padding:20px;margin:24px 0}

  /* Complimentary albums: 2 columns */
  .cv-comps.cv-grid-5{grid-template-columns:repeat(2,minmax(0,1fr)) !important}

  /* Spacing */
  .cv-section{margin-top:24px}
  .cv-hr{margin:40px 0}
  .cv-footer{margin-top:32px}
}

/* ===========================================
   Responsive — phone (≤480px)
   =========================================== */
@media (max-width:480px){

  /* Shell */
  .cv-shell{padding:14px 12px 36px}

  /* Topbar */
  .cv-topbar{margin-bottom:18px}
  .cv-logo-img{height:58px}

  /* Collection grid: 2 columns */
  .cv-grid{grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px}

  /* Toolbar: label font tighter */
  .cv-label{font-size:14px}
  .cv-select{font-size:13px;padding:7px 8px}

  /* Typography */
  .cv-h1{font-size:24px}
  .cv-h2{font-size:17px}
  .cv-artistline{font-size:18px}

  /* Album details: keep 2-column, narrow label */
  .cv-detail,
  article.cv-album .cv-details .cv-detail{grid-template-columns:90px 1fr;gap:2px}
  .cv-dt{font-size:14px}
  .cv-dd{font-size:15px}
  .cv-details .cv-group{margin-bottom:16px}

  /* Tracklist: compact */
  article.cv-album section.cv-tracks .cv-track-main,
  section.cv-tracks .cv-track-main{grid-template-columns:46px 1fr 52px}
  .cv-pos{font-size:13px;padding-left:10px}
  .cv-name{font-size:14px}
  .cv-dur{font-size:13px;padding-right:10px}
  .cv-runtime{font-size:13px;padding-right:10px}

  /* Complimentary albums: stay 2 columns */
  .cv-comps.cv-grid-5{grid-template-columns:repeat(2,minmax(0,1fr)) !important}

  /* Album chips */
  article.cv-album .cv-chiplink,
  article.cv-album .cv-chiptext,
  article.cv-album .cv-wikilink .cv-chiplink,
  article.cv-album .cv-wikilink .cv-chiptext{padding:8px 12px;font-size:12px}

  /* Album summary */
  article.cv-album .cv-summary-wide{padding:14px}

  /* Section headings */
  .cv-section h3{font-size:16px}

  /* Divider */
  .cv-hr{margin:28px 0}
}
