
:root{
  --bg:#ffffff;
  --fg:#1f2937;
  --muted:#6b7280;
  --primary:#ec4899;
  --primary-600:#db2777;
  --accent:#a78bfa;
  --card:#f8f8fc;
  --border:#ececf2;
  --ring:rgba(236,72,153,.25);
  --radius:14px;
  --shadow:0 10px 24px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial,sans-serif;
  color:var(--fg);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  background:
    radial-gradient(1200px 800px at 120% -20%, rgba(167,139,250,.25), transparent 60%),
    radial-gradient(800px 600px at -20% 10%, rgba(236,72,153,.18), transparent 55%),
    linear-gradient(180deg, #ffffff, #fdfcff 40%, #fbf8ff);
}
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:-1; opacity:.05;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"140\" height=\"140\"><filter id=\"n\"><feTurbulence type=\"fractalNoise\" baseFrequency=\"0.8\" numOctaves=\"3\" stitchTiles=\"stitch\"/></filter><rect width=\"100%\" height=\"100%\" filter=\"url(%23n)\" opacity=\"0.06\"/></svg>');
  mix-blend-mode:multiply;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3{line-height:1.2;margin:0 0 .5rem 0; font-family: ui-serif, Georgia, Cambria, 'Times New Roman', Times, serif}
h1{font-size:clamp(1.9rem,3.4vw,3rem)}
h2{font-size:clamp(1.5rem,2.4vw,2.1rem);margin-bottom:1rem}
h3{font-size:clamp(1.15rem,1.9vw,1.35rem);margin-top:.5rem}
p{margin:.5rem 0 1rem}
ul{padding-left:1.1rem}

.section{padding:clamp(2rem,4vw,4rem) clamp(1rem,3vw,2rem);max-width:1100px;margin:0 auto}
.section.alt{background:linear-gradient(180deg,#fff, #faf9ff)}
.note{color:var(--muted);font-size:.95rem}

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.9);backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:.6rem 1rem; min-height:56px;
}
.site-header[data-shadow="on"]{box-shadow:var(--shadow)}
.logo{display:inline-flex;align-items:center;gap:.5rem}
.primary-nav{display:flex;gap:.9rem;align-items:center}
.primary-nav a{padding:.45rem .65rem;border-radius:10px; font-family: ui-rounded, 'SF Pro Rounded', 'Segoe UI', system-ui, sans-serif}
.primary-nav a:hover{background:var(--card);text-decoration:none}
.primary-nav .cta{background:var(--primary);color:#fff}
.nav-toggle{display:none;background:none;border:0;padding:.4rem;margin-left:auto}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--fg);margin:5px 0;border-radius:2px}

@media (max-width: 860px){
  .primary-nav{position:fixed;inset:58px 0 auto 0; background:#fff; padding:1rem; display:none; flex-direction:column; align-items:flex-start; box-shadow:var(--shadow); max-height:80vh; overflow:auto}
  .primary-nav.open{display:flex}
  .nav-toggle{display:inline-block}
}

.hero{position:relative;display:grid;align-items:center;min-height:72vh; padding-top:clamp(2rem,6vw,5rem)}
.hero picture{position:absolute;inset:0;z-index:-2;opacity:.55;filter:saturate(112%) contrast(106%)}
.hero-overlay{position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(80% 80% at 50% 20%, rgba(255,255,255,.85) 0%, rgba(255,255,255,.65) 35%, rgba(255,255,255,.4) 60%, rgba(255,255,255,0) 100%),
    linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,.2));
}
.hero::after{
  content:""; position:absolute; width:34vmin; height:34vmin; right:-8vmin; top:-8vmin;
  background: radial-gradient(circle at 30% 30%, rgba(236,72,153,.22), rgba(236,72,153,0) 60%);
  filter: blur(6px);
  animation: float 14s ease-in-out infinite alternate;
}
@keyframes float{ from{ transform:translateY(0) translateX(0)} to{ transform:translateY(12px) translateX(-10px)} }

.hero-content{max-width:950px;margin:0 auto;padding:clamp(2rem,4vw,4rem) 1rem;text-align:center}
.hero .btn{margin:.25rem .3rem}
.badges{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;color:#111;padding:0;margin:1rem 0 0;list-style:none}
.badges li{background:#fff;border:1px solid var(--border);border-radius:999px;padding:.3rem .7rem;box-shadow:var(--shadow)}

.btn{display:inline-block;padding:.7rem 1rem;border-radius:12px;border:1px solid var(--primary);font-weight:600}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn.primary:hover{background:var(--primary-600)}
.btn.outline{background:transparent;color:var(--primary)}
.btn.small{padding:.5rem .8rem;font-size:.95rem}

.grid.two{display:grid;grid-template-columns:1.1fr .9fr;gap:1.2rem;align-items:center}
.media{display:grid;gap:.6rem}
@media (max-width: 900px){.grid.two{grid-template-columns:1fr}}

.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.card img{border-radius:10px;margin-bottom:.6rem; filter:saturate(108%) contrast(103%) }
.card.highlight{border:2px solid var(--accent);background:#fff}
@media (max-width: 980px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 580px){.cards{grid-template-columns:1fr}}

.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.price-col{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.price-col ul{list-style:none;padding:0;margin:0}
.price-col li{display:flex;align-items:center;justify-content:space-between;border-bottom:1px dashed var(--border);padding:.45rem 0}
.price-col li:last-child{border-bottom:0}
.price-col.accent{border:2px solid var(--primary)}

@media (max-width: 980px){.pricing{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 580px){.pricing{grid-template-columns:1fr}}

.masonry{columns:3 320px;column-gap:1rem}
.masonry figure{break-inside:avoid;background:#fff;border:1px solid var(--border);border-radius:12px;margin:0 0 1rem;padding:.5rem;box-shadow:var(--shadow)}
.masonry figcaption{font-size:.9rem;color:var(--muted);margin-top:.4rem}

.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.reviews blockquote{margin:0;background:#fff;border-left:4px solid var(--primary);padding:1rem;border-radius:10px;box-shadow:var(--shadow)}
.reviews cite{display:block;color:var(--muted);margin-top:.5rem;font-style:normal}
@media (max-width: 900px){.reviews{grid-template-columns:1fr}}

.post{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1rem;box-shadow:var(--shadow);margin-bottom:1rem}
.post .meta{color:var(--muted);font-size:.9rem}

.contact .map{margin-top:1rem; width:100%; height:auto; aspect-ratio:4/3; border:1px solid var(--border); border-radius:12px; overflow:hidden; box-shadow:var(--shadow)}
.form{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1rem;box-shadow:var(--shadow)}
.form label{display:block;margin-bottom:.7rem}
.form input,.form textarea{width:100%;padding:.7rem;border:1px solid var(--border);border-radius:10px;font:inherit}
.form input:focus,.form textarea:focus{outline:none;box-shadow:0 0 0 4px var(--ring);border-color:var(--primary)}
.checkbox{display:flex;align-items:flex-start;gap:.6rem}
.form-status{min-height:1.4em;color:var(--muted)}

.site-footer{padding:2rem 1rem;border-top:1px solid var(--border);text-align:center;background:#fff}
.footer-nav{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin:.5rem 0 0}
.tiny{color:var(--muted);font-size:.85rem; letter-spacing:.2px}

.reveal-on-scroll{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal-on-scroll.visible{opacity:1;transform:none}

body{scroll-padding-top:72px}
