:root {
  --pink: #e94b94;
  --pink-dark: #c73c7d;
  --black: #111111;
  --gray-900: #1c1c1c;
  --gray-700: #444444;
  --gray-500: #777777;
  --gray-200: #e9e9ec;
  --white: #ffffff;
  --container: 1180px;
  --shadow: 0 10px 30px rgba(0,0,0,0.25);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--white);
  background: var(--black);
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(var(--container), calc(100% - 2rem)); margin: 0 auto; }
.topbar {
  background: #000;
  color: #fff;
  padding: .7rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.topbar-inner {
  display: flex; gap: 1rem; justify-content: space-between; align-items: center; flex-wrap: wrap;
  font-size: 1rem; font-weight: 700;
}
.topbar a { color: var(--pink); }
header.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: rgba(17,17,17,0.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.nav-wrap { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding: .9rem 0; }
.logo {
  font-size: 1.5rem; font-weight: 800; letter-spacing: .4px; color:#fff;
}
.logo span { color: var(--pink); }
nav ul { list-style:none; display:flex; gap:1rem; padding:0; margin:0; align-items:center; }
nav a {
  padding: .75rem .9rem; border-radius: 999px; font-weight: 700; font-size: .98rem;
}
nav a:hover, nav a.active { background: var(--pink); color: #fff; }
.menu-toggle {
  display:none; background: var(--pink); color:#fff; border:none; border-radius:12px;
  padding: .8rem 1rem; font-size:1rem; font-weight:700;
}
.hero {
  min-height: 78vh;
  display:flex; align-items:center;
  position: relative;
  background: linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.72)), var(--hero-image) center/cover no-repeat;
}
.hero::after {
  content:""; position:absolute; inset:0;
  background: radial-gradient(circle at top right, rgba(233,75,148,0.18), transparent 35%);
}
.hero-content { position:relative; z-index:2; padding: 4rem 0; max-width: 760px; }
.badge {
  display:inline-block; background: rgba(233,75,148,.15); color: #ffd4e8;
  border:1px solid rgba(233,75,148,.4); padding:.55rem .85rem; border-radius:999px; font-weight:700; margin-bottom:1rem;
}
h1, h2, h3 { line-height: 1.15; margin: 0 0 1rem; }
h1 { font-size: clamp(2.2rem, 5vw, 4.5rem); }
h2 { font-size: clamp(1.7rem, 3vw, 2.6rem); }
h3 { font-size: 1.35rem; }
.lead { font-size: clamp(1.08rem, 2vw, 1.3rem); color: #f3f3f5; }
.hero-actions, .button-row { display:flex; gap:1rem; flex-wrap:wrap; margin-top:1.6rem; }
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding: 1rem 1.25rem; border-radius: 14px; font-weight:800; font-size:1rem;
  border: 2px solid transparent; min-height: 54px;
}
.btn-primary { background: var(--pink); color:#fff; box-shadow: var(--shadow); }
.btn-primary:hover { background: var(--pink-dark); }
.btn-secondary { background: transparent; border-color:#fff; color:#fff; }
.btn-secondary:hover { background:#fff; color:#111; }
section { padding: 4.5rem 0; }
.section-dark { background: #161616; }
.section-light { background: #f5f5f7; color: #111; }
.grid {
  display:grid; gap:1.25rem;
}
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.card {
  background: rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  padding: 1.4rem; border-radius: 24px; box-shadow: var(--shadow);
}
.section-light .card {
  background:#fff; border:1px solid rgba(0,0,0,.08); box-shadow:0 10px 24px rgba(0,0,0,.08);
}
.price-tag {
  display:inline-block; background:#111; color:#fff; padding:.5rem .8rem; border-radius:999px; font-weight:800; margin-bottom:.9rem;
}
.checklist { list-style:none; padding:0; margin: 1rem 0 0; }
.checklist li { padding:.45rem 0 .45rem 1.7rem; position:relative; }
.checklist li::before {
  content:"✓"; position:absolute; left:0; top:.42rem; font-weight:800; color: var(--pink);
}
.cta-band {
  background: linear-gradient(135deg, #111, #2a2a2a);
  border-top: 2px solid rgba(233,75,148,.35);
  border-bottom: 2px solid rgba(233,75,148,.35);
}
.service-hero {
  min-height: 56vh;
  background: linear-gradient(rgba(0,0,0,.55), rgba(0,0,0,.75)), var(--hero-image) center/cover no-repeat;
  display:flex; align-items:center;
}
.content-box {
  background: rgba(17,17,17,.82); border:1px solid rgba(255,255,255,.08); border-radius:24px; padding:1.5rem;
}
.service-summary p, .section-light p, .section-dark p { margin: 0 0 1rem; }
.callout {
  background: rgba(233,75,148,.12); border-left: 4px solid var(--pink); padding: 1rem 1rem 1rem 1.15rem; border-radius: 14px;
}
.location-list span {
  display:inline-block; padding:.45rem .7rem; margin:.3rem; background:rgba(255,255,255,.08); border-radius:999px; font-weight:700;
}
.contact-panel {
  background:#111; border:1px solid rgba(255,255,255,.08); border-radius:28px; padding:1.5rem;
}
.contact-list { list-style:none; padding:0; margin:0; }
.contact-list li { margin:.8rem 0; font-size:1.05rem; }
footer {
  background: #090909; padding: 2rem 0; border-top:1px solid rgba(255,255,255,0.08);
}
.footer-grid { display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.small { font-size:.95rem; color:#d2d2d7; }
.form-grid { display:grid; gap:1rem; }
input, textarea {
  width:100%; padding:1rem; border-radius:14px; border:1px solid #555; background:#1c1c1c; color:#fff; font-size:1rem;
}
textarea { min-height: 150px; resize: vertical; }
.notice { font-size:.95rem; color:#ffe4f1; }
@media (max-width: 980px) {
  .grid-3 { grid-template-columns: 1fr 1fr; }
  nav ul {
    display:none; position:absolute; right:1rem; top:100%; width:min(94vw, 360px); background:#101010;
    flex-direction:column; align-items:stretch; padding:1rem; border-radius:18px; box-shadow: var(--shadow);
  }
  nav ul.open { display:flex; }
  .menu-toggle { display:inline-block; }
}
@media (max-width: 720px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .hero, .service-hero { min-height:auto; }
  section { padding: 3.3rem 0; }
  .hero-content { padding: 3rem 0; }
  .topbar-inner { font-size:.95rem; }
  .logo { font-size: 1.25rem; }
  .btn { width:100%; }
}
