:root{
  --bg:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --line:#e5e7eb;
  --accent:#a855f7;     /* purple */
  --accent-ink:#ffffff;
  --container:min(1080px,92vw);
}

*{box-sizing:border-box}
html,body{height:100%}
/* Force zoom reset */
html{zoom:1;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}

.container{width:var(--container);margin-inline:auto;padding:0 16px}
h1,h2{line-height:1.15;margin:0 0 .5rem}
h1{font-size:clamp(28px,5vw,44px);font-weight:800;letter-spacing:.01em}
h2{font-size:clamp(22px,3.2vw,30px);font-weight:800}
p{margin:.25rem 0 1rem}
.muted{color:var(--muted);font-weight:600}

/* Header */
.site-header{
  position:sticky;top:0;background:#fff8;border-bottom:1px solid var(--line);
  backdrop-filter:saturate(120%) blur(6px);z-index:10
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{font-weight:800;text-decoration:none;color:var(--text)}
.nav{display:flex;gap:10px;align-items:center}
.nav a{color:inherit;text-decoration:none;padding:8px 10px;border-radius:6px}
.nav a:hover{background:#f6f7f9}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  height:42px;padding:0 14px;border:1px solid var(--line);border-radius:8px;
  background:#fff;color:var(--text);font-weight:700;text-decoration:none;
}
.btn:hover{background:#f6f7f9}
.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:transparent}
.btn.primary:hover{filter:brightness(.95)}
.btn.ghost{background:#fff;border-color:var(--line);color:var(--text)}

/* Hero */
.hero{border-bottom:1px solid var(--line);background:linear-gradient(180deg,#faf5ff,#ffffff)}
.hero-inner{
  display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center;
  padding:40px 0;
}
.hero-text .tagline{color:var(--muted);font-size:1.05rem}
.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:.5rem}
.hero-art{max-width:260px;justify-self:end;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:#fff}
.hero-art svg{display:block;width:100%;height:auto}

/* Sections */
.section{padding:32px 0}
.about p{max-width:70ch}
.highlights{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:.5rem 0 0;list-style:none}
.highlights li{
  padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:#fff;font-weight:600;color:#0f172a
}

/* Gallery grid (uniform 3:2 tiles) */
.gallery .grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:12px;
}

.tile{margin:0;display:flex;flex-direction:column}

/* Force identical visual size for all images */
.tile img{
  width:100%;
  aspect-ratio: 3 / 2;    /* uniform box */
  object-fit: cover;      /* fill without distortion; crop overflow */
  object-position: center;/* tweak if you want: center top; */
  display:block;
  border:1px solid var(--line);
  border-radius:10px;
  background:#f3f4f6;     /* nice placeholder while loading */
}

/* Fallback for older browsers without aspect-ratio support */
@supports not (aspect-ratio: 3 / 2) {
  .tile img{
    height: 260px;        /* choose a consistent height */
  }
}

/* Keep captions tidy/aligned */
.tile figcaption{
  margin-top:6px;
  color:var(--muted);
  font-size:.9rem;
  min-height:1.4em;       /* rows line up even if titles differ */
  display:-webkit-box;
  -webkit-line-clamp:1;   /* set to 2 if you want two-line captions */
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Contact */
.contact .sub{color:var(--muted)}
.contact-form{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px
}
.contact-form label{display:grid;gap:6px}
.contact-form label.full{grid-column:1 / -1}
.contact-form input, .contact-form textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;
  font:inherit;background:#fff;color:var(--text)
}
.contact-form input:focus, .contact-form textarea:focus{
  outline:2px solid #c4b5fd;outline-offset:2px
}
.contact-form .row{grid-column:1 / -1;display:flex;gap:10px;flex-wrap:wrap}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:16px 0;color:var(--muted);text-align:center;background:#fff}

/* Enhanced Mobile Responsiveness */
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:18px}
  .hero-art{justify-self:start;max-width:220px}
  .gallery .grid{grid-template-columns:repeat(2,1fr)}
  .contact-form{grid-template-columns:1fr}
  .nav{flex-wrap:wrap;gap:8px}
  .nav a{padding:6px 8px;font-size:0.95rem}
  .cta-row{justify-content:center}
  .btn{height:38px;padding:0 12px;font-size:0.95rem}
}

@media (max-width:640px){
  .container{padding:0 12px}
  .hero-inner{padding:24px 0}
  .hero-art{max-width:180px;justify-self:center}
  .gallery .grid{grid-template-columns:1fr;gap:16px}
  .gallery .grid .tile:nth-child(1){grid-column:1}
  .gallery .grid .tile:nth-child(2){grid-column:1}
  .gallery .grid .tile:nth-child(3){grid-column:1}
  .gallery .grid .tile:nth-child(4){grid-column:1}
  .gallery .grid .tile:nth-child(5){grid-column:1}
  .gallery .grid .tile:nth-child(6){grid-column:1}
  .section{padding:24px 0}
  .header-inner{padding:8px 0}
  .brand{font-size:0.95rem}
  .nav{gap:6px}
  .nav a{padding:6px 8px;font-size:0.9rem}
  .highlights{flex-direction:column;gap:6px}
  .highlights li{padding:6px 8px;font-size:0.9rem}
  .contact-form .row{flex-direction:column;gap:8px}
  .btn{width:100%;justify-content:center}
  .cta-row{flex-direction:column;gap:8px}
}

@media (max-width:480px){
  .hero-inner{padding:20px 0}
  .hero-art{max-width:160px}
  .section{padding:20px 0}
  .container{padding:0 8px}
  .header-inner{padding:6px 0}
  .brand{font-size:0.9rem}
  .nav a{padding:5px 6px;font-size:0.85rem}
  .tile figcaption{font-size:0.85rem}
  .contact-form input, .contact-form textarea{padding:8px 10px}
}
