
:root{
  --bg:#f5f1e8;
  --card:#fffdf8;
  --ink:#221d18;
  --muted:#6d6258;
  --line:#d7cbbd;
  --accent:#8b5e3c;
  --shadow:0 12px 28px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: Georgia, "Times New Roman", serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.7), rgba(255,255,255,0) 28%),
    linear-gradient(180deg,#f8f5ee 0%, var(--bg) 100%);
  min-height:100vh;
}
a{color:inherit}
.wrap{max-width:1380px;margin:0 auto;padding:28px 20px 56px}
.hero{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:20px}
.hero h1{margin:0;font-size:clamp(30px,4vw,54px);letter-spacing:.4px}
.hero p{margin:.5rem 0 0;color:var(--muted);max-width:70ch;line-height:1.5}
.hero .stats{display:flex;gap:12px;flex-wrap:wrap}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 14px;font-size:14px;box-shadow:var(--shadow)}
.toolbar{
  display:grid;
  grid-template-columns: minmax(220px,1.6fr) repeat(4, minmax(120px,.6fr));
  gap:12px;
  background:rgba(255,255,255,.7);
  border:1px solid var(--line);
  backdrop-filter: blur(6px);
  padding:14px;border-radius:18px; box-shadow:var(--shadow); position:sticky; top:10px; z-index:20;
}
input,select{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid var(--line);
  background:#fff; font:inherit; color:var(--ink);
}
.toolbar .buttonish{display:flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px 14px;text-decoration:none}
.grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:18px; margin-top:22px;
}
.card{
  background:var(--card); border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:var(--shadow);
  display:flex; flex-direction:column; min-height:100%;
}
.thumb{
  position:relative; background:#efe7da; aspect-ratio:4/3; display:grid; place-items:center; overflow:hidden;
}
.thumb img{width:100%;height:100%;object-fit:cover;display:block;cursor:zoom-in}
.thumb .ph{
  padding:24px; text-align:center; color:var(--muted); font-size:14px; line-height:1.5;
}
.badge{
  position:absolute; left:10px; top:10px; background:rgba(34,29,24,.86); color:#fff; border-radius:999px; padding:6px 10px; font-size:12px;
}
.card .content{padding:14px 14px 16px; display:flex; flex-direction:column; gap:9px; flex:1}
.eyebrow{font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted)}
.title{font-size:20px; line-height:1.2; margin:0}
.sub{font-size:14px; color:var(--muted); line-height:1.4; min-height:2.8em}
.meta{display:grid; grid-template-columns:1fr 1fr; gap:8px; font-size:14px; color:#3e342c}
.meta div{background:#faf7f1; border:1px solid #eee2d1; padding:8px 10px; border-radius:10px}
.card .actions{display:flex; gap:10px; margin-top:auto; padding-top:6px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; text-decoration:none; padding:10px 12px; border-radius:10px;
  border:1px solid var(--line); background:#fff; font-size:14px;
}
.btn.primary{background:#2e231c;color:#fff;border-color:#2e231c}
.resultsline{margin-top:16px;color:var(--muted);font-size:14px}
.modal{
  position:fixed; inset:0; background:rgba(10,10,10,.78); display:none; align-items:center; justify-content:center; z-index:100;
  padding:24px;
}
.modal.open{display:flex}
.modal-box{
  max-width:min(1180px,94vw); max-height:90vh; width:100%; background:#181512; border-radius:18px; overflow:hidden; border:1px solid rgba(255,255,255,.12);
}
.modal-head{
  display:flex; justify-content:space-between; align-items:center; padding:12px 14px; color:#f5eee4; background:#211a16;
}
.modal-head button{
  border:0; background:#fff; color:#111; border-radius:999px; width:34px; height:34px; font-size:18px; cursor:pointer;
}
.modal-main{
  display:grid; place-items:center; background:#111; min-height:60vh;
}
.modal-main img{max-width:100%; max-height:74vh; object-fit:contain; display:block}
.footer-note{margin-top:28px;color:var(--muted);font-size:14px;line-height:1.5}
.kicker{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;font-size:12px;margin-bottom:4px}
.detail{
  display:grid; grid-template-columns:minmax(280px, 1.1fr) minmax(280px,.9fr); gap:24px; align-items:start;
}
.panel{background:var(--card); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow)}
.viewer{padding:18px}
.viewer .frame{background:#efe7da; border-radius:14px; overflow:hidden; min-height:420px; display:grid; place-items:center}
.viewer img{max-width:100%; max-height:70vh; object-fit:contain; cursor:zoom-in}
.viewer .ph{padding:26px;color:var(--muted)}
.info{padding:22px}
.info h1{margin:0 0 8px; font-size:40px; line-height:1.08}
.info .lede{color:var(--muted); margin-bottom:18px}
.dl{display:grid; grid-template-columns:160px 1fr; gap:10px 14px; font-size:15px}
.dl dt{color:var(--muted)}
.dl dd{margin:0}
.back{display:inline-flex; gap:8px; text-decoration:none; margin-bottom:14px; color:var(--muted)}
@media (max-width: 980px){
  .toolbar{grid-template-columns:1fr 1fr}
  .detail{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .toolbar{grid-template-columns:1fr}
  .hero{flex-direction:column; align-items:flex-start}
  .info h1{font-size:31px}
}
