/* BookPressed page components — ported directly from the WordPress style.css
   .bk-* book spines · .rc-* race cards · .challenge-* challenge archive */

/* ============ shared cream paper background for archive pages ============ */
.archive-paper{background:#ece6d6;background-image:
  radial-gradient(circle at 30% 20%, rgba(0,0,0,.015) 0 2px, transparent 3px),
  radial-gradient(circle at 70% 60%, rgba(0,0,0,.015) 0 2px, transparent 3px);
  background-size:60px 60px;min-height:70vh}
.archive-head{padding:34px 0 6px}
.archive-head h1{font-family:'Playfair Display',serif;font-weight:900;font-size:34px;color:#3a3a3a;margin:0}
.archive-head p{font-family:'Barlow',sans-serif;color:#777;margin:8px 0 0;font-size:16px}

/* ============ FILTER BAR (chapters) ============ */
.bp-filter{display:block;width:100%;background:#fff;border-top:4px solid #2c45fe;
  box-shadow:0 3px 14px rgba(44,69,254,.12);margin-bottom:24px;font-family:'Barlow Condensed',sans-serif;
  border-radius:0 0 4px 4px}
.bp-filter__inner{display:flex;align-items:center;flex-wrap:wrap;gap:10px 18px;max-width:960px;margin:0 auto;padding:12px 20px}
.bp-filter__heading{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:900;letter-spacing:.2em;
  text-transform:uppercase;color:#dd012c;flex-shrink:0;padding-right:14px;border-right:2px solid #eee}
.bp-filter__group{display:flex;align-items:center;gap:7px}
.bp-filter__sel-wrap{position:relative;display:inline-flex;align-items:center}
.bp-filter__select{appearance:none;-webkit-appearance:none;background:#f5f6ff;border:2px solid #dde0ff;border-radius:7px;
  padding:6px 30px 6px 11px;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:800;letter-spacing:.04em;
  color:#444;cursor:pointer;min-width:130px;outline:none;transition:border-color .15s,background .15s,box-shadow .15s}
.bp-filter__select:hover{border-color:#2c45fe;background:#eef0ff}
.bp-filter__select:focus{border-color:#2c45fe;box-shadow:0 0 0 3px rgba(44,69,254,.14);background:#fff}
.bp-filter__group.is-active[data-tax="genre"] .bp-filter__select,
.bp-filter__group.is-active[data-tax="rating"] .bp-filter__select{border-color:#dd012c;color:#dd012c;background:#fff5f6}
.bp-filter__group.is-active[data-tax="type"] .bp-filter__select,
.bp-filter__group.is-active[data-tax="skill"] .bp-filter__select{border-color:#2c45fe;color:#2c45fe;background:#eef0ff}
.bp-filter__chevron{position:absolute;right:9px;font-size:11px;color:#bbb;pointer-events:none}
.bp-filter__clear{margin-left:auto;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:#ccc;text-decoration:none;border:1px solid #e5e5e5;border-radius:50px;padding:5px 14px;
  transition:color .15s,border-color .15s,background .15s;white-space:nowrap}
.bp-filter__clear:hover{color:#dd012c;border-color:#dd012c;background:#fff5f6}

/* ============ BOOK SPINES (chapters) ============ */
.bk-shelf{display:flex;flex-direction:row;flex-wrap:wrap;align-items:flex-end;align-content:flex-start;
  gap:36px 6px;padding:24px 16px 16px;position:relative;background:transparent}
.bk-plank{display:none}
.bk-wrap{position:relative;z-index:1;display:inline-block;width:64px;margin-left:7px;perspective:800px;flex-shrink:0;align-self:flex-end}
.bk-wrap:hover{z-index:200}
.bk-book{display:flex;flex-direction:column;height:100%;width:64px;position:relative;transform-style:preserve-3d;
  transform-origin:left center;transition:transform .45s cubic-bezier(.23,1,.32,1),box-shadow .45s ease;
  text-decoration:none;cursor:pointer;box-shadow:-3px 0 8px rgba(0,0,0,.4),2px 0 4px rgba(0,0,0,.15)}
.bk-spine{position:absolute;inset:0;background:var(--bk-bg,#3b2a1a);display:flex;flex-direction:column;
  align-items:center;justify-content:space-between;padding:12px 4px;overflow:hidden;
  border-top:6px solid var(--bk-band,#dd012c);border-bottom:4px solid var(--bk-band,#dd012c)}
.bk-spine::after{content:'';position:absolute;top:0;right:0;width:5px;height:100%;
  background:linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.06) 60%,transparent);pointer-events:none}
.bk-spine__title{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:rgba(255,255,255,.97);
  writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.04em;line-height:1;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;flex:1;min-height:0;text-align:center;padding:6px 0;margin:3px 0;
  border-top:1px solid rgba(255,255,255,.25);border-bottom:1px solid rgba(255,255,255,.25);
  text-shadow:-1px -1px 0 rgba(0,0,0,.95),1px -1px 0 rgba(0,0,0,.95),-1px 1px 0 rgba(0,0,0,.95),1px 1px 0 rgba(0,0,0,.95),0 0 5px rgba(0,0,0,.4)}
.bk-spine__author{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;color:rgba(255,255,255,.8);
  writing-mode:vertical-rl;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-height:90px;letter-spacing:.02em;
  flex-shrink:0;text-shadow:0 1px 3px rgba(0,0,0,.8)}
.bk-spine__year{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:400;color:rgba(255,255,255,.5);
  writing-mode:vertical-rl;letter-spacing:.02em;flex-shrink:0}
.bk-cover{position:absolute;top:0;left:64px;width:0;height:100%;overflow:hidden;background:#fff;opacity:0;
  display:flex;flex-direction:column;box-shadow:6px 0 18px rgba(0,0,0,.35);transition:width 0s linear .45s,opacity .15s ease .35s}
.bk-cover__body{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column;gap:8px;overflow:hidden}
.bk-cover__cat{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#888}
.bk-cover__level{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:2px 8px;border-radius:2px;align-self:flex-start}
.bk-cover__level--beginner{background:#dd012c;color:#fff}.bk-cover__level--intermediate{background:#b07000;color:#fff}.bk-cover__level--advanced{background:#2c45fe;color:#fff}
.bk-cover__title{font-family:'Barlow',sans-serif;font-size:16px;font-weight:700;color:#1a1a2e;line-height:1.35;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.bk-cover__excerpt{font-family:'Barlow',sans-serif;font-size:13px;color:#444;line-height:1.65;margin:0;flex:1;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.bk-cover__cta{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:#dd012c;align-self:flex-end;margin-top:auto}
.bk-wrap:hover .bk-book{transform:rotateY(-20deg) translateX(8px);box-shadow:-8px 2px 20px rgba(0,0,0,.5),8px 0 12px rgba(0,0,0,.2)}
.bk-wrap:hover .bk-cover{width:220px;opacity:1;transition:width .42s cubic-bezier(.23,1,.32,1) .04s,opacity .28s ease .08s}

/* ============ RACE CARDS ============ */
.rc-list{display:grid;grid-template-columns:1fr;gap:14px;padding:20px 0}
.rc-card{border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 2px 12px rgba(44,69,254,.1),0 1px 3px rgba(0,0,0,.06);transition:transform .2s,box-shadow .2s}
.rc-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(44,69,254,.15)}
.rc-card__link{display:grid;grid-template-columns:8px 1fr auto auto auto;align-items:stretch;text-decoration:none;min-height:80px}
.rc-card__flag{background:repeating-linear-gradient(180deg,#fcef1d 0,#fcef1d 10px,#fffbe8 10px,#fffbe8 20px);width:8px;border-radius:12px 0 0 12px}
.rc-card__body{padding:13px 18px 13px 16px;display:flex;flex-direction:column;justify-content:center;gap:4px;flex:1;overflow:hidden}
.rc-card__title{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:#1a1a2e;line-height:1.15;margin:0;transition:color .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rc-card:hover .rc-card__title{color:#dd012c}
.rc-card__meta{display:flex;gap:12px;flex-wrap:wrap;font-family:'Barlow',sans-serif;font-size:12px;font-weight:600;color:#666;margin-top:2px}
.rc-card__time{color:#2c45fe}
.rc-card__reactions{display:flex;align-items:center;gap:4px;color:#aaa}
.rc-card__reactions-icon{color:#dd012c;opacity:.7}
.rc-card__status{display:flex;align-items:center;padding:0 14px;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;border-left:1px solid #eee;white-space:nowrap;min-width:80px;justify-content:center}
.rc-card__status--open{color:#fff;background:#2c45fe}.rc-card__status--waiting{color:#fff;background:#dd012c}
.rc-card__status--in-progress{color:#1a1a2e;background:#fcef1d}
.rc-card__status--finished{color:#fff;background:#2c45fe;position:relative;overflow:hidden}
.rc-card__status--finished::after{content:'';position:absolute;top:0;right:0;width:18px;height:100%;background:repeating-linear-gradient(180deg,#fff 0,#fff 5px,#2c45fe 5px,#2c45fe 10px);opacity:.35}
.rc-card__cta{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:800;color:#aaa;padding:0 18px;display:flex;align-items:center;justify-content:center;transition:color .2s;white-space:nowrap;border-left:1px solid #eee;letter-spacing:.05em}
.rc-card:hover .rc-card__cta{color:#dd012c}

@media(max-width:640px){
  .bk-shelf{flex-direction:column;align-items:stretch;gap:0;padding:0;background-image:none}
  .bk-plank{display:none}
  .bk-wrap{height:72px!important;width:100%!important;display:block;align-self:stretch;perspective:none}
  .bk-book{width:100%!important;height:72px!important;transform:none!important;box-shadow:none!important;border-left:6px solid var(--bk-band,#fcef1d);border-radius:0;background:var(--bk-bg,#0a0d1a);flex-direction:row;align-items:center}
  .bk-spine{position:static;writing-mode:horizontal-tb;flex-direction:row;align-items:center;justify-content:space-between;width:100%;height:72px;padding:0 16px;border-top:none;border-bottom:1px solid rgba(255,255,255,.1);gap:12px}
  .bk-spine__title,.bk-spine__author,.bk-spine__year{writing-mode:horizontal-tb;white-space:nowrap;max-height:none}
  .bk-spine__title{font-size:15px;flex:1}.bk-cover{display:none}
  .bk-wrap:hover .bk-book{transform:none!important}
  .rc-card__status{min-width:60px;font-size:10px;padding:0 10px}
  .challenge-archive__grid{grid-template-columns:1fr}
  .bp-filter{padding:12px 14px}
}

/* ============ LIMIT HEADER CARD (matches existing site) ============ */
.bp-limit-header{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:#fff;border-top:3px solid #dd012c;border-radius:6px;
  box-shadow:0 2px 10px rgba(0,0,0,.05);padding:14px 22px;margin:18px 0 14px}
.bp-limit-header h1{margin:0;font-family:'Barlow',sans-serif;font-size:20px;font-weight:700;color:#1a1a2e;display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1;min-width:240px}
.bp-limit-header__svg{width:18px;height:18px;color:#2c45fe;flex-shrink:0}
.bp-limit-header__inline{display:inline-flex;align-items:center;gap:10px;padding-left:10px;border-left:1px solid #e3e7f5;margin-left:2px}
.bp-limit-header__usage{font-family:'Barlow',sans-serif;font-weight:600;font-size:13px;color:#2c45fe}
.bp-limit-header__usage .muted{color:#888;font-weight:400;margin-left:2px}
.bp-limit-header__bar{display:inline-block;height:3px;border-radius:50px;background:#f0f0f0;overflow:hidden;width:90px;position:relative}
.bp-limit-header__bar span{display:block;height:100%;background:linear-gradient(90deg,#dd012c 0,#fcef1d 50%,#2c45fe 100%);border-radius:50px}
.bp-limit-header__actions{display:flex;gap:8px;flex-wrap:wrap}
.bp-limit-header__btn{display:inline-flex;align-items:center;gap:6px;font-family:'Barlow',sans-serif;font-weight:600;font-size:13px;
  padding:8px 14px;border-radius:6px;text-decoration:none;border:1px solid transparent;white-space:nowrap;transition:.15s;cursor:pointer}
.bp-limit-header__btn.ghost{background:#fff;color:#444;border-color:#e0e4ff}
.bp-limit-header__btn.ghost:hover{border-color:#dd012c;color:#dd012c;text-decoration:none}
.bp-limit-header__btn.blue{background:#dd012c;color:#fff;border-color:#dd012c}
.bp-limit-header__btn.blue:hover{background:#a8001f;border-color:#a8001f;text-decoration:none}
.bp-limit-header__btn svg{width:14px;height:14px}
@media(max-width:520px){.bp-limit-header__inline{padding-left:0;border-left:none;margin-left:0}.bp-limit-header__actions{width:100%}.bp-limit-header__btn{flex:1;justify-content:center}}

/* ============ INCREASE-LIMIT MODAL ============ */
.bp-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9999;align-items:flex-start;justify-content:center;padding:32px 16px;overflow-y:auto}
.bp-modal.is-open{display:flex}
.bp-modal__inner{background:#fff;border-radius:10px;max-width:520px;width:100%;box-shadow:0 18px 60px rgba(0,0,0,.35);max-height:calc(100vh - 64px);display:flex;flex-direction:column}
.bp-modal__head{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid #e3e7f5}
.bp-modal__head h2{margin:0;font-family:'Barlow',sans-serif;font-weight:700;font-size:18px;color:#1a1a2e;flex:1}
.bp-modal__close{background:none;border:none;font-size:28px;color:#aaa;cursor:pointer;line-height:1;padding:0 4px}
.bp-modal__close:hover{color:#1a1a2e}
.bp-modal__body{padding:16px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}
.bp-pack{background:#fff;border:1px solid #e3e7f5;border-top:3px solid #dd012c;border-radius:6px;padding:14px 16px;position:relative}
.bp-pack--blue{border-top-color:#2c45fe}
.bp-pack__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}
.bp-pack__head h3{margin:0;font-family:'Barlow',sans-serif;font-weight:700;font-size:16px;color:#1a1a2e}
.bp-pack__meta{font-family:'Barlow',sans-serif;font-size:12px;color:#888;margin-top:2px}
.bp-pack__pill{font-family:'Barlow',sans-serif;font-size:11px;font-weight:700;letter-spacing:.04em;background:#1d6b3c;color:#fff;padding:3px 10px;border-radius:50px;flex-shrink:0;text-transform:uppercase}
.bp-pack__body{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.bp-qty{display:inline-flex;align-items:center;border:1px solid #d8dce8;border-radius:6px;overflow:hidden;background:#f5f6fb}
.bp-qty__btn{background:none;border:none;font-size:16px;font-weight:700;color:#666;cursor:pointer;width:30px;height:34px;line-height:1}
.bp-qty__btn:hover{color:#1a1a2e;background:#e3e7f5}
.bp-qty__input{width:48px;height:34px;text-align:center;border:none;border-left:1px solid #d8dce8;border-right:1px solid #d8dce8;background:#fff;font-family:'Barlow',sans-serif;font-size:14px;color:#1a1a2e;font-weight:600;outline:none;-moz-appearance:textfield}
.bp-qty__input::-webkit-outer-spin-button,.bp-qty__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.bp-pack__total{display:flex;flex-direction:column;font-family:'Barlow',sans-serif;line-height:1.1}
.bp-pack__total-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.bp-pack__total-val{font-size:17px;color:#dd012c;font-weight:800}
.bp-pack--blue .bp-pack__total-val{color:#2c45fe}
.bp-pack__btn{flex:1;font-family:'Barlow',sans-serif;font-weight:700;font-size:13px;letter-spacing:.02em;padding:9px 16px;border-radius:6px;border:none;color:#fff;cursor:pointer;background:#dd012c;transition:.15s}
.bp-pack__btn:hover:not(:disabled){background:#a8001f}
.bp-pack__btn:disabled{opacity:.6;cursor:wait}
.bp-pack--blue .bp-pack__btn{background:#2c45fe}
.bp-pack--blue .bp-pack__btn:hover:not(:disabled){background:#1d2fb0}
.bp-pack__feathers{background:#fcef1d;color:#1a1a2e;font-family:'Barlow',sans-serif;font-size:13px;font-weight:800;padding:6px 12px;border-radius:50px;border:1px solid #e0d000;display:inline-flex;align-items:center;gap:5px;cursor:pointer;transition:.15s}
.bp-pack__feathers:hover:not(:disabled){background:#fde900;border-color:#c4b500}
.bp-pack__feathers:disabled{opacity:.6;cursor:wait}

/* ============ ADMIN: shared aesthetic for every admin page ============ */
.admin-main h1{font-family:'Barlow',sans-serif;font-weight:700;font-size:22px;color:#1a1a2e;margin:0 0 4px}
.admin-main > h1 + p,.admin-main .adm-sub{font-family:'Barlow',sans-serif;font-size:13px;color:#666;margin:0 0 16px;max-width:760px}
.adm-section{background:#fff;border:1px solid #e3e7f5;border-radius:6px;padding:20px 22px;margin-bottom:18px}
.adm-section > h2,.adm-section > h2:first-child{font-family:'Barlow',sans-serif;font-weight:700;font-size:16px;color:#1a1a2e;margin:0 0 4px;text-transform:uppercase;letter-spacing:.06em}
.adm-section .adm-help{font-family:'Barlow',sans-serif;font-size:13px;color:#666;margin:0 0 14px;max-width:720px}
.adm-table{width:100%;border-collapse:collapse;font-family:'Barlow',sans-serif;font-size:14px}
.adm-table th{text-align:left;background:#f5f6fb;padding:8px 10px;font-weight:700;font-size:12px;color:#555;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid #e3e7f5}
.adm-table td{padding:7px 10px;border-bottom:1px solid #f1f3f9;vertical-align:middle}
.adm-table tbody tr:nth-child(even) td{background:#fafbff}
.adm-table input[type=text],.adm-table input[type=email],.adm-table input[type=number],.adm-table input[type=password],.adm-table select{font-size:13px;padding:5px 8px;border:1px solid #d8dce8;border-radius:4px;background:#fff;font-family:inherit;color:#1a1a2e}
.adm-table input[type=number]{width:70px}
.adm-table input[disabled]{background:#f2f4fa;color:#888}
.adm-table code{font-size:12px;color:#666;background:none;padding:0}
.adm-table a{color:#2c45fe;text-decoration:none}
.adm-table a:hover{text-decoration:underline}
.adm-btn{font-family:'Barlow',sans-serif;font-size:13px;font-weight:600;padding:6px 14px;border-radius:4px;border:1px solid #d8dce8;background:#fff;color:#333;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.adm-btn:hover{border-color:#2c45fe;color:#2c45fe;text-decoration:none}
.adm-btn.primary{background:#2c45fe;color:#fff;border-color:#2c45fe}
.adm-btn.primary:hover{background:#1d2fb0;color:#fff}
.adm-btn.danger{color:#c0392b;border-color:#f0c8c8}
.adm-btn.danger:hover{background:#fff5f5;color:#c0392b}
.adm-btn svg{width:13px;height:13px}
.adm-x{background:none;border:none;color:#c0392b;font-size:16px;cursor:pointer;padding:0 4px;line-height:1}
.adm-x:hover{color:#8a0018}
.adm-row-actions{display:flex;gap:6px;justify-content:flex-end}
.adm-section .adm-actions{display:flex;gap:8px;align-items:center;margin-top:14px}
.adm-inline{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
.adm-inline label{font-family:'Barlow',sans-serif;font-size:12px;color:#555;text-transform:uppercase;letter-spacing:.06em;font-weight:700;display:block;margin:0 0 4px}
.adm-inline input{width:140px;padding:6px 8px;border:1px solid #d8dce8;border-radius:4px;font-size:13px;font-family:inherit}
.adm-placeholder{padding:24px;text-align:center;color:#888;font-family:'Barlow',sans-serif;font-size:13px;background:#fafbff;border:1px dashed #d8dce8;border-radius:6px}
.adm-section form label{font-family:'Barlow',sans-serif;font-size:12px;color:#555;text-transform:uppercase;letter-spacing:.06em;font-weight:700;display:block;margin:14px 0 4px}
.adm-section form input[type=text],.adm-section form input[type=email],.adm-section form input[type=number],.adm-section form select,.adm-section form textarea{font-size:13px;padding:7px 10px;border:1px solid #d8dce8;border-radius:4px;background:#fff;font-family:inherit;color:#1a1a2e;width:100%;max-width:420px}
.adm-section form textarea{min-height:80px}
.adm-pill{display:inline-block;font-family:'Barlow',sans-serif;font-size:11px;font-weight:700;letter-spacing:.04em;padding:2px 8px;border-radius:50px;text-transform:uppercase}
.adm-pill.green{background:#e8f5ed;color:#1d6b3c}
.adm-pill.red{background:#fff0f0;color:#8b1f1f}
.adm-pill.blue{background:#e8ebff;color:#1d2fb0}
.adm-pill.gray{background:#f0f0f5;color:#666}

/* ============ CHAPTER DETAIL HEADER (port of bk-meta) ============ */
.bk-meta{font-family:'Barlow',sans-serif;width:100%;margin:18px 0 0;background:#fff;border:1px solid #e8e0d4;border-radius:6px;overflow:hidden}
.bk-meta__spine{height:5px;background:#5c3a1e}
.bk-meta__spine--intermediate{height:8px}
/* Outline-style text shadow for words on the intermediate (yellow) variant, so labels/byline pop on white */
.bk-meta__spine--intermediate + * .bk-meta__label,
.bk-meta--int .bk-meta__label{text-shadow:-1px -1px 0 rgba(0,0,0,.08),1px -1px 0 rgba(0,0,0,.08),-1px 1px 0 rgba(0,0,0,.08),1px 1px 0 rgba(0,0,0,.08)}
.bk-meta__cover{width:100%;max-height:320px;object-fit:cover;object-position:center top;display:block}
.bk-meta__body{padding:20px 28px 12px}
.bk-meta__label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;color:#8a5c2a}
.bk-meta__title{font-family:'Playfair Display',serif;font-size:30px;font-weight:900;color:#1a1a1a;line-height:1.2;margin:0 0 10px}
.bk-meta__byline{font-size:14px;color:#888;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.bk-meta__byline strong{color:#444;font-weight:600}
.bk-meta__byline .sep{color:#ccc}
.bk-meta__stats{display:flex;flex-wrap:wrap;gap:8px;padding:0 28px 12px}
.bk-stat{display:inline-flex;align-items:center;gap:6px;background:#f5f0e8;border:1px solid #e0d8cc;border-radius:50px;padding:5px 14px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#888}
.bk-stat__val{color:#333}
.bk-meta__taxa{display:flex;flex-wrap:wrap;gap:8px;padding:0 28px 12px}
.bk-tax-pill,.bk-serial-wrap{display:inline-flex;align-items:center;gap:6px;background:#f5f0e8;border:1px solid #e0d8cc;border-radius:50px;padding:5px 14px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#888}
.bk-tax-pill__label{color:var(--pc,#8a5c2a);font-weight:700}
.bk-serial-wrap select{background:transparent;border:none;color:#333;font-family:'Barlow',sans-serif;font-size:13px;font-weight:600;cursor:pointer;outline:none;padding:0 4px;text-transform:none;letter-spacing:0}
.bk-serial-wrap select option{background:#fff;color:#333}
.bk-meta__actions{display:flex;gap:10px;padding:4px 28px 20px;flex-wrap:wrap}
.bk-btn{font-family:'Barlow',sans-serif;font-size:13px;font-weight:600;letter-spacing:.04em;border:1px solid;border-radius:50px;padding:7px 18px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:.15s;background:#fff}
.bk-btn--edit{color:#444;border-color:#ddd}
.bk-btn--edit:hover{border-color:#2c45fe;color:#2c45fe;text-decoration:none}
.bk-btn--delete{background:#fff0f0;color:#c0392b;border-color:#f5c0c0}
.bk-btn--delete:hover{background:#ffe5e5;color:#8b1f1f}
.bk-btn--report{color:#aaa;border-color:#e8ecff}
.bk-btn--report:hover{border-color:#dd012c;color:#dd012c}

/* Chapter body — solid border in the level color so it reads even with bright yellow */
.bk-body{margin:0 0 28px;padding:24px 28px;background:#fff;border:3px solid #ccc;border-top:none;border-radius:0 0 6px 6px;font-family:'Source Serif 4',Georgia,serif;font-size:17px;line-height:1.75;color:#1a1a1a}
.bk-body p{margin:0 0 1em}
.bk-body img{max-width:100%;height:auto;border-radius:4px}

/* Intermediate text outline — adds a subtle dark stroke around words so black-on-white labels feel intentional next to bright yellow accents */
.txt-outline{text-shadow:-1px -1px 0 rgba(0,0,0,.12),1px -1px 0 rgba(0,0,0,.12),-1px 1px 0 rgba(0,0,0,.12),1px 1px 0 rgba(0,0,0,.12)}

/* ============ REPORT MODAL ============ */
.rpt-modal-backdrop{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.55);align-items:center;justify-content:center;padding:16px}
.rpt-modal{width:100%;max-width:460px;border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 18px 60px rgba(0,0,0,.4);position:relative;font-family:'Barlow',sans-serif}
.rpt-modal__head{padding:18px 22px 14px;border-bottom:3px solid #dd012c;background:#fafbff}
.rpt-modal__eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#dd012c;margin-bottom:4px}
.rpt-modal__title{font-family:'Playfair Display',serif;font-size:18px;font-weight:900;color:#1a1a2e}
.rpt-modal__body{padding:18px 22px}
.rpt-modal__close{position:absolute;top:14px;right:18px;font-size:22px;background:none;border:none;cursor:pointer;color:#999;line-height:1}
.rpt-modal__close:hover{color:#c0392b}
.rpt-label{display:block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#888;margin-bottom:8px}
.rpt-reason-opt{display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:9px 14px;border-radius:6px;cursor:pointer;border:1px solid #e0e4ff;background:#fafbff;margin-bottom:6px;font-size:14px;color:#444;text-align:left}
.rpt-reason-opt input{margin:0;flex-shrink:0}
.rpt-reason-opt span{flex:1;text-align:left}

/* ============ REPORT MODAL — bulletproof grid layout ============ */
/* Reset any inherited flex/grid quirks on the reasons list and lay out each row
   as a fixed-width radio cell + a flexible text cell so labels can't overflow. */
.rpt-reasons{display:block;width:100%}
.rpt-reasons .rpt-reason-opt{
  display:grid !important;
  grid-template-columns:22px 1fr !important;
  align-items:center;
  gap:12px;
  width:100%;
  box-sizing:border-box;
  padding:10px 14px;
  margin:0 0 6px;
  border:1px solid #e0e4ff;
  background:#fafbff;
  border-radius:6px;
  cursor:pointer;
  text-align:left;
  font-size:14px;
  color:#444;
  line-height:1.35;
}
.rpt-reasons .rpt-reason-opt input[type=radio]{
  margin:0;
  width:18px;height:18px;
  accent-color:#dd012c;
  justify-self:center;
}
.rpt-reasons .rpt-reason-opt span{
  text-align:left;
  word-break:break-word;
  min-width:0;
}
.rpt-reasons .rpt-reason-opt:has(input:checked){border-color:#dd012c;background:#fff5f6;color:#1a1a2e}

/* ============ MAIN NAV ICONS + COMMUNITY DROPDOWN ============ */
.nav-ic{width:16px;height:16px;flex-shrink:0;vertical-align:middle;margin-right:6px;color:currentColor}
.nav .links a{display:inline-flex;align-items:center;gap:0}
.nav-dropdown{position:relative;display:inline-flex;align-items:center}
.nav-dropdown__trigger{display:inline-flex;align-items:center;gap:0}
.nav-caret{width:12px;height:12px;margin-left:4px;flex-shrink:0;opacity:.65}
.nav-dropdown__menu{
  position:absolute;top:100%;right:0;margin-top:0;
  background:#fff;border:1px solid #e3e7f5;border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  min-width:200px;padding:6px;z-index:200;
  display:none;flex-direction:column;
}
/* Invisible bridge so the cursor can move from the trigger into the menu */
.nav-dropdown__menu::before{
  content:'';position:absolute;top:-10px;left:0;right:0;height:12px;background:transparent;
}
.nav-dropdown:hover .nav-dropdown__menu,
.nav-dropdown:focus-within .nav-dropdown__menu{display:flex}
.nav-dropdown__menu a{
  display:flex !important;align-items:center;gap:0;
  padding:8px 12px;border-radius:6px;
  font-family:'Barlow',sans-serif;font-weight:600;font-size:13px;
  color:#1a1a2e;text-decoration:none;text-transform:none;letter-spacing:0;
  white-space:nowrap;
}
.nav-dropdown__menu a:hover{background:#fafbff;color:#dd012c}
.nav-dropdown__menu .nav-ic{width:18px;height:18px;color:#dd012c;margin-right:10px}
.rpt-reason-opt:has(input:checked){border-color:#dd012c;background:#fff5f6;color:#1a1a2e}
.rpt-reason-opt input{accent-color:#dd012c}
.rpt-detail{width:100%;box-sizing:border-box;background:#fff;border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:9px 12px;resize:vertical;outline:none}
.rpt-detail:focus{border-color:#dd012c}
.rpt-modal__foot{padding:14px 22px;border-top:1px solid #f1f3f9;display:flex;justify-content:flex-end;gap:10px;background:#fafbff}
.rpt-cancel{background:none;border:1px solid #ddd;color:#888;border-radius:50px;padding:8px 18px;cursor:pointer;font-size:13px}
.rpt-cancel:hover{border-color:#888;color:#333}
.rpt-submit-btn--chapter{font-family:'Barlow',sans-serif;font-size:13px;font-weight:700;background:#c0392b;color:#fff;border:none;border-radius:50px;padding:8px 20px;cursor:pointer}
.rpt-submit-btn--chapter:hover:not(:disabled){background:#a8001f}
.rpt-msg{border-radius:6px;padding:9px 12px;margin-bottom:12px;font-size:13px;font-weight:600;display:none}
.rpt-msg.success{background:#e8f5ed;color:#1d6b3c;border:1px solid #a8d4b8;display:block}
.rpt-msg.error{background:#fff0f0;color:#c0392b;border:1px solid #f5c0c0;display:block}

/* ============ 3-LEVEL READER FEEDBACK ============ */
.fb-section{margin:24px 0 60px;font-family:'Barlow',sans-serif}
.fb-title{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;color:#1a1a2e;margin:0 0 4px}
.fb-sub{color:#888;font-size:14px;margin:0 0 18px}
.fb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:900px){.fb-grid{grid-template-columns:1fr}}
.fb-col{background:#fff;border-radius:6px;overflow:hidden;border:1px solid #e3e7f5;display:flex;flex-direction:column}
.fb-head{display:flex;align-items:center;justify-content:space-between;padding:12px 18px}
.fb-head h3{margin:0;font-family:'Barlow',sans-serif;font-weight:800;font-size:18px}
.fb-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:50px;letter-spacing:.04em}
.fb-col--beginner   .fb-head{background:#dd012c;color:#fff}
.fb-col--beginner   .fb-head h3{color:#fff}
.fb-col--beginner   .fb-badge{background:rgba(255,255,255,.25);color:#fff}
.fb-col--intermediate .fb-head{background:#fcef1d;color:#1a1a1a}
.fb-col--intermediate .fb-head h3{color:#1a1a1a;text-shadow:0 1px 0 rgba(255,255,255,.6),0 0 1px rgba(0,0,0,.4)}
.fb-col--intermediate .fb-badge{background:rgba(0,0,0,.78);color:#fcef1d}
.fb-col--advanced   .fb-head{background:#2c45fe;color:#fff}
.fb-col--advanced   .fb-head h3{color:#fff}
.fb-col--advanced   .fb-badge{background:rgba(255,255,255,.25);color:#fff}
.fb-body{padding:14px 18px 16px;flex:1;display:flex;flex-direction:column;background:#fff}
.fb-text{font-family:'Source Serif 4',Georgia,serif;font-size:15px;line-height:1.5;color:#1a1a1a;margin:0 0 14px;flex:1}
.fb-empty{color:#888;font-size:14px;font-weight:600;margin:0 0 12px}
.fb-label{display:block;font-family:'Barlow',sans-serif;font-size:13px;font-weight:700;color:#1a1a1a;margin-bottom:6px}
.fb-form textarea{width:100%;box-sizing:border-box;background:#ece6d6;border:1px solid #e0d8cc;border-radius:6px;padding:10px 12px;font-family:'Source Serif 4',Georgia,serif;font-size:14px;color:#1a1a1a;resize:vertical;outline:none;margin-bottom:10px}
.fb-form textarea:focus{border-color:#2c45fe}
.fb-submit{font-family:'Barlow',sans-serif;font-weight:800;font-size:13px;border:none;border-radius:6px;padding:10px 18px;cursor:pointer;color:#fff;letter-spacing:.02em;align-self:stretch}
.fb-submit--beginner{background:#dd012c}.fb-submit--beginner:hover{background:#a8001f}
.fb-submit--intermediate{background:#fcef1d;color:#1a1a1a;text-shadow:0 1px 0 rgba(255,255,255,.5)}.fb-submit--intermediate:hover{background:#fde900}
.fb-submit--advanced{background:#2c45fe}.fb-submit--advanced:hover{background:#1d2fb0}
.fb-votes{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto;padding-top:10px;border-top:1px solid #f1f3f9}
.fb-vote-btn{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid #e3e7f5;border-radius:50px;padding:4px 11px;font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;color:#666;cursor:pointer;transition:.15s}
.fb-vote-btn:hover:not(.is-static){border-color:#1a1a2e;color:#1a1a2e}
.fb-vote-btn.is-static{cursor:default;opacity:.7}
.fb-vote-icon{font-size:13px;line-height:1}
.fb-vote-btn--up.is-active{background:#e8f5ed;border-color:#1d6b3c;color:#1d6b3c}
.fb-vote-btn--down.is-active{background:#fff0f0;border-color:#c0392b;color:#c0392b}
.fb-vote-btn--heart.is-active{background:#ffeef2;border-color:#dd012c;color:#dd012c}

/* ============ TOP UTILITY BAR — REDESIGNED ============ */
.util-right{display:flex;align-items:center;gap:6px;margin-left:auto}
.util-ic{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;background:transparent;border:none;cursor:pointer;
  color:#cfd2dd;transition:.15s;padding:0}
.util-ic svg{width:18px;height:18px}
.util-ic:hover{background:rgba(255,255,255,.08);color:#fff}
.util-badge{position:absolute;top:2px;right:2px;background:#dd012c;color:#fff;font-family:'Barlow',sans-serif;
  font-weight:800;font-size:10px;line-height:1;padding:2px 5px;border-radius:50px;min-width:8px;
  display:inline-flex;align-items:center;justify-content:center;letter-spacing:.02em}
.util-me{display:inline-flex;align-items:center;gap:9px;padding:4px 4px 4px 12px;border-radius:50px;
  background:transparent;border:none;cursor:pointer;color:#fff;font-family:'Barlow',sans-serif;
  font-weight:700;font-size:13px;letter-spacing:.01em;transition:.15s}
.util-me:hover{background:rgba(255,255,255,.08)}
.util-me__name{white-space:nowrap}
.util-me__avatar{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;
  justify-content:center;background:#444a5f;color:#fff;font-weight:800;font-size:11px;object-fit:cover}
.util-pop{position:relative;display:inline-block}
.util-pop__trigger{position:relative}
.util-pop__panel{position:absolute;top:calc(100% + 6px);right:0;width:340px;background:#fff;
  border:1px solid #e3e7f5;border-radius:10px;box-shadow:0 12px 32px rgba(0,0,0,.18);
  z-index:300;display:none;flex-direction:column;overflow:hidden}
.util-pop__panel--profile{width:220px}
.util-pop.is-open .util-pop__panel{display:flex}
.util-pop__panel::before{content:'';position:absolute;top:-10px;left:0;right:0;height:12px;background:transparent}
.util-pop__head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;
  border-bottom:1px solid #f0f2f8;font-family:'Barlow',sans-serif;font-weight:800;font-size:14px;color:#1a1a2e}
.util-pop__see{font-size:12px;color:#2c45fe;text-decoration:none;font-weight:600}
.util-pop__list{max-height:380px;overflow-y:auto}
.util-pop__empty{padding:24px 16px;text-align:center;color:#999;font-size:13px;font-family:'Barlow',sans-serif}
.util-pop__item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-family:'Barlow',sans-serif;
  font-size:13px;color:#1a1a2e;text-decoration:none;border-bottom:1px solid #f5f6fb;font-weight:600;line-height:1.4}
.util-pop__item:last-child{border-bottom:none}
.util-pop__item svg{width:16px;height:16px;color:#666;flex-shrink:0}
.util-pop__item:hover{background:#fafbff;color:#dd012c;text-decoration:none}
.util-pop__item:hover svg{color:#dd012c}
.util-pop__item--logout{color:#dd012c}.util-pop__item--logout svg{color:#dd012c}
.util-pop__item--unread{background:#fff5f6}
.util-pop__item--feed{display:block;padding:11px 16px}
.util-pop__msg{font-size:13px;color:#1a1a2e;line-height:1.4;margin-bottom:3px}
.util-pop__when{font-size:11px;color:#999}
.util-pop__sep{height:1px;background:#f0f2f8;margin:4px 0}
