.btn { display: inline-block; padding: 14px 32px; font: 500 12px/1 var(--sans); letter-spacing: 2px;
  text-transform: uppercase; text-decoration: none; border-radius: 2px; border: 1px solid var(--ink);
  cursor: pointer; transition: background .3s ease, color .3s ease; }
.btn-primary { background: var(--ink); color: var(--porcelain); }
.btn-primary:hover { background: transparent; color: var(--ink); }
.btn-outline { background: transparent; color: var(--ink); }
.btn-outline:hover { background: var(--ink); color: var(--porcelain); }
.btn-whatsapp { background: var(--terracotta); border-color: var(--terracotta); color: #F9F1E4; }
.btn-whatsapp:hover { background: transparent; color: var(--terracotta); }
.btn:disabled { opacity: .6; cursor: wait; }

.site-header { position: sticky; top: 0; z-index: 40; background: var(--porcelain);
  border-bottom: 1px solid var(--husk); }
.site-header .bar { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px;
  max-width: 1200px; margin: 0 auto; }
.brand { font-family: var(--serif); font-size: 20px; letter-spacing: 4px; text-transform: uppercase;
  text-decoration: none; }
.site-nav { display: flex; gap: 28px; align-items: center; }
.site-nav a { font: 500 12px/1 var(--sans); letter-spacing: 1.5px; text-transform: uppercase;
  text-decoration: none; color: var(--driftwood); }
.site-nav a:hover, .site-nav a[aria-current] { color: var(--ink); }
.cart-link { position: relative; }
.cart-link .badge { display: inline-block; min-width: 18px; text-align: center; background: var(--sage);
  color: var(--porcelain); border-radius: 9px; font-size: 11px; padding: 2px 5px; margin-left: 4px; }
.nav-toggle { display: none; background: none; border: 0; font-size: 22px; cursor: pointer; color: var(--ink); }
@media (max-width: 760px) {
  .nav-toggle { display: block; }
  .site-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column;
    background: var(--porcelain); border-bottom: 1px solid var(--husk); padding: 24px; gap: 20px; }
  .site-nav.open { display: flex; }
}

.card { text-decoration: none; }
.card figure { aspect-ratio: 4 / 5; overflow: hidden; background: var(--husk); }
.card img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.card:hover img { transform: scale(1.03); }
.card h3 { font-size: 20px; margin: 14px 0 2px; }
.card .byline { font-size: 13px; color: var(--driftwood); }

input, select, textarea { width: 100%; padding: 12px 14px; font: 400 15px/1.4 var(--sans);
  color: var(--ink); background: #fff; border: 1px solid var(--husk); border-radius: 2px; }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--sage); outline-offset: 0; }
label { display: block; font: 500 12px/1 var(--sans); letter-spacing: 1px; text-transform: uppercase;
  color: var(--driftwood); margin: 18px 0 6px; }
.field-error { color: var(--terracotta); font-size: 13px; margin-top: 4px; }
.hp-field { position: absolute; left: -9999px; opacity: 0; }

.site-footer { background: var(--sand); border-top: 1px solid var(--husk); padding: 64px 0 32px; }
.site-footer .cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 40px; max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.site-footer a { color: var(--driftwood); text-decoration: none; display: block; padding: 4px 0; font-size: 14px; }
.site-footer .legal { text-align: center; color: var(--driftwood); font-size: 13px; margin-top: 48px; }

.drawer { position: fixed; top: 0; right: 0; bottom: 0; width: min(420px, 100%); background: var(--porcelain);
  z-index: 51; transform: translateX(100%); transition: transform .4s ease; display: flex; flex-direction: column;
  border-left: 1px solid var(--husk); visibility: hidden; }
.drawer.open { transform: none; visibility: visible; }
@media (max-width: 640px) {
  .drawer { top: auto; left: 0; width: 100%; max-height: 85vh; transform: translateY(100%);
    border-left: 0; border-top: 1px solid var(--husk); }
  .drawer.open { transform: none; }
}
.drawer-head { display: flex; justify-content: space-between; align-items: center; padding: 20px 24px;
  border-bottom: 1px solid var(--husk); }
.drawer-body { flex: 1; overflow-y: auto; padding: 12px 24px; }
.drawer-foot { padding: 20px 24px; border-top: 1px solid var(--husk); }
.drawer-line { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--husk); }
.drawer-line img { width: 64px; height: 80px; object-fit: cover; }
.qty-controls { display: inline-flex; align-items: center; gap: 10px; }
.qty-controls button { width: 28px; height: 28px; border: 1px solid var(--husk); background: none;
  cursor: pointer; padding: 0; color: var(--ink); }
