:root{
  --paper:#FAF6F0; --card:#FFFFFF; --ink:#231E18; --soft:#6F6358;
  --line:#E6DCCE; --accent:#E0571F; --accent-deep:#B23F12;
  --ok:#2E7D5B; --err:#C0392B; --shadow:0 1px 3px rgba(35,30,24,.06),0 6px 20px rgba(35,30,24,.05);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Poppins',-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--paper);color:var(--ink);font-size:15px;line-height:1.5}
a{color:var(--accent-deep);text-decoration:none}
a:hover{text-decoration:underline}

/* header */
.top{background:var(--ink);color:#fff;padding:0 24px;display:flex;align-items:center;
  height:58px;gap:28px;position:sticky;top:0;z-index:10}
.top .brand{font-weight:700;letter-spacing:.02em}
.top .brand b{color:var(--accent)}
.top nav{display:flex;gap:20px;margin-left:8px}
.top nav a{color:#D8CEC2;font-size:13.5px;font-weight:500;text-transform:uppercase;
  letter-spacing:.08em}
.top nav a.active,.top nav a:hover{color:#fff;text-decoration:none}
.top .right{margin-left:auto}
.top .right a{color:#B9AEA1;font-size:13px}

.wrap{max-width:980px;margin:0 auto;padding:30px 24px 60px}
h1{font-size:24px;font-weight:700;margin:0 0 4px;letter-spacing:-.01em}
.sub{color:var(--soft);margin:0 0 24px}

/* flash */
.flash{padding:11px 15px;border-radius:8px;margin-bottom:16px;font-size:14px;font-weight:500}
.flash.ok{background:rgba(46,125,91,.1);color:var(--ok)}
.flash.error{background:rgba(192,57,43,.09);color:var(--err)}

/* cards grid (dashboard) */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.book{background:var(--card);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.book .bar{height:6px}
.book .body{padding:16px 18px;flex:1;display:flex;flex-direction:column}
.book h3{margin:0 0 2px;font-size:16.5px;font-weight:700;letter-spacing:-.01em}
.book .slug{color:var(--soft);font-size:12px;font-family:ui-monospace,monospace;margin-bottom:12px}
.book .stat{display:flex;gap:18px;margin-top:auto;padding-top:12px;border-top:1px solid var(--line)}
.book .stat .n{font-weight:700;font-size:17px}
.book .stat .l{font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--soft)}
.badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;
  text-transform:uppercase;letter-spacing:.06em}
.badge.ready{background:rgba(46,125,91,.12);color:var(--ok)}
.badge.empty{background:rgba(111,99,88,.12);color:var(--soft)}

/* book detail */
.panel{background:var(--card);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow);padding:22px 24px;margin-bottom:18px}
.panel h2{margin:0 0 16px;font-size:17px;font-weight:700}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.kpi{display:flex;gap:26px;margin-bottom:4px}
.kpi .n{font-weight:700;font-size:22px}
.kpi .l{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--soft)}

/* buttons */
.btn{display:inline-block;border:none;border-radius:8px;padding:10px 18px;font-size:14px;
  font-weight:600;cursor:pointer;font-family:inherit}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-deep);text-decoration:none}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent-deep);text-decoration:none}
.btn.dark{background:var(--ink);color:#fff}
.btn[disabled]{opacity:.45;cursor:not-allowed}

/* progress */
.progress{height:10px;background:var(--line);border-radius:6px;overflow:hidden;margin:12px 0 6px}
.progress > i{display:block;height:100%;background:var(--accent);width:0;transition:width .3s}
.muted{color:var(--soft);font-size:13px}

/* forms */
label{display:block;font-size:13px;font-weight:600;margin:14px 0 5px}
input[type=text],input[type=password],input[type=email]{width:100%;padding:10px 12px;
  border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;background:#fff}
input:focus{outline:none;border-color:var(--accent)}
.hint{font-size:12.5px;color:var(--soft);margin-top:4px}

/* recipe table */
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--soft);
  padding:6px 8px;border-bottom:2px solid var(--line)}
td{padding:7px 8px;border-bottom:1px solid var(--line)}
td.mono{font-family:ui-monospace,monospace;font-size:12px;color:var(--soft)}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.dot.yes{background:var(--ok)}.dot.no{background:var(--line)}

/* login */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:6px}
.gallery figure{margin:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
.gallery img{width:100%;height:110px;object-fit:cover;display:block;background:var(--line)}
.gallery figcaption{font-size:11.5px;padding:6px 8px;color:var(--soft);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}

/* login */
.login{max-width:360px;margin:12vh auto;background:var(--card);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow);padding:30px 28px}
.login h1{text-align:center;margin-bottom:4px}
.login .sub{text-align:center}
