/* Core look and feel. Variables come from inline style set by shortcode render or settings page. */
.cjg-timeline *{box-sizing:border-box}
.cjg-timeline{
  color:var(--ink); background:linear-gradient(180deg,var(--bg), #0a0e19);
  padding:2.5rem; border-radius:18px; position:relative; overflow:hidden;
}
.cjg-tl-header{display:flex; gap:1rem; align-items:center; justify-content:space-between; flex-wrap:wrap}
.cjg-tl-title{margin:0; font-size:clamp(1.25rem,2.4vw,1.8rem); letter-spacing:.3px}
.cjg-tl-controls{display:flex; align-items:center; gap:.75rem}
.cjg-btn{background:var(--chip); color:var(--ink); border:1px solid var(--line); border-radius:12px; padding:.55rem .8rem; font-size:1.15rem; line-height:1; cursor:pointer; transition:.2s ease}
.cjg-btn:hover{background:var(--chipOn); transform:translateY(-1px)}
.cjg-progress{width:min(32vw,320px); height:6px; background:var(--line); border-radius:999px; overflow:hidden}
.cjg-progress-bar{height:100%; width:0%; background:linear-gradient(90deg,var(--accent),#e6c784)}
.cjg-decades{display:flex; gap:.5rem; flex-wrap:wrap; margin:1rem 0 1.25rem}
.cjg-chip{appearance:none; border:1px solid var(--line); background:var(--chip); color:var(--ink); padding:.45rem .7rem; border-radius:999px; cursor:pointer; font-size:.95rem; transition:.2s}
.cjg-chip[aria-selected="true"], .cjg-chip:hover{background:var(--chipOn); border-color:var(--accent); color:#fff}
.cjg-tl-viewport{position:relative; overflow:auto; scroll-behavior:smooth; padding-bottom:.5rem}
.cjg-tl-viewport::-webkit-scrollbar{height:10px}
.cjg-tl-viewport::-webkit-scrollbar-thumb{background:var(--line); border-radius:999px}
.cjg-tl-track{display:grid; grid-auto-flow:column; gap:1rem; align-items:stretch; scroll-snap-type:x mandatory; padding:1rem 0 1.5rem; position:relative}
.cjg-tl-track::before{content:""; position:absolute; left:0; right:0; top:50%; height:2px; background:linear-gradient(90deg,transparent, var(--accent), transparent); opacity:.35; pointer-events:none}
.cjg-card{scroll-snap-align:center; width:min(70vw,520px); background:var(--card); border:1px solid var(--line); border-radius:18px; box-shadow:0 8px 20px rgba(0,0,0,.35); padding:1rem; display:flex; flex-direction:column; gap:.65rem; position:relative}
.cjg-pin{position:absolute; left:50%; transform:translate(-50%,-50%); top:0; width:12px; height:12px; background:var(--accent); border-radius:50%; box-shadow:0 0 0 6px rgba(198,161,91,.18)}
.cjg-year{font-weight:700; font-size:1.05rem; color:#fff; letter-spacing:.4px}
.cjg-title{font-size:1.05rem; margin:0}
.cjg-meta{color:var(--muted); font-size:.9rem; margin:0}
.cjg-img{width:100%; height:230px; object-fit:cover; border-radius:12px; border:1px solid var(--line); display:none}
.cjg-body{color:var(--ink); font-size:.98rem; line-height:1.45}
.cjg-more{align-self:flex-start; margin-top:.25rem; background:transparent; color:var(--accent); border:1px dashed var(--accent); border-radius:10px; padding:.35rem .6rem; cursor:pointer}
@media (max-width:900px){
  .cjg-tl-track{grid-auto-flow:row; scroll-snap-type:y mandatory}
  .cjg-tl-viewport{max-height:75vh}
  .cjg-card{width:100%}
  .cjg-progress{display:none}
}
.cjg-modal{border:none; border-radius:16px; padding:0; max-width:min(800px,92vw); width:100%; background:#0e1426; color:var(--ink)}
.cjg-modal::backdrop{background:rgba(0,0,0,.6)}
.cjg-modal-content{padding:1.25rem}
.cjg-modal-title{margin:.25rem 0 .25rem}
.cjg-modal-meta{margin:.25rem 0 .75rem; color:var(--muted)}
.cjg-modal-img{width:100%; max-height:55vh; object-fit:cover; border-radius:12px; border:1px solid var(--line); display:none}
.cjg-modal-close{position:absolute; top:.25rem; right:.5rem; background:transparent; color:#fff; border:none; font-size:1.75rem; cursor:pointer}
