:root{
  --pink:#ff4fa3;
  --orange:#ff944d;
  --green:#9be28a;

  --ink:#1f1b22;
  --muted:rgba(31,27,34,.65);
  --line:rgba(31,27,34,.12);

  --radius:26px;
  --shadow:0 18px 60px rgba(30,20,40,.12);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 700px at 10% 0%, rgba(255,79,163,.18), transparent 60%),
    radial-gradient(1200px 700px at 90% 10%, rgba(255,148,77,.18), transparent 60%),
    linear-gradient(180deg,#ffffff 0%, #fff4f8 40%, #fff0e6 70%, #ffffff 100%);
}

.container{width:min(1100px,calc(100% - 44px));margin:0 auto}
.center{text-align:center}
.max{max-width:72ch;margin:0 auto}
.muted{color:var(--muted)}
.white{color:#fff}
a{text-decoration:none;color:inherit}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

h1,h2,h3{font-family:Fraunces,serif;margin:0}
h1{font-size:clamp(44px,6vw,78px);line-height:1.05;color:#fff;text-align:center}
h2{font-size:clamp(34px,4vw,52px)}
h3{font-size:22px}

.kicker{
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:12px;
  font-weight:800;
  margin:0 0 10px;
}
.kicker.orange{color:rgba(255,148,77,.95)}
.kicker.pink{color:rgba(255,79,163,.95)}
.kicker.green{color:rgba(155,226,138,.95)}

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:14px}
.brand-name{font-family:Fraunces,serif;font-size:26px;color:var(--pink)}
.navlinks{display:flex;gap:26px;font-weight:700;color:rgba(31,27,34,.70)}
.navlinks a:hover{color:var(--pink)}
.nav-toggle{display:none}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:16px;
  padding:12px 16px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
  cursor:pointer;
}
.btn-primary{
  border:none;color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--orange));
  box-shadow:0 14px 30px rgba(255,79,163,.25);
}
.btn-outline{background:#fff}
.btn-hero{
  padding:18px 34px;border-radius:999px;font-size:18px;
  border:none;color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--orange));
  box-shadow:0 22px 60px rgba(255,79,163,.35);
}
.btn-cta{
  padding:18px 34px;border-radius:999px;
  background:#fff;border:1px solid rgba(255,255,255,.45);
  color:var(--pink);font-weight:900;
}
.block{width:100%}

/* HERO (solo dancer sunset) */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;
  background-image:url("/assets/images/hula_dancer_sunset_hero.png");
  background-size:cover;background-position:center;
  z-index:-2;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.22),rgba(0,0,0,.55));
  z-index:-1;
}
.hero-inner{padding:110px 0 80px;display:flex;flex-direction:column;align-items:center;gap:22px}
.hero-sub{max-width:72ch;text-align:center;color:rgba(255,255,255,.88);font-size:18px;line-height:1.6;margin:0}

/* SECTIONS */
.section{padding:90px 0}
.section.soft{
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(255,79,163,.12), transparent 60%),
    radial-gradient(900px 420px at 80% 10%, rgba(255,148,77,.12), transparent 60%),
    linear-gradient(180deg,#ffffff,#fffaf6);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:center}
.body{font-size:17px;line-height:1.65;color:rgba(31,27,34,.78);margin:14px 0 18px}
.checks{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.checks li{display:flex;gap:12px;align-items:flex-start;font-weight:700;color:rgba(31,27,34,.78)}
.checks li::before{
  content:"✓";width:28px;height:28px;border-radius:99px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(155,226,138,.22);color:rgba(31,27,34,.82);flex:0 0 28px
}
.about-photo{
  height:520px;border-radius:28px;border:1px solid var(--line);box-shadow:var(--shadow);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.15)),
    url("/assets/images/hula_hands_cultural_dance.png");
  background-size:cover;background-position:center;
}

/* SERVICES */
.cards{margin-top:34px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.card{border-radius:26px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}
.card-img{height:200px;background-size:cover;background-position:center}
.card-body{padding:18px}
.card-body p{margin:8px 0 12px;color:rgba(31,27,34,.72);line-height:1.55}
.mini{margin:0 0 14px;padding-left:18px;color:rgba(31,27,34,.70);line-height:1.55}
.mini li{margin:6px 0}

/* service card image bindings */
.img-wedding{background-image:url("/assets/images/hula_dancer_sunset_hero.png")}
.img-party{background-image:url("/assets/images/group_hula_performance_beach.png")}
.img-grad{background-image:url("/assets/images/kids_hula_dance_class.png")}
.img-corp{background-image:url("/assets/images/cultural_hula_ceremony.png")}

/* CTA */
.cta{padding:92px 0;background:linear-gradient(135deg,var(--pink),var(--orange))}
.cta-inner{width:min(900px,calc(100% - 44px));margin:0 auto;text-align:center;color:#fff}

/* EVENTS */
.event-grid{margin-top:34px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.event-card{background:#fff;border-radius:26px;border:1px solid var(--line);box-shadow:var(--shadow);padding:18px;display:flex;gap:16px}
.event-date{
  width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--pink),var(--orange));
  color:#fff;font-weight:900;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:0 0 64px
}
.event-date .m{font-size:13px;letter-spacing:.06em}
.event-date .d{font-size:22px;line-height:1}
.event-meta{margin:0 0 10px;color:rgba(31,27,34,.70);font-weight:700}
.event-loc{margin:12px 0 12px;color:rgba(155,226,138,.95);font-weight:900}

/* ✅ MOSAIC (exact: hands / kids / group / sunset) */
.mosaic{
  margin-top:34px;
  display:grid;
  grid-template-columns:1.15fr .92fr .92fr;
  grid-template-rows:240px 340px;
  gap:18px;
}
.mosaic button{
  border:none;border-radius:26px;cursor:pointer;
  box-shadow:var(--shadow);border:1px solid var(--line);
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
.m1{grid-column:1;grid-row:1 / span 2;background-image:url("/assets/images/hula_hands_cultural_dance.png")}
.m2{grid-column:2;grid-row:1;background-image:url("/assets/images/kids_hula_dance_class.png")}
.m3{grid-column:3;grid-row:1;background-image:url("/assets/images/group_hula_performance_beach.png")}
.m4{grid-column:2 / span 2;grid-row:2;background-image:url("/assets/images/hawaiian_sunset_palm_trees.png")}

/* TESTIMONIALS */
.testimonials{margin-top:34px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:22px;position:relative}
.quote::before{content:"“";position:absolute;left:16px;top:8px;font-size:44px;color:rgba(255,79,163,.35);font-family:Fraunces,serif}
.q{margin:18px 0 18px;font-size:18px;line-height:1.7;color:rgba(31,27,34,.75);font-style:italic}
.who{display:flex;gap:12px;align-items:center}
.avatar{width:48px;height:48px;border-radius:999px;background-size:cover;background-position:center;border:2px solid rgba(155,226,138,.35)}
.a1{background-image:url("/assets/images/young_woman_testimonial_portrait.png")}
.a2{background-image:url("/assets/images/hawaiian_man_testimonial_portrait.png")}
.a3{background-image:url("/assets/images/hawaiian_woman_testimonial_portrait.png")}
.name{font-weight:900}
.role{color:rgba(31,27,34,.62);font-weight:700}

/* BOOKING */
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
.form{background:#fff;border-radius:26px;border:1px solid var(--line);box-shadow:var(--shadow);padding:20px}
label{display:flex;flex-direction:column;gap:8px;font-size:13px;font-weight:800;margin-bottom:12px;color:rgba(31,27,34,.75)}
input,select,textarea{border-radius:16px;border:1px solid var(--line);padding:12px;font:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,79,163,.18)}

/* FOOTER */
.footer{padding:40px 0;border-top:1px solid var(--line);background:#fff}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.foot-brand{font-family:Fraunces,serif;font-size:20px;color:var(--pink)}

/* RESPONSIVE */
@media(max-width:1050px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .event-grid{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
  .booking-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .about-photo{height:420px}
}
@media(max-width:760px){
  .navlinks{display:none}
  .nav-toggle{display:block}
  .mosaic{grid-template-columns:1fr;grid-template-rows:auto}
  .m1,.m2,.m3,.m4{grid-column:auto;grid-row:auto;height:220px}
}
