/* StudioAprile v2 — minimal grid, static site */

/* Falster (from v1.5 assets) */
@font-face {
  font-family: 'Falster';
  src: url('../assets/fonts/Falster-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Falster';
  src: url('../assets/fonts/Falster-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root{
  --bg:#ffffff;
  --fg:#111111;
  --muted:#6b6b6b;
  --border:#e9e9e9;
  --max:1180px;
  --pad:24px;
  --pad-lg:48px;
  --radius:0px;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --font: 'Falster', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--fg);
  line-height:1.45;
  letter-spacing:.15px;
}

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:none; }

.container{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
}

/* Page width helpers (used by About + Commission) */
.page{
  width:100%;
  margin:0 auto;
}
.page--medium{
  max-width:980px; /* keeps About/Commission from feeling too wide */
}

/* Prose width (used inside Commission, optional elsewhere) */
.prose{
  max-width:72ch;
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(120%) blur(10px);
  border-bottom:1px solid var(--border);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 0;
  gap:18px;
}
.brand{
  display:flex;
  align-items:baseline;
  gap:10px;
  white-space:nowrap;
}
.brand-title{
  font-size:34px;
  letter-spacing:.6px;
  margin:0;
}
.brand-sub{
  font-size:12px;
  color:var(--muted);
}

.nav{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.nav a{
  font-size:13px;
  letter-spacing:.35px;
  text-transform:uppercase;
  color:var(--muted);
  padding:6px 2px;
  border-bottom:1px solid transparent;
}
.nav a[aria-current="page"]{
  color:var(--fg);
  border-bottom-color:var(--fg);
}
.nav a:hover{ color:var(--fg); }

/* Main */
main{ padding:38px 0 64px; }

.page-title{
  margin:0 0 22px;
  font-size:18px;
  text-transform:uppercase;
  letter-spacing:.6px;
}
.page-intro{
  margin:0 0 34px;
  color:var(--muted);
  max-width:58ch;
}

/* Home “card play” (Utica-like): 1 featured card + 4 project cards */
.work-deck{
  display:grid;
  grid-template-columns:repeat(12, minmax(0,1fr));
  gap:18px;
}

.project-card{
  position:relative;
  aspect-ratio: 3 / 2;
  border-radius:0;
  overflow:hidden;
  border:1px solid var(--border);
  background:#f4f4f4;
  box-shadow:none;
  transform:translateZ(0);
  grid-column: span 6;
}

/* Featured card (top) */
.project-card--featured{
  grid-column: 1 / -1;
  aspect-ratio: 16 / 9;
}
.project-card:hover{ box-shadow:var(--shadow); }
.project-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(96%);
  transform:scale(1.01);
  transition:transform .35s ease;
}
.project-card:hover img{ transform:scale(1.05); }

.project-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  padding:18px;
  background:rgba(0,0,0,.48);
  opacity:0;
  transition:opacity .18s ease;
}
.project-card:hover .project-overlay,
.project-card:focus-within .project-overlay{ opacity:1; }
.project-title{
  color:#fff;
  font-size:14px;
  letter-spacing:.5px;
  text-transform:uppercase;
}

/* Mailing list */
.mailing{
  margin-top:44px;
  padding-top:28px;
  border-top:1px solid var(--border);
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:22px;
  align-items:start;
}
.mailing h2{
  margin:0 0 8px;
  font-size:14px;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.mailing p{ margin:0; color:var(--muted); max-width:62ch; }

.mailing .embed{
  border:1px solid var(--border);
  border-radius:0;
  overflow:hidden;
  background:#fff;
}
.mailing iframe{
  width:100%;
  height:240px;
  border:0;
  display:block;
}

/* embed resets ONLY (avoid affecting future Stripe/other iframes) */
.embed{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent;
}
.embed iframe{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  display:block;
}

/* Project pages */
.breadcrumb{
  margin:0 0 12px;
  color:var(--muted);
  font-size:13px;
}

.project-hero{
  margin:0 0 20px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.project-hero h1{
  margin:0;
  font-size:22px;
  letter-spacing:.4px;
  text-transform:uppercase;
}
.project-hero .desc{
  margin:0;
  color:var(--muted);
  max-width:68ch;
}

.gallery{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
}
.gallery figure{ margin:0; }
.gallery img{
  width:100%;
  aspect-ratio: 1 / 1;
  height:auto; /* important: prevents caption/row overlap issues */
  object-fit:cover;
  display:block;
  border-radius:0;
  border:1px solid var(--border);
  background:#f4f4f4;
}
.gallery figcaption{
  margin-top:8px;
  color:var(--muted);
  font-size:12px;
}

/* Simple content pages (if still used somewhere) */
.content{
  max-width:72ch;
}
.content h1{
  margin:0 0 12px;
  font-size:22px;
  letter-spacing:.4px;
  text-transform:uppercase;
}
.content h2{
  margin:28px 0 10px;
  font-size:14px;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.content p{
  margin:0 0 14px;
  color:var(--muted);
}
.content ul{ margin:0 0 14px 18px; color:var(--muted); }

/* About (single source of truth) */
.about-split{
  display:grid;
  grid-template-columns: 0.9fr 1.1fr; /* photo left, text right */
  gap:28px;
  align-items:start;
}
.about-photo{
  margin:0;
}
.about-photo img{
  width:100%;
  height:auto;
  display:block;
  border:1px solid var(--border);
  background:#f4f4f4;
}
.about-copy h1{
  margin:0 0 12px;
  font-size:22px;
  letter-spacing:.4px;
  text-transform:uppercase;
}
.about-copy p{
  margin:0 0 14px;
  color:var(--muted);
  max-width:60ch; /* keeps copy calm inside a wide column */
}
.about-contact{
  margin-top:18px;
}

/* Footer */
.site-footer{
  border-top:1px solid var(--border);
  padding:26px 0;
  color:var(--muted);
  font-size:12px;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; }
}

/* Shop (grid cards) */
.products-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}
.product-card{
  border:1px solid var(--border);
  border-radius:0;
  overflow:hidden;
  background:#fff;
}
.product-card img{
  width:100%;
  aspect-ratio: 1 / 1;
  object-fit:cover;
  display:block;
  background:#f4f4f4;
}
.product-body{ padding:14px 16px 16px; }
.product-name{ margin:0 0 6px; font-size:14px; letter-spacing:.4px; text-transform:uppercase; }
.product-meta{ margin:0 0 12px; color:var(--muted); font-size:13px; }
.product-actions{ display:flex; align-items:center; gap:10px; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:38px;
  padding:0 14px;
  border-radius:8px; /* keep as requested */
  border:1px solid var(--fg);
  background:var(--fg);
  color:#fff;
  font-size:13px;
  letter-spacing:.35px;
  text-transform:uppercase;
}
.btn:hover{ opacity:.9; }
.btn.secondary{
  background:transparent;
  color:var(--fg);
}

@media (max-width: 980px){
  .products-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}

/* --- Shop: single product layout --- */
.product-detail{
  display:grid;
  grid-template-columns: 1.6fr 0.4fr;
  gap:48px;
  align-items:start;
  margin-top:24px;
}

.product-media img{
  width:100%;
  aspect-ratio: 1 / 1;
  object-fit:cover;
  display:block;
  border:1px solid var(--border);
  background:#f4f4f4;
}

.product-info{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.product-title{
  margin:0;
  font-size:20px;
  letter-spacing:.4px;
  text-transform:uppercase;
}

.product-meta{
  margin:0;
  font-size:13px;
  color:var(--muted);
  line-height:1.6;
}

.product-description{
  margin:6px 0 0;
  font-size:14px;
  max-width:42ch;
}

@media (max-width: 820px){
  .work-deck{ grid-template-columns:1fr; }
  .project-card{ grid-column: 1 / -1; }
  .gallery{ grid-template-columns:1fr; }
  .mailing{ grid-template-columns:1fr; }
  .header-inner{ padding:14px 0; }

  .about-split{ grid-template-columns:1fr; }
  .about-copy p{ max-width:72ch; }

  .products-grid{ grid-template-columns:1fr; }

  .product-detail{
    grid-template-columns:1fr;
    gap:28px;
  }
}