:root{
  --bg:#ffffff;
  --ink:#121011;
  --muted:#5b5252;
  --brand:#F0A098;
  --brand2:#E7C4C1;
  --card:#ffffff;
  --shadow: 0 18px 45px rgba(0,0,0,.10);
  --radius: 22px;
  --max: 1120px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background: radial-gradient(1200px 500px at 20% -10%, rgba(240,160,152,.22), transparent 60%),
              radial-gradient(900px 450px at 80% 0%, rgba(231,196,193,.18), transparent 55%),
              var(--bg);
  line-height:1.6;
}
a{color:inherit}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 18px}
.topbar{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(255,255,255,.75);
  border-bottom: 1px solid rgba(18,16,17,.08);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0;
}
.brand{
  display:flex;align-items:center;gap:10px;text-decoration:none;
}
.brand img{width:42px;height:42px;border-radius:14px;box-shadow:0 10px 25px rgba(0,0,0,.14)}
.brand .title{
  display:flex;flex-direction:column;line-height:1.1
}
.brand .title strong{font-family:"Playfair Display", Georgia, serif;font-size:18px;letter-spacing:.2px}
.brand .title span{font-size:12px;color:var(--muted)}
.navlinks{
  display:flex;align-items:center;gap:14px;
}
.navlinks a{
  text-decoration:none;
  font-size:13px;
  padding:10px 12px;
  border-radius:999px;
  transition: .2s ease;
}
.navlinks a:hover{background:rgba(240,160,152,.18)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border:1px solid rgba(18,16,17,.12);
  background:#fff;
  border-radius:999px;
  padding:12px 16px;
  text-decoration:none;
  box-shadow: 0 10px 25px rgba(0,0,0,.08);
  transition:.2s ease;
  font-weight:600;
}
.btn:hover{transform:translateY(-1px);box-shadow: 0 16px 35px rgba(0,0,0,.12)}
.btn.primary{
  background: linear-gradient(135deg, var(--brand), #ffb7b0);
  border-color: rgba(240,160,152,.5);
}
.btn.primary:hover{filter:saturate(1.05)}
.hero{
  position:relative;
  overflow:hidden;
  border-bottom: 1px solid rgba(18,16,17,.08);
}
.hero-inner{
  padding: 46px 0 28px;
  display:grid;grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  align-items:center;
}
.hero-card{
  background: rgba(255,255,255,.78);
  border:1px solid rgba(18,16,17,.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 26px 22px;
}
.kicker{
  display:inline-flex;align-items:center;gap:8px;
  background: rgba(240,160,152,.16);
  border: 1px solid rgba(240,160,152,.28);
  padding: 8px 12px;border-radius:999px;
  font-size:12px;font-weight:700;
}
h1{
  font-family:"Playfair Display", Georgia, serif;
  font-size: 44px;
  line-height:1.05;
  margin: 14px 0 10px;
}
.hero p{margin:0;color:var(--muted)}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.badges{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:14px
}
.badge{
  font-size:12px;
  padding:8px 10px;border-radius:999px;
  border:1px solid rgba(18,16,17,.10);
  background:#fff;
}
.hero-media{
  position:relative;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
  border: 1px solid rgba(18,16,17,.10);
  min-height: 420px;
}
.hero-media img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.hero-media .overlay{
  position:absolute;inset:0;
  background: linear-gradient(0deg, rgba(18,16,17,.35), rgba(18,16,17,.05));
}
.hero-media .stamp{
  position:absolute;left:16px;bottom:16px;
  background: rgba(255,255,255,.80);
  border:1px solid rgba(255,255,255,.7);
  border-radius: 16px;
  padding:10px 12px;
  display:flex;align-items:center;gap:10px;
}
.stamp strong{font-size:13px}
.stamp span{font-size:12px;color:var(--muted)}
.section{padding:56px 0}
.section h2{
  font-family:"Playfair Display", Georgia, serif;
  font-size:34px;margin:0 0 10px
}
.section p.lead{margin:0 0 22px;color:var(--muted)}
.grid-3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.card{
  background: rgba(255,255,255,.85);
  border:1px solid rgba(18,16,17,.10);
  border-radius: var(--radius);
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  padding: 18px;
}
.card h3{margin:0 0 6px;font-size:16px}
.card p{margin:0;color:var(--muted);font-size:14px}
.card .meta{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.pill{
  font-size:12px;
  padding:7px 10px;border-radius:999px;
  background: rgba(240,160,152,.14);
  border:1px solid rgba(240,160,152,.25);
}
.gallery{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 10px;
}
.gitem{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(18,16,17,.10);
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
  cursor:pointer;
}
.gitem img{width:100%;height:100%;object-fit:cover;display:block;transition:.25s ease}
.gitem:hover img{transform:scale(1.04)}
/* Responsive mosaic */
.gitem:nth-child(1){grid-column: span 4; aspect-ratio: 4/5}
.gitem:nth-child(2){grid-column: span 4; aspect-ratio: 4/5}
.gitem:nth-child(3){grid-column: span 4; aspect-ratio: 4/5}
.gitem:nth-child(4){grid-column: span 6; aspect-ratio: 16/10}
.gitem:nth-child(5){grid-column: span 6; aspect-ratio: 16/10}
.gitem:nth-child(6){grid-column: span 6; aspect-ratio: 16/10}
.gitem:nth-child(7){grid-column: span 6; aspect-ratio: 16/10}
.lightbox{
  position:fixed;inset:0;z-index:100;
  background: rgba(18,16,17,.86);
  display:none;
  align-items:center;justify-content:center;
  padding: 22px;
}
.lightbox.open{display:flex}
.lightbox .frame{
  max-width: 980px;width:100%;
  border-radius: 18px;
  overflow:hidden;
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
  position:relative;
}
.lightbox img{width:100%;height:auto;display:block;background:#000}
.lb-close{
  position:absolute;right:10px;top:10px;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(18,16,17,.10);
  border-radius: 999px;
  padding:10px 12px;
  cursor:pointer;
  font-weight:800;
}
.two{
  display:grid;grid-template-columns: 1.1fr .9fr;gap:16px;align-items:start
}
.embed{
  width:100%;
  border:1px solid rgba(18,16,17,.10);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  background:#fff;
}
.embed iframe{width:100%;height:520px;border:0}
.map iframe{height:420px}
.contact{
  display:grid;grid-template-columns: 1fr 1fr;gap:16px
}
.field{
  display:flex;flex-direction:column;gap:6px;margin-bottom:12px
}
label{font-size:13px;font-weight:700}
input,textarea{
  border:1px solid rgba(18,16,17,.14);
  border-radius: 14px;
  padding: 12px 12px;
  font: inherit;
  background: rgba(255,255,255,.92);
}
textarea{min-height:120px;resize:vertical}
small{color:var(--muted)}
.footer{
  padding: 28px 0 90px;
  border-top: 1px solid rgba(18,16,17,.10);
  background: rgba(255,255,255,.72);
}
.footer .row{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between
}
.footer .row .left{
  display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px
}
.footer .row .left img{width:28px;height:28px;border-radius:10px}
.floating-wa{
  position:fixed;right:18px;bottom:18px;z-index:60;
  width:56px;height:56px;border-radius:999px;
  background: #25D366;
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;
}
.floating-wa svg{width:28px;height:28px;fill:#fff}
.toast{
  position:fixed;left:18px;bottom:18px;z-index:60;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(18,16,17,.10);
  border-radius: 18px;
  padding: 10px 12px;
  box-shadow: 0 14px 44px rgba(0,0,0,.14);
  display:none;
  max-width: 360px;
  font-size: 13px;
}
.toast.show{display:block}
.reveal{opacity:0;transform:translateY(10px);transition: .65s ease}
.reveal.on{opacity:1;transform:none}
@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr; padding: 32px 0 22px}
  .hero-media{min-height: 340px}
  h1{font-size: 38px}
  .grid-3{grid-template-columns:1fr}
  .two{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .embed iframe{height:420px}
  .map iframe{height:360px}
  .gitem:nth-child(1),.gitem:nth-child(2),.gitem:nth-child(3){grid-column:span 6}
  .gitem:nth-child(4),.gitem:nth-child(5),.gitem:nth-child(6),.gitem:nth-child(7){grid-column:span 12}
}