:root{
  --ink:#1f1b16; --paper:#f7f3ec; --card:#fffdf9;
  --accent:#7a4b2b; --accent2:#b07a4e; --muted:#8a8178; --line:#e4ddd0;
  --danger:#a23b2d; --ok:#3f7d4f;
  --serif:Georgia,"Iowan Old Style","Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--paper);color:var(--ink);font-family:var(--serif);
  line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)} .small{font-size:.85rem}

/* header */
.site-head{background:linear-gradient(180deg,#211c16,#322a20);color:#f3ece0;
  padding:22px 0 18px;border-bottom:3px solid var(--accent)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between}
.brand{font-size:1.6rem;font-weight:700;color:#fff;letter-spacing:.02em}
.brand-mark{color:var(--accent2)}
.site-nav a{color:#e9dcc7;margin-left:20px;font-family:var(--sans);font-size:.95rem}
.tagline{margin:.5rem auto 0;color:#cbbfa9;font-style:italic}

/* flashes */
.flashes{margin-top:16px}
.flash{background:#fff6e6;border:1px solid #e8d6a8;color:#6b5826;
  padding:10px 14px;border-radius:8px;margin-bottom:8px;font-family:var(--sans);font-size:.92rem}

main.wrap{padding-top:28px;padding-bottom:60px;min-height:50vh}

/* library grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:28px}
.card{display:block;background:var(--card);border:1px solid var(--line);border-radius:12px;
  overflow:hidden;transition:transform .15s,box-shadow .15s;color:inherit}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(60,40,20,.16);text-decoration:none}
.card-cover{aspect-ratio:2/3;background:#2a2320;overflow:hidden}
.card-cover img{width:100%;height:100%;object-fit:cover;display:block}
.card-cover-fallback{display:flex;align-items:center;justify-content:center;height:100%;
  color:#f0e7d8;padding:20px;text-align:center;font-size:1.2rem}
.card-body{padding:14px 16px 18px}
.card-body h3{margin:.3rem 0 .2rem;font-size:1.18rem;line-height:1.25}
.byline{margin:.1rem 0;color:var(--muted);font-style:italic;font-size:.95rem}
.blurb{margin:.5rem 0 0;font-size:.92rem;color:#5b5247}
.tag{display:inline-block;font-family:var(--sans);font-size:.7rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent);background:#f0e6d8;padding:3px 9px;border-radius:20px}

.empty{text-align:center;padding:80px 0}

/* story page */
.story-head{display:flex;gap:30px;margin-bottom:30px;align-items:flex-start}
.story-cover{width:220px;border-radius:10px;box-shadow:0 10px 30px rgba(50,30,15,.25);flex:none}
.story-meta h1{margin:.3rem 0 .2rem;font-size:2.2rem;line-height:1.1}
.downloads{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap}
.btn{display:inline-block;font-family:var(--sans);font-size:.9rem;border:1px solid var(--accent);
  color:var(--accent);background:transparent;padding:8px 16px;border-radius:8px;cursor:pointer}
.btn:hover{background:var(--accent);color:#fff;text-decoration:none}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:#5f3920}
.btn.small{padding:5px 11px;font-size:.82rem}
.btn.danger{border-color:var(--danger);color:var(--danger)}
.btn.danger:hover{background:var(--danger);color:#fff}

.prose{max-width:42rem;margin:0 auto;font-size:1.16rem;line-height:1.8}
.prose p{margin:0 0 1.1em;text-align:justify}
.prose h2,.prose h3{margin:1.6em 0 .5em}
.prose hr{border:none;text-align:center;margin:2em 0}
.prose hr:after{content:"* * *";color:var(--muted);letter-spacing:.5em}
.prose em{font-style:italic}

/* comments */
.comments{max-width:42rem;margin:50px auto 0;border-top:1px solid var(--line);padding-top:24px}
.comment{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-bottom:12px}
.comment.pending{background:#fffaf0}
.comment-head{display:flex;gap:10px;align-items:baseline;font-family:var(--sans);font-size:.9rem;margin-bottom:6px}
.comment p{margin:0}
.comment-form{margin-top:22px;display:flex;flex-direction:column;gap:10px}
.comment-form input[type=text],.comment-form textarea,.login input,.edit-form input,
.edit-form textarea,.edit-form select{
  width:100%;font-family:var(--sans);font-size:1rem;padding:10px 12px;border:1px solid var(--line);
  border-radius:8px;background:#fff}
.comment-form textarea{resize:vertical}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}

/* admin */
.admin-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.admin-table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:.92rem;background:var(--card)}
.admin-table th,.admin-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.admin-table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.actions form{margin:0}
.status{font-family:var(--sans);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;
  padding:3px 9px;border-radius:20px}
.status.published{background:#e3f1e6;color:var(--ok)}
.status.draft{background:#f0ece2;color:var(--muted)}

.edit-form{display:flex;flex-direction:column;gap:16px;max-width:760px;font-family:var(--sans)}
.edit-form label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;font-weight:600;color:#4a423a}
.edit-form .two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.edit-form textarea.mono{font-family:"DejaVu Sans Mono",ui-monospace,Menlo,Consolas,monospace;font-size:.95rem;line-height:1.55}
.asset-panel{margin-top:30px;padding:20px;background:var(--card);border:1px solid var(--line);border-radius:12px;max-width:760px}
.cover-preview{width:180px;border-radius:8px;margin-top:16px;box-shadow:0 6px 18px rgba(50,30,15,.2)}
.login{max-width:340px;margin:60px auto;text-align:center}
.login form{display:flex;flex-direction:column;gap:12px}

/* footer */
.site-foot{border-top:1px solid var(--line);padding:24px 0;color:var(--muted);
  font-family:var(--sans);font-size:.85rem;text-align:center}

@media(max-width:640px){
  .story-head{flex-direction:column;align-items:center;text-align:center}
  .story-cover{width:160px}
  .edit-form .two-col{grid-template-columns:1fr}
  .site-head .wrap{flex-direction:column;gap:8px}
}
