:root{
  --bg:#ffffff;
  --bg-soft:#f7f5f1;
  --ink:#16130f;
  --ink-soft:#5c564d;
  --line:#e7e2d9;
  --accent:#1a1a1a;
  --accent-warm:#7a4a2b;
  --radius:14px;
  --maxw:1140px;
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --shadow:0 1px 2px rgba(20,16,12,.04), 0 8px 24px rgba(20,16,12,.06);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.muted{color:var(--ink-soft)}
.small{font-size:13px}
.section{padding-block:56px}
.narrow{max-width:760px}
.skip{position:absolute; left:-9999px}
.skip:focus{left:16px; top:16px; background:#fff; padding:8px 12px; z-index:50}

h1,h2,h3{font-family:var(--serif); font-weight:600; line-height:1.12; letter-spacing:-.01em; margin:0 0 .4em}
h1{font-size:clamp(2rem,4vw,3rem)}
h2{font-size:clamp(1.4rem,2.5vw,2rem)}

/* ---- Header ---- */
.site-header{position:sticky; top:0; z-index:30; background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(12px); border-bottom:1px solid var(--line)}
.header-inner{display:flex; align-items:center; justify-content:space-between; height:68px}
.brand{display:flex; align-items:center; gap:10px; font-family:var(--serif); font-weight:600; font-size:1.25rem}
.brand:hover{text-decoration:none}
.brand-mark{display:inline-grid; place-items:center; width:34px; height:34px; border:1.5px solid var(--ink);
  border-radius:50%; font-size:1rem}
.site-nav{display:flex; align-items:center; gap:28px; font-size:.96rem}
.site-nav a{color:var(--ink-soft)}
.site-nav a:hover,.site-nav a.active{color:var(--ink); text-decoration:none}
.nav-search{font-size:1.2rem}
.nav-toggle{display:none; background:none; border:0; font-size:1.4rem; cursor:pointer}

/* ---- Buttons ---- */
.btn{display:inline-block; padding:11px 20px; border-radius:999px; font-weight:500; font-size:.95rem;
  border:1.5px solid transparent; cursor:pointer; transition:.15s; line-height:1}
.btn:hover{text-decoration:none; transform:translateY(-1px)}
.btn-primary{background:var(--accent); color:#fff}
.btn-ghost{background:transparent; border-color:var(--line); color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-danger{background:#fff; color:#a12; border-color:#e3b4b4}

/* ---- Hero ---- */
.hero{padding:84px 0 40px; background:
  radial-gradient(1200px 400px at 80% -10%, #f3efe7 0%, transparent 60%), var(--bg)}
.hero-kicker{text-transform:uppercase; letter-spacing:.18em; font-size:.78rem; color:var(--accent-warm); margin:0 0 14px}
.hero-title{font-size:clamp(2.4rem,6vw,4.2rem); max-width:14ch; margin:0 0 18px}
.hero-lede{font-size:1.15rem; color:var(--ink-soft); max-width:60ch; margin:0 0 28px}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap}
.hero-stats{display:flex; gap:40px; flex-wrap:wrap; margin:48px 0 0; padding-top:28px; border-top:1px solid var(--line)}
.hero-stats div dt{font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-soft)}
.hero-stats div dd{margin:4px 0 0; font-family:var(--serif); font-size:1.7rem}

/* ---- Section heads ---- */
.section-head{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:28px}
.section-head h2{margin:0}
.seemore{color:var(--ink-soft); font-size:.95rem}
.page-head{margin-bottom:32px}
.page-head h1{margin-bottom:.2em}

/* ---- Grid + cards ---- */
.grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(190px,1fr)); gap:30px 26px}
.card{display:block}
.card:hover{text-decoration:none}
.card .cover{margin-bottom:14px; transition:transform .18s, box-shadow .18s}
.card:hover .cover{transform:translateY(-4px); box-shadow:var(--shadow)}
.card-title{font-size:1.05rem; margin:0 0 2px; line-height:1.25}
.card-author{margin:0; color:var(--ink-soft); font-size:.92rem}
.card-meta{margin:6px 0 0; font-size:.82rem; color:var(--ink-soft); display:flex; gap:10px; flex-wrap:wrap}
.card-meta span:not(:last-child)::after{content:"·"; margin-left:10px; color:var(--line)}

/* ---- Covers ---- */
.cover{position:relative; aspect-ratio:3/4; border-radius:10px; overflow:hidden; background:var(--bg-soft);
  border:1px solid var(--line)}
.cover.has-image img{width:100%; height:100%; object-fit:cover}
.cover.placeholder{display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:14% 12%; gap:10px; background:var(--bg); color:var(--fg);
  background-image:linear-gradient(135deg, color-mix(in srgb, var(--bg) 100%, #000 6%), var(--bg));
  border:0}
.cover.placeholder .ph-title{font-family:var(--serif); font-weight:600; font-size:1.04rem; line-height:1.2}
.cover.placeholder .ph-author{font-size:.74rem; letter-spacing:.04em; opacity:.85}
.cover.placeholder .ph-year{font-size:.72rem; letter-spacing:.18em; opacity:.7}
.cover.placeholder .ph-rule{width:34px; height:1px; background:currentColor; opacity:.45}

/* ---- Filters ---- */
.filters{background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--radius);
  padding:18px; margin-bottom:24px}
.filters-search input{width:100%; padding:14px 16px; font-size:1.05rem; border:1px solid var(--line);
  border-radius:10px; background:#fff; font-family:inherit}
.filters-row{display:flex; flex-wrap:wrap; gap:14px; margin:16px 0}
.select{display:flex; flex-direction:column; gap:5px; font-size:.78rem; color:var(--ink-soft)}
.select span{text-transform:uppercase; letter-spacing:.1em}
.select select{padding:9px 12px; border:1px solid var(--line); border-radius:9px; background:#fff;
  font-family:inherit; font-size:.92rem; color:var(--ink); min-width:140px}
.filters-actions{display:flex; gap:10px}
.result-count{margin:0 0 20px}

/* ---- Book detail ---- */
.crumb{margin:24px 0 12px; font-size:.92rem}
.book{padding-bottom:64px}
.book-head{display:grid; grid-template-columns:300px 1fr; gap:48px; align-items:start; margin-bottom:48px}
.book-cover .cover{max-width:300px}
.credit{font-size:.78rem; margin-top:10px}
.book-info h1{margin-bottom:.1em}
.book-author{font-size:1.2rem; color:var(--ink-soft); margin:0 0 24px}
.facts{display:grid; grid-template-columns:1fr 1fr; gap:14px 28px; margin:0 0 22px; padding:22px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.facts dt{font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-soft)}
.facts dd{margin:3px 0 0; font-size:1.02rem}
.chips{display:flex; flex-wrap:wrap; gap:8px}
.chip{display:inline-block; padding:6px 13px; border:1px solid var(--line); border-radius:999px; font-size:.84rem; color:var(--ink-soft)}
.chip:hover{border-color:var(--ink); color:var(--ink); text-decoration:none}

/* ---- Prose ---- */
.prose{font-size:1.08rem; max-width:68ch}
.prose p{margin:0 0 1.1em}
.prose h2{margin-top:1.6em}
.prose a{color:var(--accent-warm); text-decoration:underline; text-underline-offset:2px}
.excerpt{margin-top:40px; padding-top:8px}
.excerpt-body{background:var(--bg-soft); border-left:3px solid var(--accent-warm); border-radius:0 10px 10px 0;
  padding:22px 26px; font-family:var(--serif); font-size:1.05rem}
.lede{font-size:1.25rem; color:var(--ink-soft)}

/* ---- Recipes ---- */
.recipes{margin-top:44px}
.recipes>h2{margin-bottom:20px}
.recipe{padding:24px 0; border-top:1px solid var(--line)}
.recipe:first-of-type{border-top:2px solid var(--ink)}
.recipe-head{display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; margin-bottom:6px}
.recipe-head h3{margin:0; font-size:1.4rem}
.recipe .tag{font-size:.7rem; text-transform:uppercase; letter-spacing:.12em; color:var(--accent-warm);
  border:1px solid var(--accent-warm); border-radius:999px; padding:3px 10px}
.recipe-headnote{color:var(--ink-soft); font-style:italic; margin:0 0 14px; max-width:68ch}
.recipe-authentic .recipe-body{background:var(--bg-soft); border-left:3px solid var(--accent-warm);
  border-radius:0 10px 10px 0; padding:20px 24px; font-family:var(--serif); font-size:1.05rem}
.recipe-signature .recipe-body{max-width:68ch}
.recipe .credit{margin-top:12px}

/* ---- Journal ---- */
.post-list{display:flex; flex-direction:column; gap:2px}
.post-row{display:block; padding:18px 0; border-top:1px solid var(--line)}
.post-row h3{margin:0 0 2px; font-size:1.2rem}
.post-row:hover{text-decoration:none}
.post-row:hover h3{color:var(--accent-warm)}
.journal-list{display:flex; flex-direction:column; gap:8px}
.journal-item{display:grid; grid-template-columns:160px 1fr; gap:24px; padding:20px 0; border-top:1px solid var(--line); align-items:center}
.journal-item:hover{text-decoration:none}
.journal-thumb{aspect-ratio:4/3; border-radius:8px; overflow:hidden; background:var(--bg-soft)}
.journal-thumb img{width:100%; height:100%; object-fit:cover}
.journal-text h2{margin:0 0 4px; font-size:1.4rem}
.date{font-size:.85rem; margin-top:6px}
.post{padding-bottom:64px}
.post-header{max-width:68ch; margin:8px 0 28px}
.post-sub{font-size:1.2rem; color:var(--ink-soft); margin:0 0 8px}
.post-cover{margin:0 0 32px; border-radius:var(--radius); overflow:hidden}
.linked-book{margin-top:40px; padding:18px 22px; background:var(--bg-soft); border-radius:var(--radius)}
.linked-row{font-family:var(--serif); font-size:1.1rem}

/* ---- Footer ---- */
.site-footer{margin-top:40px; border-top:1px solid var(--line); padding:48px 0 36px; background:var(--bg-soft)}
.footer-inner{display:flex; justify-content:space-between; gap:32px; flex-wrap:wrap; margin-bottom:24px}
.footer-brand{font-family:var(--serif); font-size:1.3rem; font-weight:600}
.footer-nav{display:flex; gap:22px; flex-wrap:wrap; align-items:flex-start}
.footer-nav a{color:var(--ink-soft)}
.footer-fine{font-size:.82rem; padding-top:20px; border-top:1px solid var(--line); max-width:80ch}

/* ---- Flash + empty ---- */
.flashes{margin-top:18px}
.flash{padding:12px 16px; border-radius:10px; margin-bottom:8px; font-size:.95rem}
.flash-ok{background:#eef6ee; color:#274d27}
.flash-error{background:#fbedea; color:#7a2418}
.empty{text-align:center; padding:60px 0; color:var(--ink-soft)}

/* ---- Admin ---- */
.is-admin-area{background:var(--bg-soft)}
.admin-cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px}
.admin-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow)}
.admin-card .big{font-family:var(--serif); font-size:2rem; margin:.2em 0 .6em}
.row-actions{display:flex; gap:10px; flex-wrap:wrap}
.admin-table{width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden}
.admin-table th,.admin-table td{text-align:left; padding:11px 14px; border-bottom:1px solid var(--line); font-size:.92rem}
.admin-table th{font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-soft); background:var(--bg-soft)}
.pill{border:1px solid var(--line); background:#fff; border-radius:999px; padding:4px 12px; font-size:.8rem; cursor:pointer}
.pill.on{background:#eef6ee; border-color:#bcd9bc; color:#274d27}
.pill.off{color:var(--ink-soft)}
.inline-search{display:flex; gap:8px; margin-bottom:18px}
.inline-search input{flex:1; padding:10px 14px; border:1px solid var(--line); border-radius:9px; font-family:inherit}
.stack{display:flex; flex-direction:column; gap:16px; max-width:820px}
.field{display:flex; flex-direction:column; gap:6px}
.field>span,.field>legend{font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-soft)}
.field input,.field textarea,.field select{padding:11px 13px; border:1px solid var(--line); border-radius:9px; font-family:inherit; font-size:1rem; background:#fff; width:100%}
.field textarea{font-family:var(--sans); line-height:1.5; resize:vertical}
.two{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.three{display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px}
.check{display:flex; align-items:center; gap:8px; font-size:.95rem}
.check input{width:auto}
fieldset.field{border:1px solid var(--line); border-radius:10px; padding:14px}
.note-box{background:#fff8e8; border:1px solid #ecd9a6; border-radius:10px; padding:14px 18px; margin-bottom:24px; font-size:.92rem}
.note-box p{margin:.4em 0 0}
.danger-form{margin-top:32px; padding-top:24px; border-top:1px solid var(--line); max-width:820px}

/* ---- Responsive ---- */
@media (max-width:900px){
  .grid{grid-template-columns:repeat(auto-fill, minmax(160px,1fr)); gap:24px 18px}
}

@media (max-width:760px){
  body{font-size:16px; overflow-x:hidden}
  .wrap{padding:0 30px}
  .section{padding-block:38px}

  /* nav */
  .nav-toggle{display:block; line-height:1; padding:6px 4px}
  .site-nav{position:absolute; top:67px; left:0; right:0; flex-direction:column; gap:0;
    background:#fff; border-bottom:1px solid var(--line); padding:4px 18px 8px;
    display:none; box-shadow:var(--shadow)}
  .nav-open .site-nav{display:flex}
  .site-nav a{padding:14px 2px; border-bottom:1px solid var(--line); font-size:1.05rem}
  .site-nav a:last-child{border-bottom:0}
  .nav-search{display:none}

  /* hero */
  .hero{padding:48px 0 24px}
  .hero-lede{font-size:1.05rem}
  .hero-actions{gap:10px}
  .hero-actions .btn{flex:1; text-align:center}
  .hero-stats{gap:16px 26px; margin-top:30px; padding-top:22px}
  .hero-stats div dd{font-size:1.35rem}

  .section-head{margin-bottom:20px}
  .page-head{margin-bottom:24px}

  /* two-up card grid on phones */
  .grid{grid-template-columns:1fr 1fr; gap:22px 14px}
  .card .cover{margin-bottom:10px}
  .card-title{font-size:.98rem}
  .card-author{font-size:.85rem}
  .card-meta{font-size:.78rem; gap:8px}

  /* filters */
  .filters{padding:14px; border-radius:12px; margin-bottom:18px}
  .filters-search input{font-size:16px; padding:12px 14px}
  .filters-row{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:14px 0}
  .select{gap:4px}
  .select select{min-width:0; width:100%; font-size:16px; padding:10px 12px}
  .filters-actions{gap:10px}
  .filters-actions .btn{flex:1; text-align:center}
  .result-count{margin-bottom:16px}

  /* book detail */
  .crumb{margin:16px 0 10px}
  .book-head{grid-template-columns:1fr; gap:22px}
  .book-cover{max-width:190px}
  .book-cover .cover{max-width:190px}
  .book-author{font-size:1.08rem; margin-bottom:18px}
  .facts{grid-template-columns:1fr 1fr; gap:12px 18px; padding:18px 0}
  .prose{font-size:1.02rem}
  .excerpt{margin-top:30px}
  .excerpt-body{padding:16px 18px; font-size:1rem}

  /* forms — 16px inputs prevent iOS zoom-on-focus */
  .two,.three{grid-template-columns:1fr}
  .field input,.field textarea,.field select{font-size:16px}
  .stack{max-width:none}

  /* journal */
  .journal-item{grid-template-columns:1fr; gap:6px}
  .journal-thumb{display:none}
  .journal-text h2{font-size:1.25rem}

  /* footer */
  .footer-inner{flex-direction:column; gap:18px}

  /* admin tables scroll rather than squish */
  .admin-table{display:block; overflow-x:auto; white-space:nowrap; -webkit-overflow-scrolling:touch}
  .admin-cards{gap:14px}
}

@media (max-width:380px){
  .filters-row{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr}
}
