:root{--red:#c4161c;--bg:#ffffff;--text:#111;--muted:#6b7280;--border:#e5e7eb;--card:#fff;--soft:#fff5f5;--shadow:0 10px 30px rgba(0,0,0,.08);--radius:18px;--max:1100px;--font:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial;}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);color:var(--text);background:linear-gradient(180deg,#fff 0%,#fff 35%,#fafafa 100%);}
.wrap{max-width:var(--max);margin:0 auto;padding:0 18px;}
.topbar{background:var(--red);color:#fff;padding:14px 0;}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.brand{display:flex;align-items:center;gap:12px;}
.brandmark{width:44px;height:44px;border-radius:999px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.brandmark img{width:44px;height:44px;object-fit:cover;}
.brandname{font-weight:900;font-size:18px;line-height:1;}
.tagline{font-weight:800;font-size:12px;opacity:.95;}
.quicklinks{display:flex;gap:10px;flex-wrap:wrap;}
.qbtn{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;text-decoration:none;color:#fff;border:1px solid rgba(255,255,255,.22);font-weight:900;}
.qbtn img{width:16px;height:16px;display:block;}
.qbtn:hover{background:rgba(255,255,255,.10);}
.qbtn-dark{background:#25D366;border-color:#25D366;color:#fff;}
.qbtn-dark:hover{filter:brightness(0.95);}
.hero{padding:26px 0 18px;display:grid;grid-template-columns:1.1fr .9fr;gap:18px;}
@media(max-width:920px){.hero{grid-template-columns:1fr;}}
h1{margin:0 0 10px;font-size:clamp(28px,4vw,44px);letter-spacing:-.5px;line-height:1.05;}
.sub{margin:0;color:var(--muted);line-height:1.6;font-size:16px;}
.hero-cards{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;}
.pill{background:var(--soft);border:1px solid #ffd0d0;padding:10px 12px;border-radius:999px;font-weight:900;font-size:13px;}
.location{margin-top:18px;padding:14px;border-radius:var(--radius);border:1px solid var(--border);background:#fff;box-shadow:var(--shadow);}
.loc-title{font-weight:900;margin-bottom:4px;}
.link{display:inline-block;margin-top:8px;margin-bottom:18px;font-weight:900;color:var(--red);text-decoration:none;}
.link:hover{text-decoration:underline;}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;}
h2{margin:0 0 6px;letter-spacing:-.2px;}
.small{margin:0 0 12px;color:var(--muted);line-height:1.6;font-size:13px;}
.form label{display:block;font-weight:900;font-size:13px;margin:10px 0 6px;}
input,textarea{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);font:inherit;outline:none;}
input:focus,textarea:focus{border-color:#ffb4b4;box-shadow:0 0 0 4px rgba(196,22,28,.12);}
textarea{resize:vertical;min-height:110px;}
.btn{margin-top:12px;width:100%;padding:14px;border-radius:14px;border:1px solid rgba(0,0,0,.08);background:var(--red);color:#fff;font-weight:1000;cursor:pointer;font-size:15px;}
.fineprint{margin:10px 0 0;color:var(--muted);font-size:12px;line-height:1.6;}
.upload-meta{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-weight:800;font-size:12px;margin-top:8px;}
.preview{margin-top:10px;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fafafa;}
.preview img{display:block;width:100%;height:auto;}
.hp{position:absolute;left:-9999px;top:-9999px;}
.recaptcha{margin:12px 0 0;}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:0 0 24px;}
@media(max-width:920px){.grid{grid-template-columns:1fr;}}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;font-weight:1000;text-decoration:none;color:#111;}
.btn-outline:hover{box-shadow:var(--shadow);transform:translateY(-1px);}
.footer{border-top:1px solid var(--border);padding:18px 0 30px;color:var(--muted);font-size:12px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.muted{opacity:.9;}

select{width:100%;padding:14px 14px;border-radius:14px;border:1px solid #e5e7eb;font:inherit;background:#fff;}


/* Storefront + Instagram feed */
.storefront{
  width:100%;
  border-radius:18px;
  overflow:hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,0.12);
  margin-bottom:18px;
  background:#fff;
}
.storefront img{
  width:100%;
  height:auto;
  max-height:none;
  object-fit:contain;
  display:block;
  background:#fff;
}
.ig-feed{
  margin: 14px 0 22px;
  padding: 14px 14px 16px;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 18px;
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(6px);
}
.ig-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.ig-head h3{ margin:0; }
.ig-links{ display:flex; gap:10px; }
.ig-follow{
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}
.ig-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.ig-item{
  display:block;
  border-radius: 12px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,0.06);
  background:#fff;
}
.ig-item img{
  width:100%;
  height:100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  display:block;
}
.ig-note{
  margin-top:10px;
  font-size: 13px;
  opacity: 0.8;
}

.ig-item{
  position:relative;
  display:block;
}
.ig-item img{
  transition: transform .18s ease, filter .18s ease;
}
.ig-item:hover img{
  transform: scale(1.04);
  filter: saturate(1.05);
}
.ig-badge{
  position:absolute;
  top:8px;
  left:8px;
  padding:4px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  color:#fff;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
}


/* Service tabs */
.service-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin: 0 0 16px;
}
.service-tabs .tab{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,0.10);
  background:#fff;
  font-weight:800;
  font-size:13px;
  text-decoration:none;
  color:#111;
  box-shadow: 0 8px 18px rgba(0,0,0,0.08);
  transition: transform .15s ease, box-shadow .15s ease;
}
.service-tabs .tab:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 22px rgba(0,0,0,0.12);
}

/* Instagram profile link */
.ig-profile{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:#111;
  font-weight:900;
}
.ig-handle{
  font-size:14px;
}
.ig-icon{
  width:18px;
  height:18px;
  display:inline-block;
  background: currentColor;
  -webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5Zm10 2H7a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V7a3 3 0 0 0-3-3Zm-5 4.2a3.8 3.8 0 1 1 0 7.6 3.8 3.8 0 0 1 0-7.6Zm0 2a1.8 1.8 0 1 0 0 3.6 1.8 1.8 0 0 0 0-3.6ZM18 6.5a1 1 0 1 1 0 2 1 1 0 0 1 0-2Z"/></svg>') center / contain no-repeat;
          mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5Zm10 2H7a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V7a3 3 0 0 0-3-3Zm-5 4.2a3.8 3.8 0 1 1 0 7.6 3.8 3.8 0 0 1 0-7.6Zm0 2a1.8 1.8 0 1 0 0 3.6 1.8 1.8 0 0 0 0-3.6ZM18 6.5a1 1 0 1 1 0 2 1 1 0 0 1 0-2Z"/></svg>') center / contain no-repeat;
}


/* Booking form subtitle */
.form-subtitle{margin:-6px 0 18px 0;color:#6b7280;font-size:14px;line-height:1.4}

.qbtn-dark img{filter:brightness(0) invert(1);} /* ensure white icon */

.form-subtitle .voucher-highlight{font-weight:800;color:#b80f0f;}
.form-subtitle .reply-note{display:inline-block;margin-top:2px;}

/* WhatsApp Button Styling */
.qbtn-whatsapp {
  background-color: #25D366;
  color: #ffffff;
  border-color: #25D366;
}

.qbtn-whatsapp:hover {
  background-color: #1ebe5d;
  border-color: #1ebe5d;
}

.qbtn-whatsapp img {
  filter: brightness(0) invert(1);
}


/* Contact Us (footer replacement) */
.contact-us .contact-lines{margin-top:6px;margin-bottom:12px;color:var(--muted);}
.contact-us .contact-line{margin:6px 0;}
.contact-us .contact-line a{color:var(--red);font-weight:900;text-decoration:none;}
.contact-us .contact-line a:hover{text-decoration:underline;}
.contact-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;}
.cbtn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;border-radius:12px;
  border:1px solid #e5e7eb;background:#fff;color:#111;
  font-weight:900;text-decoration:none;
}
.cbtn:hover{background:#f3f4f6;}
.cbtn img{width:16px;height:16px;display:block;}
.cbtn-whatsapp{background:#25D366;border-color:#25D366;color:#fff;}
.cbtn-whatsapp:hover{filter:brightness(0.95);}


a.loc-addr{color:var(--muted);text-decoration:none;}
a.loc-addr:hover{text-decoration:none;}

.preview iframe{display:block;width:100%;height:220px;border:0;border-radius:14px;}

.contact-actions a[href^="tel:"] img,.contact-actions a[href^="sms:"] img{filter:brightness(0);}
