/* The Cayman Files — chapter reader styles */

.reader{padding:80px 0 120px}
.reader-header{text-align:center;margin-bottom:64px;padding:0 24px}
.reader-header .eyebrow-center{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:24px}
.reader-header .bar-sm{width:36px;height:1px;background:var(--gold)}
.reader-header .label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.24em;text-transform:uppercase;color:var(--gold)}
.reader-header h1{font-family:'Fraunces',serif;font-weight:800;font-size:clamp(40px,6vw,80px);line-height:0.98;letter-spacing:-0.025em;margin:0 0 12px}
.reader-header .subtitle{font-family:'Fraunces',serif;font-style:italic;color:var(--gold);font-size:clamp(20px,2.2vw,28px);margin:0 0 24px}
.reader-header .tagline{color:var(--ink-2);max-width:60ch;margin:0 auto;font-size:16px;line-height:1.6}
.reader-header .meta-row{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:32px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted)}
.reader-header .meta-row span:not(:last-child)::after{content:'·';margin-left:16px;color:var(--line)}

/* Chapter card */
.chapter{border:1px solid var(--line);background:var(--bg-2);margin-bottom:28px;border-radius:var(--r);overflow:hidden;transition:border-color .2s}
.chapter.is-locked{opacity:0.62}
.chapter.is-locked:hover{opacity:0.85}
.chapter:hover{border-color:var(--gold-2)}

.chapter-head{padding:24px 28px;border-bottom:1px solid var(--line);background:var(--bg-3);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.chapter-head-left{display:flex;align-items:center;gap:18px;min-width:0;flex:1}
.chapter-num{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:36px;color:var(--gold);line-height:1;min-width:54px}
.chapter-title-block{min-width:0}
.chapter-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.chapter-title{font-family:'Fraunces',serif;font-weight:700;font-size:24px;letter-spacing:-0.015em;margin:0;line-height:1.15}
.chapter-meta{display:flex;align-items:center;gap:14px;color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;white-space:nowrap}
.chapter-meta .lock-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--gold);color:var(--gold);border-radius:2px}
.chapter-meta .free-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--gold);color:#0a0a0a;border-radius:2px;font-weight:700}

.chapter-body{padding:28px;display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:36px;align-items:start}
@media(max-width:880px){.chapter-body{grid-template-columns:1fr;gap:24px}}

.chapter-audio-col{position:sticky;top:96px}
.chapter-audio-shell{border:1px solid var(--line);background:var(--bg-3);padding:18px;border-radius:var(--r)}
.chapter-audio-shell .player-label{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-2)}
.chapter-audio-shell .player-label .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 12px var(--red);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}
.chapter-audio-shell audio{width:100%;height:42px;filter:invert(0.94) hue-rotate(180deg) contrast(0.92)}
.chapter-audio-shell .caption{font-size:11px;color:var(--muted);margin-top:10px;font-family:'JetBrains Mono',monospace;letter-spacing:0.08em;text-transform:uppercase}
.chapter-locked-shell{border:1px dashed var(--gold);background:rgba(212,169,96,0.04);padding:24px;border-radius:var(--r);text-align:center}
.chapter-locked-shell .lock-icon{font-size:32px;color:var(--gold);margin-bottom:10px}
.chapter-locked-shell .lock-title{font-family:'Fraunces',serif;font-size:17px;color:var(--ink);margin:0 0 6px}
.chapter-locked-shell .lock-text{font-size:13px;color:var(--ink-2);line-height:1.5;margin:0 0 16px}
.chapter-locked-shell .btn{font-size:12px;padding:10px 16px}

.chapter-text-col{font-family:'Fraunces',serif;font-size:17px;line-height:1.75;color:var(--ink-2)}
.chapter-text-col p{margin:0 0 18px}
.chapter-text-col p:first-child::first-line{font-variant:small-caps;letter-spacing:0.06em;color:var(--ink)}
.chapter-text-col p em{color:var(--gold);font-style:italic}
.chapter-text-col .gated-synopsis{font-style:italic;color:var(--muted);padding:18px;border-left:2px solid var(--gold);background:rgba(212,169,96,0.03)}
.chapter-text-col .gated-blur{filter:blur(4px);user-select:none;pointer-events:none}

/* Gate banner (frontstage) */
.gate-banner{margin:32px 0 56px;padding:36px;border:1px solid var(--gold);background:linear-gradient(135deg,rgba(212,169,96,0.08),rgba(212,169,96,0.02));border-radius:var(--r);text-align:center}
.gate-banner h3{font-family:'Fraunces',serif;font-weight:800;font-size:clamp(22px,3vw,32px);margin:0 0 10px;line-height:1.2}
.gate-banner h3 em{color:var(--gold);font-style:italic}
.gate-banner p{color:var(--ink-2);margin:0 auto 22px;max-width:52ch}
.gate-banner .price{display:flex;align-items:baseline;justify-content:center;gap:14px;margin:18px 0 22px}
.gate-banner .price .dollar{font-family:'Fraunces',serif;font-weight:800;font-size:48px;color:var(--gold);line-height:1}
.gate-banner .price .strike{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--muted);text-decoration:line-through}
.gate-banner .price .note{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold)}

/* Email gate inline */
.email-gate{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r);padding:28px;margin:20px 0 32px}
.email-gate h4{font-family:'Fraunces',serif;font-size:22px;margin:0 0 8px;line-height:1.2}
.email-gate p{color:var(--ink-2);font-size:14px;margin:0 0 18px;line-height:1.55}
.email-gate form{display:flex;gap:10px;flex-wrap:wrap}
.email-gate input[type=email]{flex:1;min-width:200px;background:var(--bg);border:1px solid var(--line);color:var(--ink);padding:14px 16px;font-size:15px;font-family:inherit;border-radius:var(--r);outline:none}
.email-gate input[type=email]:focus{border-color:var(--gold)}
.email-gate .btn{padding:14px 22px;white-space:nowrap}
.email-gate .fine{font-size:11px;color:var(--muted);margin-top:12px;font-family:'JetBrains Mono',monospace;letter-spacing:0.08em;text-transform:uppercase}

/* TOC sidebar (sticky chapter list) */
.toc{position:fixed;top:80px;right:20px;width:240px;background:rgba(10,10,10,0.9);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:var(--r);padding:18px;z-index:40;max-height:calc(100vh - 120px);overflow-y:auto;display:none}
@media(min-width:1480px){.toc{display:block}}
@media(min-width:1480px){body.has-toc .container{padding-right:280px}}
.toc h4{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin:0 0 12px}
.toc ol{list-style:none;padding:0;margin:0;counter-reset:tocnum}
.toc li{counter-increment:tocnum;padding:6px 0;border-top:1px solid var(--line);font-size:12px}
.toc li:first-child{border-top:0}
.toc li::before{content:counter(tocnum, decimal-leading-zero);color:var(--muted);font-family:'JetBrains Mono',monospace;margin-right:8px;font-size:10px}
.toc li a{color:var(--ink-2)}
.toc li a:hover,.toc li.active a{color:var(--gold)}
.toc li.locked a{color:var(--muted)}
.toc li.locked::after{content:'🔒';font-size:9px;margin-left:6px;opacity:0.5}

/* Compact mode */
.read-mode-row{display:flex;justify-content:center;gap:12px;margin:0 auto 48px;flex-wrap:wrap}
.mode-pill{padding:8px 14px;border:1px solid var(--line);background:transparent;color:var(--ink-2);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;border-radius:24px;cursor:pointer;transition:all .15s}
.mode-pill:hover{border-color:var(--gold);color:var(--gold)}
.mode-pill.active{background:var(--gold);color:#0a0a0a;border-color:var(--gold)}
body.audio-only .chapter-text-col{display:none}
body.audio-only .chapter-body{grid-template-columns:1fr;max-width:560px;margin:0 auto}
body.text-only .chapter-audio-col{display:none}
body.text-only .chapter-body{grid-template-columns:1fr}
