*{box-sizing:border-box}
html,body{margin:0;padding:0}
:root{
  --bg:#f6f7f8; --card:#fff; --text:#111; --muted:#666;
  --line:#e6e6e6; --accent:#111;
}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--text); line-height:1.4;
}
.wrap{width:min(1100px,92vw);margin:0 auto}
a{text-decoration:none;color:inherit}

.topbar{
  position:sticky; top:0; z-index:20;
  background:var(--card); border-bottom:1px solid var(--line);
}
.bar{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{font-weight:900;letter-spacing:.2px}

.tabs{display:flex;gap:10px}
.tab{
  border:1px solid var(--line); background:#fff;
  padding:8px 12px; border-radius:10px; cursor:pointer;
  color:var(--muted); font-weight:700;
}
.tab.active{background:#111;color:#fff;border-color:#111}

.head{padding:18px 0 8px}
.head h1{margin:0 0 6px;font-size:28px}
.muted{color:var(--muted)}
.small{font-size:12px}

.filters{
  display:grid; grid-template-columns:1.3fr 1fr auto;
  gap:10px; margin:12px 0 18px;
}
.filters input,.filters select{
  padding:10px 12px; border:1px solid var(--line);
  border-radius:10px; background:#fff; outline:none;
}
.btn{
  padding:10px 14px; border-radius:10px;
  border:1px solid #111; background:#111; color:#fff;
  font-weight:800; cursor:pointer;
}

.grid{
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px; padding-bottom:30px;
}
.card{
  background:var(--card); border:1px solid var(--line);
  border-radius:14px; overflow:hidden; cursor:pointer;
  transition:transform .12s ease;
}
.card:hover{transform:translateY(-2px)}
.card img{width:100%;height:190px;object-fit:cover;display:block;background:#eee}
.card-body{padding:12px}
.card-title{margin:0 0 6px;font-weight:900}
.card-meta{display:flex;flex-wrap:wrap;gap:6px 10px;font-size:13px;color:var(--muted)}
.card-bottom{margin-top:10px;display:flex;justify-content:space-between;align-items:center}
.price{font-weight:900}
.badge{
  font-size:12px; padding:5px 10px; border-radius:999px;
  border:1px solid var(--line); color:var(--muted); background:#fff;
}
.badge.available{color:#0a7a34;border-color:#bfe6c9;background:#eef9f1}
.badge.sold{color:#9a1a1a;border-color:#f0c0c0;background:#fff1f1}

.footer{background:#fff;border-top:1px solid var(--line);padding:22px 0}
.foot{display:flex;justify-content:space-between;gap:14px;align-items:flex-end;flex-wrap:wrap}

/* Modal */
.modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999
}
.modal[aria-hidden="false"]{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.modal-card{
  position:relative;
  width:min(980px,92vw);
  margin:6vh auto;
  background:#fff;
  border-radius:14px;
  border:1px solid var(--line);
  overflow:hidden;
}
.close {
  position: absolute;
  top: 10px;
  right: 10px;
  border: 1px solid var(--line);
  background: #fff;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  cursor: pointer;
  z-index: 2;
}
.modal-body{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:12px;
  padding:12px;
}
.m-gallery{border:1px solid var(--line);border-radius:12px;padding:10px}
.m-main{width:100%;border-radius:10px;border:1px solid var(--line);display:block;background:#eee}
.m-thumbs{display:flex;gap:10px;margin-top:10px;overflow:auto}
.m-thumbs img{width:90px;height:60px;object-fit:cover;border-radius:10px;border:1px solid var(--line);cursor:pointer;background:#eee}

.m-info{border:1px solid var(--line);border-radius:12px;padding:10px}
.row{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.row h2{margin:0;font-size:20px}
.price.big{font-size:22px;margin:8px 0 12px}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kv div{border:1px solid var(--line);border-radius:12px;padding:10px}
.kv span{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
.section{margin-top:12px}
.section p{margin:6px 0 0}

/* responsive */
@media (max-width:900px){
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .modal-body{grid-template-columns:1fr}
}
@media (max-width:520px){
  .grid{grid-template-columns:1fr}
  .filters{grid-template-columns:1fr}
  .kv{grid-template-columns:1fr}
}

/* Filter modal tweaks */
.modal-card.small{
  width: min(520px, 92vw);
}

.modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px;
  border-bottom:1px solid var(--line);
  background:#fff;
}

.modal-body.onecol{
  display:block;
  padding:12px;
}

.fgroup{ margin-bottom:12px; }
.fgroup label{
  display:block;
  font-size:12px;
  color:var(--muted);
  margin-bottom:6px;
}

.fgroup input, .fgroup select{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  outline:none;
}

.two{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.factions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:8px;
}

/* On phones, make filter modal feel like a bottom sheet */
@media (max-width:520px){
  .modal-card.small{
    width: 100vw;
    margin: auto 0 0 0;
    border-radius: 14px 14px 0 0;
  }
}

/* Align close button with header title */
.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-head .close {
  position: static;
  /* override absolute positioning */
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.modal-head strong{
  font-size:16px;
}

.icon-btn {
  width: auto;
  /* ADD THIS */
  min-width: 110px;
  /* optional: keeps it nice on desktop */
  height: 42px;
  padding: 0 14px;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 10px;
  font-weight: 800;
  cursor: pointer;
}

.sort {
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font-weight: 600;
}

@media (max-width:520px) {
  .filters-mobile {
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }

  .filters-mobile input {
    min-width: 0;
  }
}

/* Search + controls stacked */
.filters-stack {
  display: block;
  margin: 12px 0 18px;
}

.search {
  width: 100%;
  padding: 12px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  outline: none;
  font-size: 16px;
}

.controls {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
}

.icon-btn {
  height: 42px;
  padding: 0 14px;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 10px;
  font-weight: 800;
  cursor: pointer;
}

.sort {
  height: 42px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font-weight: 600;
}

/* Make buttons comfy on very small screens */
@media (max-width:520px) {
  .icon-btn {
    min-width: 110px;
  }

  .sort {
    min-width: 150px;
  }
}

.controls {
  position: relative;
  z-index: 1;
}