/* ============================================================
   THE ATLAS — The Canon (books & source-texts) view styles
   Append to css/views.css, or link as a separate stylesheet.
   Uses the existing design tokens from css/tokens.css.
   ============================================================ */

/* ---- no underlines anywhere in the Canon (match the native link style) ---- */
.canon-view a, .canon-detail a,
.canon-view a:hover, .canon-detail a:hover{ text-decoration:none; }

/* ---- author portrait (replaces the initials monogram) ---- */
.canon-portrait{ flex:0 0 54px; width:54px; height:54px; border-radius:50%; overflow:hidden;
  border:1px solid var(--ink-700); background:var(--ink-800); }
.canon-portrait img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ---- filter ---- */
.canon-filter{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:var(--space-5)}
.canon-fbtn{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--parchment-3);background:none;border:1px solid var(--ink-600);border-radius:var(--r-pill);
  padding:9px 16px;cursor:pointer;transition:color var(--dur-quick),border-color var(--dur-quick)}
.canon-fbtn:hover{color:var(--parchment);border-color:var(--gold-600)}
.canon-fbtn.on{color:var(--void);background:var(--grad-gold);border-color:transparent}

/* ---- index sections + cards ---- */
.canon-sec{margin-top:var(--space-7);padding-top:var(--space-5);border-top:1px solid var(--ink-700)}
.canon-sec-h{font-family:var(--font-display);font-weight:400;font-size:var(--t-h2)}
.canon-sec-sub{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--parchment-4);margin:2px 0 var(--space-5)}
.canon-card{display:block;position:relative;overflow:hidden}
.canon-card::before{content:"";position:absolute;inset:0 auto 0 0;width:2px;
  background:var(--grad-gold);opacity:0;transition:opacity var(--dur-base)}
.canon-card:hover::before{opacity:1}
.canon-yr{font-family:var(--font-mono);font-size:.7rem;color:var(--parchment-4)}
.canon-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:7px;vertical-align:middle}
.canon-dot.d-foundational{background:var(--gold-100)}
.canon-dot.d-pillars{background:var(--gold)}
.canon-dot.d-living{background:var(--teal)}
.canon-card .card-title{font-family:var(--font-display);font-weight:400;font-size:1.3rem;line-height:1.12;margin:8px 0 5px}
.canon-by{color:var(--gold);font-size:.9rem}
.canon-badges{margin-top:13px;display:flex;gap:6px;flex-wrap:wrap}
.canon-bdg{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;padding:3px 8px;
  border-radius:var(--r-pill);border:1px solid var(--ink-600);color:var(--parchment-3)}
.canon-bdg.q{color:var(--gold-100);border-color:var(--gold-600)}
.canon-bdg.p{color:var(--teal);border-color:var(--teal)}

/* ---- detail ---- */
.canon-narrow{max-width:760px}
.canon-detail .crumb{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--parchment-4);margin-bottom:var(--space-5)}
.canon-detail .crumb a{color:var(--gold)}
.canon-topline{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.canon-save{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--parchment-3);background:none;border:1px solid var(--ink-600);border-radius:var(--r-pill);
  padding:7px 14px;cursor:pointer;white-space:nowrap;transition:.3s}
.canon-save:hover,.canon-save.on{border-color:var(--gold);color:var(--gold-100)}
.canon-title{font-size:clamp(2.1rem,6vw,3.4rem);line-height:1.05;margin:10px 0 8px}
.canon-meta{color:var(--parchment-2)}
.canon-meta a{color:var(--gold);border-bottom:1px solid var(--gold-600)}
.canon-attrib{color:var(--parchment-3);font-size:.95rem;margin-top:4px}
.canon-fam{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--parchment-3);border:1px solid var(--ink-600);border-radius:var(--r-pill);padding:5px 11px;
  display:inline-block;margin-top:14px}
.canon-rule{height:1px;background:var(--grad-hairline);margin:var(--space-6) 0}
.canon-summary p{font-family:var(--font-display);font-size:1.16rem;line-height:1.66;margin-bottom:16px;color:var(--parchment)}
.canon-summary em{font-style:italic;color:var(--gold-100)}
.canon-eyebrow{margin:var(--space-6) 0 var(--space-4);display:flex;align-items:baseline;gap:10px}
.canon-eyebrow span{font-family:var(--font-mono);font-size:.64rem;color:var(--parchment-4);letter-spacing:.06em;text-transform:none}
.canon-q{border-left:2px solid var(--gold-600);padding:4px 0 4px 20px;margin:16px 0}
.canon-q p{font-family:var(--font-display);font-style:italic;font-size:1.14rem;color:var(--parchment)}
.canon-q cite{display:block;font-style:normal;font-size:.76rem;color:var(--parchment-3);margin-top:7px;font-family:var(--font-mono)}
.canon-tr b{font-family:var(--font-mono);font-size:.68rem;color:var(--gold-100);margin-right:6px}
.canon-lx{font-family:var(--font-display);font-style:italic}
.canon-pr{display:block;border:1px solid var(--ink-700);border-radius:var(--r-lg);padding:15px 18px;margin-bottom:11px;transition:border-color .3s}
.canon-pr:hover{border-color:var(--gold-600)}
.canon-pr h4{font-family:var(--font-display);font-weight:400;font-size:1.06rem;margin-bottom:5px;color:var(--gold-100)}
.canon-pr p{color:var(--parchment-2);font-size:.92rem;line-height:1.5}
.canon-lin{display:grid;gap:16px}
.canon-lab{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--parchment-4);margin-bottom:9px}
.canon-authcard{display:flex;gap:16px;align-items:center;border:1px solid var(--ink-700);border-radius:var(--r-lg);padding:18px;transition:border-color .3s}
.canon-authcard:hover{border-color:var(--gold-600)}
.canon-mono{flex:0 0 54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.25rem;color:var(--void);background:var(--grad-gold)}
.canon-auth-body{flex:1}
.canon-auth-body .nm{display:block;font-family:var(--font-display);font-size:1.18rem;color:var(--parchment)}
.canon-auth-body .co{display:block;color:var(--parchment-3);font-size:.9rem;margin-top:2px}
.canon-auth-go{color:var(--gold);font-size:.8rem;font-family:var(--font-mono);white-space:nowrap}
.canon-rel{display:flex;gap:12px;flex-wrap:wrap}
.canon-rb{flex:1 1 200px;border:1px solid var(--ink-700);border-radius:var(--r-lg);padding:14px 16px;
  font-family:var(--font-display);color:var(--parchment);transition:.3s}
.canon-rb:hover{border-color:var(--gold-600);transform:translateY(-2px)}
.canon-rb span{display:block;font-family:var(--font-mono);font-size:.66rem;color:var(--parchment-4);margin-top:4px}
.canon-rb.dead{opacity:.7}
.canon-rb.dead:hover{transform:none;border-color:var(--ink-700)}
