:root{
  --paper:#f6f5f1; --card:#fff; --ink:#191917; --muted:#6f6e68; --faint:#9a988f;
  --line:#e3e1d8; --line-2:#d3d0c5; --link:#27457e; --link-hov:#15315f;
  --stamp:#b23a2e; --ok:#2f7d4f; --okbg:#e8f3ec;
  --shadow:0 1px 2px rgba(25,25,23,.05),0 4px 14px rgba(25,25,23,.04);
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --disp:"Archivo",system-ui,sans-serif; --body:"Inter",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:var(--body);background:var(--paper);color:var(--ink);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--link);text-decoration:none} a:hover{color:var(--link-hov);text-decoration:underline}
button{font-family:inherit} img{display:block;max-width:100%}
:focus-visible{outline:2px solid var(--link);outline-offset:2px}

/* header */
header.site{position:sticky;top:0;z-index:40;background:var(--paper);border-bottom:1px solid var(--line-2)}
.bar{max-width:1180px;margin:0 auto;padding:12px 18px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.brand{display:flex;flex-direction:column;line-height:1;flex:0 0 auto;text-decoration:none}
.brand:hover{text-decoration:none}
.brand .name{font-family:var(--disp);font-weight:800;font-size:22px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.brand .name b{color:var(--stamp)}
.brand .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:4px;font-weight:600}
.search{flex:1 1 220px;display:flex;min-width:160px}
.search input{flex:1;border:1px solid var(--line-2);border-right:none;border-radius:6px 0 0 6px;padding:9px 12px;font-size:14px;background:var(--card);color:var(--ink);min-width:0}
.search button{border:1px solid var(--ink);background:var(--ink);color:#fff;border-radius:0 6px 6px 0;padding:0 16px;font-weight:600;cursor:pointer;font-size:14px}
.search button:hover{background:#000}
.actions{display:flex;gap:8px;align-items:center;flex:0 0 auto}
.btn{border:1px solid var(--line-2);background:var(--card);color:var(--ink);padding:9px 14px;border-radius:6px;font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap;text-decoration:none;display:inline-block}
.btn:hover{border-color:var(--ink);text-decoration:none}
.btn.primary{background:var(--stamp);border-color:var(--stamp);color:#fff}
.btn.primary:hover{background:#9a2f25;border-color:#9a2f25}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted);padding:9px 8px}
.btn.ghost:hover{color:var(--ink);text-decoration:underline}

main{max-width:1180px;margin:0 auto;padding:22px 18px 60px}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:16px}
.crumbs a{color:var(--muted)} .crumbs a:hover{color:var(--link)}
.sec-label{font-family:var(--disp);font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:8px;margin-bottom:16px}

.home{display:grid;grid-template-columns:250px 1fr;gap:34px}
@media(max-width:820px){.home{grid-template-columns:1fr;gap:22px}}
.index h2,.col h2{font-family:var(--disp);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.cat-list{list-style:none;margin:0;padding:0}
.cat-list li{border-bottom:1px solid var(--line)}
.cat-list a{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 4px;color:var(--ink);font-weight:500}
.cat-list a:hover{text-decoration:none;color:var(--link)}
.cat-list .ct{font-family:var(--mono);font-size:12px;color:var(--faint);font-weight:400}

/* grid: 4 columns, responsive */
.grid{display:grid;gap:16px;align-items:start;grid-template-columns:repeat(4,1fr)}
@media(max-width:1000px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:720px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:430px){.grid{grid-template-columns:repeat(2,1fr);gap:12px}}

.listing{background:var(--card);border:1px solid var(--line);border-radius:8px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow);transition:transform .08s,border-color .08s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.listing:hover{transform:translateY(-2px);border-color:var(--line-2);text-decoration:none}
.thumb{position:relative;background:#eceae3;overflow:hidden;line-height:0}
.thumb img{width:100%;height:auto;max-height:400px;object-fit:cover;display:block}
.listing.sold .thumb img{filter:grayscale(.55) brightness(.96)}
.pad{padding:11px 12px 13px;display:flex;flex-direction:column;gap:4px;flex:1}
.price{font-family:var(--mono);font-weight:700;font-size:17px;color:var(--ink)}
.listing.sold .price{color:var(--muted)}
.l-title{font-weight:600;font-size:14px;line-height:1.3;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.l-meta{margin-top:auto;padding-top:6px;font-size:12px;color:var(--faint);display:flex;justify-content:space-between;gap:6px}
.pill{display:inline-block;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--muted);background:#efeee8;border-radius:4px;padding:2px 6px}

/* pagination */
.pager{display:flex;gap:6px;justify-content:center;align-items:center;margin-top:28px;flex-wrap:wrap}
.pager .pg{border:1px solid var(--line-2);background:var(--card);color:var(--ink);padding:8px 13px;border-radius:6px;font-weight:600;font-size:13px;cursor:pointer;min-width:40px;text-align:center;text-decoration:none;display:inline-block}
.pager a.pg:hover{border-color:var(--ink);text-decoration:none}
.pager .pg.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager .pg[aria-disabled]{opacity:.4;cursor:default}

/* SOLD stamp */
.stamp{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-13deg);font-family:var(--disp);font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--stamp);border:3px solid var(--stamp);border-radius:7px;padding:5px 14px;font-size:clamp(15px,4.4vw,22px);background:rgba(255,255,255,.32);box-shadow:0 0 0 2px rgba(178,58,46,.14) inset;opacity:.9;pointer-events:none}

/* toolbar / tabs */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.cat-h{font-family:var(--disp);font-size:26px;font-weight:700;margin:0}
.tabs{display:flex;gap:2px;background:#ecebe4;border-radius:8px;padding:3px}
.tabs a{padding:7px 15px;border-radius:6px;font-weight:600;font-size:13px;color:var(--muted)}
.tabs a:hover{text-decoration:none;color:var(--ink)}
.tabs a.on{background:var(--card);color:var(--ink);box-shadow:var(--shadow)}
.tabs a.on .stamp-dot{color:var(--stamp)}
.tabs .ct{font-family:var(--mono);font-size:11px}
select.sort{border:1px solid var(--line-2);border-radius:6px;padding:8px 10px;background:var(--card);font-size:13px;color:var(--ink)}

/* detail */
.detail{display:grid;grid-template-columns:1.3fr 1fr;gap:34px;align-items:start}
@media(max-width:780px){.detail{grid-template-columns:1fr;gap:22px}}
.gmain{position:relative;aspect-ratio:4/3;background:#eceae3;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.gmain img{width:100%;height:100%;object-fit:cover}
.detail.sold .gmain img{filter:grayscale(.5)}
.gthumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.gthumbs img{width:64px;height:54px;object-fit:cover;border-radius:6px;border:2px solid transparent;cursor:pointer;background:#eee}
.gthumbs img.on{border-color:var(--ink)}
.d-price{font-family:var(--mono);font-weight:700;font-size:30px;margin:0}
.d-title{font-family:var(--disp);font-size:24px;font-weight:700;margin:6px 0 12px;line-height:1.2}
.meta-row{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:13px;color:var(--muted);margin-bottom:18px}
.meta-row b{color:var(--ink);font-weight:600}
.desc{color:#33332f;line-height:1.6;margin:16px 0 22px;border-top:1px solid var(--line);padding-top:16px}
.sold-banner{display:flex;align-items:center;gap:14px;background:var(--okbg);border:1px solid #cfe6d6;border-radius:10px;padding:14px 16px;margin-bottom:18px}
.sold-banner .lab{font-family:var(--disp);font-weight:800;letter-spacing:.14em;color:var(--stamp);border:2.5px solid var(--stamp);border-radius:6px;padding:3px 10px;font-size:14px;transform:rotate(-6deg)}
.sold-banner .txt{font-size:13px;color:#2c5a3d;font-weight:500}
.sold-banner .txt b{font-family:var(--mono)}

/* forms / modal */
.modal-bg{position:fixed;inset:0;background:rgba(20,20,18,.5);z-index:90;display:flex;align-items:flex-start;justify-content:center;padding:5vh 16px;overflow:auto}
.modal{background:var(--card);border-radius:12px;max-width:520px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3);padding:24px}
.modal h3{font-family:var(--disp);font-size:20px;margin:0 0 4px}
.modal .sub{color:var(--muted);font-size:13px;margin:0 0 18px}
.modal .x{float:right;border:none;background:none;font-size:22px;cursor:pointer;color:var(--faint);line-height:1;padding:0}
label.f{display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin:13px 0 5px}
label.f .opt{color:var(--faint);font-weight:400}
input.in,textarea.in,select.in{width:100%;border:1px solid var(--line-2);border-radius:7px;padding:10px 12px;font-size:14px;background:var(--paper);color:var(--ink);font-family:inherit}
textarea.in{min-height:90px;resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.row2{grid-template-columns:1fr}}
.chk-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}
@media(max-width:480px){.chk-grid{grid-template-columns:1fr}}
.chk{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--ink);padding:5px 0;cursor:pointer}
.chk input{width:16px;height:16px;accent-color:var(--stamp)}
.actions-row{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap;align-items:center}
.submit{background:var(--stamp);border:1px solid var(--stamp);color:#fff;padding:11px 22px;border-radius:7px;font-weight:700;font-size:14px;cursor:pointer}
.submit:hover{background:#9a2f25}
.note{font-size:12px;color:var(--faint);margin-top:12px;line-height:1.5}
.ok-msg{background:var(--okbg);border:1px solid #cfe6d6;border-radius:9px;padding:18px;text-align:center;color:#2c5a3d}
.ok-msg .big{font-family:var(--disp);font-size:18px;font-weight:700;color:var(--ok);margin-bottom:4px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .e-big{font-family:var(--disp);font-size:18px;color:var(--ink);margin-bottom:6px}
.flash{background:var(--okbg);border:1px solid #cfe6d6;color:#2c5a3d;padding:10px 14px;border-radius:8px;font-size:14px;margin:0 0 14px}
.err{background:#fbeae8;border:1px solid #e6c4bf;color:#9a2f25;padding:10px 14px;border-radius:8px;font-size:14px;margin:0 0 14px}

/* admin */
.admin-bar{background:#191917;color:#fff;position:sticky;top:0;z-index:50}
.admin-bar .inner{max-width:1180px;margin:0 auto;padding:9px 18px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:13px}
.admin-bar .tag{font-family:var(--disp);font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-right:6px}
.admin-bar a{color:#cfcdc6;padding:6px 11px;border-radius:6px;text-decoration:none;font-weight:600}
.admin-bar a:hover{background:#2c2c29;color:#fff;text-decoration:none}
.admin-bar a.on{background:#2c2c29;color:#fff}
.admin-bar a.exit{margin-left:auto;border:1px solid #555}
.form-card{max-width:640px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:24px}
table.adm{width:100%;border-collapse:collapse;font-size:13px;background:var(--card);border:1px solid var(--line);border-radius:8px;overflow:hidden}
table.adm th{text-align:left;background:#f0efe9;padding:10px 12px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line)}
table.adm td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
table.adm tr:last-child td{border-bottom:none}
.mini{padding:5px 9px;font-size:12px;border-radius:5px;border:1px solid var(--line-2);background:var(--card);cursor:pointer;font-weight:600;color:var(--ink);text-decoration:none;display:inline-block}
.mini:hover{border-color:var(--ink);text-decoration:none}
.mini.sold{color:var(--stamp);border-color:#e4c2bd}
.mini.del{color:#a33;border-color:#e7c4c4}
.in-mini{width:74px;border:1px solid var(--line-2);border-radius:5px;padding:5px 7px;font-size:12px;background:var(--paper)}
.tag-sold{color:var(--stamp);font-weight:700;font-size:11px;letter-spacing:.08em}
.tag-live{color:var(--ok);font-weight:700;font-size:11px;letter-spacing:.08em}
.thumb-mini{width:46px;height:36px;object-fit:cover;border-radius:4px;background:#eee}
.img-strip{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.img-strip .it{position:relative}
.img-strip img{width:74px;height:58px;object-fit:cover;border-radius:6px;border:1px solid var(--line-2)}
.img-strip label.keep{cursor:pointer;display:block}
.img-strip label.keep input{position:absolute;top:-7px;right:-7px;width:18px;height:18px;accent-color:var(--stamp)}

/* footer */
footer.site{border-top:1px solid var(--line-2);background:#efeee8;margin-top:40px}
.foot{max-width:1180px;margin:0 auto;padding:30px 18px;display:grid;grid-template-columns:1.4fr 1fr;gap:30px}
@media(max-width:680px){.foot{grid-template-columns:1fr;gap:22px}}
.foot h4{font-family:var(--disp);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 10px}
.foot p{font-size:13px;color:var(--muted);margin:0 0 8px;max-width:46ch}
.subscribe-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.subscribe-row input{flex:1;min-width:170px;border:1px solid var(--line-2);border-radius:6px;padding:10px 12px;font-size:14px;background:var(--card)}
.foot-bottom{border-top:1px solid var(--line);text-align:center;font-size:12px;color:var(--faint);padding:14px}
.foot-bottom a{color:var(--faint)}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:30px;max-width:380px;width:100%;box-shadow:var(--shadow)}
.login-h{font-family:var(--disp);font-size:22px;font-weight:800;margin:0 0 2px;text-transform:uppercase;letter-spacing:.04em}
.login-card .sub{color:var(--muted);font-size:13px;margin:0 0 18px}

@media(max-width:430px){.brand .name{font-size:18px}}
