:root{
  --ink:#111;
  --paper:#FAF7F2;
  --line:#E7DED4;
  --muted:#5b5b5b;
  --radius:18px;
  --max:1100px;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --font-body: 'Inter', system-ui, sans-serif;
  --font-heading: 'Montserrat', 'Inter', sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}

header{
  position:sticky;top:0;z-index:1000;
  background:rgba(250,247,242,.92);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(10px);
}
.nav{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;
  gap:14px;
}
.brand img{height:42px}
.navlinks{
  display:flex;gap:18px;flex-wrap:wrap;font-size:14px;justify-content:flex-end;
}
.navlinks a{text-decoration:none;padding:8px 10px;border-radius:999px}
.navlinks a:hover{background:#fff}

/* Hero */
.hero{
  padding:56px 0;
  text-align:center;
}
.heroRow{display:flex;justify-content:center}
.heroCard{
  width:min(860px, 100%);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow);
}
.heroLogo{
  max-width:620px;
  width:100%;
  display:block;
  margin:0 auto;
}
h1{
  font-family:var(--font-heading);
  font-size:34px;
  margin:16px 0 10px;
}
.lead{color:var(--muted);margin:0 0 20px}
.ctaRow{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.btn{
  padding:12px 16px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  text-decoration:none;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.btn.primary{
  background:var(--ink);
  color:var(--paper);
  border-color:var(--ink);
}

section{padding:40px 0}
h2{
  font-family:var(--font-heading);
  font-size:22px;
  margin:0 0 10px;
}
.sub{color:var(--muted);font-size:14px;margin:0 0 16px}

.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 6px 18px rgba(0,0,0,.05);
}
.card h3{margin:0 0 8px;font-size:16px}
.card p{margin:0;color:var(--muted);font-size:14px}

/* Gallery thumbs */
.gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
}
.thumb{
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  aspect-ratio:1/1;
  cursor:pointer;
}
.thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
  transition:transform .2s ease;
}
.thumb:hover img{transform:scale(1.06)}
.thumb button{
  all:unset;
  display:block;
  width:100%;
  height:100%;
}

.panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
  box-shadow:0 6px 18px rgba(0,0,0,.05);
}

footer{
  padding:30px 0 40px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:13px;
}

/* Lightbox */
.modal{
  position:fixed; inset:0;
  background:rgba(0,0,0,.78);
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:2000;
}
.modal.open{display:flex}
.modalInner{
  width:min(1100px, 100%);
  background:#111;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 30px 80px rgba(0,0,0,.45);
}
/* full image shown (no cropping) */
.modalImg{
  width:100%;
  height:min(80vh, 820px);
  object-fit:contain;
  display:block;
  background:#111;
}
.modalBar{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 12px;
  background:#0b0b0b;
  color:#f2f2f2;
  font-size:13px;
}
#modalCaption {
  flex: 1 1 auto;        /* caption can shrink */
  min-width: 0;          /* REQUIRED for ellipsis in flex */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.controls {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;     /* prevent wrapping */
  flex-shrink: 0;        /* don’t let buttons compress */
}

.iconBtn{
  background:transparent;
  color:#f2f2f2;
  border:1px solid rgba(255,255,255,.18);
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
  font:inherit;
}
.iconBtn:hover{border-color:rgba(255,255,255,.35)}

.iconBtnLink {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-decoration: none;
}
.iconBtnLink:hover {
  box-shadow: var(--shadow);
}
.iconBtnLink svg {
  display: block;
}

.modalImageWrap {
  position: relative;
  background: #111;
}

/* Badges (Shared) */
.badge {
  position: absolute;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0, 0, 0, 0.65);
  pointer-events: none;
}
.badge.sold {
  background: rgba(140, 0, 0, 0.85);
}
.badge.available {
  background: rgba(20, 110, 60, 0.85);
}

/* Modal Badge specific */
.statusBadge {
  top: 14px;
  left: 14px;
  font-size: 12px;
}

/* Thumbnail Badge specific */
.thumb { position: relative; }
.thumbBadge {
  top: 10px;
  left: 10px;
}

/* Media Queries */
@media(max-width:900px){
  .cards{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  h1{font-size:30px}
}

@media (max-width: 480px) {
  .iconBtn { padding: 6px 8px; font-size: 12px; }
  .statusBadge { top: 10px; left: 10px; font-size: 11px; }
  .thumbBadge {
    top: 8px;
    left: 8px;
    font-size: 10px;
    padding: 5px 8px;
  }
}

.buyBtn{
  display:none;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid rgba(40,110,80,.5);
  color:#fff;
  background:#2f6f52;
  font-weight:700;
  text-decoration:none;
  white-space:nowrap;
}

.buyBtn:hover{
  background:#3a8562;
}

/* Keep controls on one line on mobile */
.controls{
  display:flex;
  gap:8px;
  flex-wrap:nowrap;
  flex-shrink:0;
}

#modalCaption{
  flex:1 1 auto;
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}