@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#fdf6f9;
  --soft:#f8d7e6;
  --secondary:#d6e6f8;
  --cta:#e89ab5;
  --cta-hover:#d4809e;
  --text:#333333;
  --text-light:#666666;
  --white:#ffffff;
  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --shadow-md:0 4px 20px rgba(0,0,0,.08);
  --radius:12px;
  --radius-lg:20px;
  --max-w:1200px;
  --hdr:72px;
}

html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;color:var(--text);background:var(--bg);line-height:1.75;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--cta);text-decoration:none;transition:color .25s}
a:hover{color:var(--cta-hover)}

.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}

/* === HEADER === */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(253,246,249,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:var(--shadow-sm);height:var(--hdr);display:flex;align-items:center}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.2rem;color:var(--text)}
.logo img{height:38px;width:auto}
.logo span{background:linear-gradient(135deg,var(--cta),#b07cc6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{color:var(--text);font-weight:500;font-size:.95rem;position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--cta);border-radius:2px;transition:width .3s}
.nav-links a:hover::after{width:100%}
.mobile-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.mobile-toggle span{display:block;width:26px;height:2.5px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}

/* === HERO === */
.hero{position:relative;min-height:480px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background-size:cover;background-position:center;background-color:var(--soft)}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(253,246,249,.78) 0%,rgba(248,215,230,.55) 50%,rgba(253,246,249,.88) 100%);z-index:1}
.hero-content{position:relative;z-index:2;padding:80px 24px;max-width:780px}
.hero h1{font-size:2.65rem;font-weight:700;line-height:1.25;margin-bottom:20px}
.hero p{font-size:1.12rem;color:var(--text-light);margin-bottom:32px;line-height:1.75}

.btn-cta{display:inline-block;background:var(--cta);color:var(--white);font-family:'Poppins',sans-serif;font-weight:600;font-size:1.05rem;padding:16px 40px;border-radius:50px;border:none;cursor:pointer;transition:background .3s,transform .2s,box-shadow .3s;box-shadow:0 4px 16px rgba(232,154,181,.35)}
.btn-cta:hover{background:var(--cta-hover);color:var(--white);transform:translateY(-2px);box-shadow:0 6px 24px rgba(232,154,181,.45)}

/* === SECTIONS === */
.section{padding:72px 0}
.section-alt{background:linear-gradient(135deg,var(--white) 0%,rgba(248,215,230,.15) 100%)}
.section h2{font-size:1.95rem;font-weight:700;margin-bottom:20px;line-height:1.3}
.section h3{font-size:1.3rem;font-weight:600;margin-bottom:12px}
.section p{color:var(--text-light);margin-bottom:16px;max-width:780px}
.section ul{list-style:none;padding:0;margin-bottom:20px}
.section ul li{position:relative;padding-left:28px;margin-bottom:12px;color:var(--text-light)}
.section ul li::before{content:'';position:absolute;left:0;top:10px;width:10px;height:10px;background:var(--soft);border-radius:50%;border:2px solid var(--cta)}

/* === TESTIMONIALS === */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:32px}
.testimonial{background:var(--white);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm);border-left:4px solid var(--cta)}
.testimonial blockquote{font-style:italic;color:var(--text-light);margin-bottom:14px;font-size:.95rem;line-height:1.7}
.testimonial cite{font-style:normal;font-weight:600;font-size:.9rem;color:var(--text)}

/* === STEPS === */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:28px;margin-top:32px;counter-reset:step}
.step{background:var(--white);border-radius:var(--radius-lg);padding:32px 24px;box-shadow:var(--shadow-sm);position:relative;counter-increment:step}
.step::before{content:counter(step);position:absolute;top:-14px;left:24px;width:36px;height:36px;background:var(--cta);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}
.step h3{margin-top:8px}

/* === FAQ === */
.faq-list{max-width:780px;margin-top:24px}
.faq-item{background:var(--white);border-radius:var(--radius);margin-bottom:16px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid rgba(248,215,230,.3)}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;font-weight:600;font-size:1rem;background:none;border:none;width:100%;text-align:left;font-family:'Poppins',sans-serif;color:var(--text);transition:background .2s}
.faq-question:hover{background:rgba(248,215,230,.15)}
.faq-question .icon{font-size:1.25rem;color:var(--cta);transition:transform .3s;flex-shrink:0;margin-left:16px}
.faq-item.active .faq-question .icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}
.faq-item.active .faq-answer{max-height:300px;padding:0 24px 20px}
.faq-answer p{color:var(--text-light);font-size:.95rem}

/* === CTA BANNER === */
.cta-banner{text-align:center;padding:64px 24px;background:linear-gradient(135deg,var(--soft),var(--secondary));border-radius:var(--radius-lg);margin:40px 0}
.cta-banner h2{margin-bottom:12px}
.cta-banner p{margin:0 auto 28px}

/* === CITY LINKS === */
.city-links{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px}
.city-link{display:inline-block;padding:10px 22px;background:var(--white);border:2px solid var(--soft);border-radius:50px;font-weight:500;font-size:.95rem;color:var(--text);transition:all .3s}
.city-link:hover{background:var(--cta);color:var(--white);border-color:var(--cta)}

/* === BLOG === */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;margin-top:32px}
.blog-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;border:1px solid rgba(248,215,230,.3)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-card-img{height:200px;background-size:cover;background-position:center;background-color:var(--soft)}
.blog-card-body{padding:28px 24px}
.blog-card-body h3{font-size:1.15rem;margin-bottom:10px}
.blog-card-body h3 a{color:var(--text)}
.blog-card-body h3 a:hover{color:var(--cta)}
.blog-card-body p{font-size:.92rem;color:var(--text-light);margin-bottom:16px}
.read-more{font-weight:600;font-size:.9rem;color:var(--cta)}

/* === ARTICLE === */
.article-content{max-width:780px;margin:0 auto;padding:48px 24px 72px}
.article-content h2{margin-top:48px;margin-bottom:16px}
.article-content h3{margin-top:32px}
.article-content p{max-width:100%}

/* === LEGAL === */
.legal-content{max-width:780px;margin:0 auto;padding:48px 24px 72px}
.legal-content h1{font-size:2rem;margin-bottom:32px}
.legal-content h2{font-size:1.4rem;margin-top:40px;margin-bottom:16px}
.legal-content p{color:var(--text-light);margin-bottom:16px;max-width:100%}
.legal-content ul{list-style:none;padding:0;margin-bottom:20px}
.legal-content ul li{position:relative;padding-left:24px;margin-bottom:10px;color:var(--text-light)}
.legal-content ul li::before{content:'';position:absolute;left:0;top:10px;width:8px;height:8px;background:var(--soft);border-radius:50%;border:2px solid var(--cta)}

/* === BACK LINK === */
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;font-weight:500;color:var(--cta);margin-bottom:24px}
.back-link:hover{color:var(--cta-hover)}

/* === FOOTER === */
.site-footer{background:var(--white);border-top:1px solid rgba(248,215,230,.5);padding:56px 0 32px;margin-top:40px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;max-width:var(--max-w);margin:0 auto;padding:0 24px}
.footer-about p{font-size:.9rem;color:var(--text-light);line-height:1.7;max-width:360px}
.footer-links h4,.footer-social h4{font-size:.95rem;font-weight:600;margin-bottom:16px;color:var(--text)}
.footer-links ul{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{color:var(--text-light);font-size:.9rem;transition:color .25s}
.footer-links a:hover{color:var(--cta)}
.social-icons{display:flex;gap:12px}
.social-icon{width:40px;height:40px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--text-light);font-size:1.1rem;transition:background .3s,color .3s}
.social-icon:hover{background:var(--cta);color:var(--white)}
.footer-bottom{text-align:center;padding-top:32px;margin-top:40px;border-top:1px solid rgba(248,215,230,.4);font-size:.85rem;color:var(--text-light);max-width:var(--max-w);margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px}

/* === RESPONSIVE === */
@media(max-width:900px){
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-about{grid-column:1/-1}
}
@media(max-width:768px){
  :root{--hdr:64px}
  .nav-links{display:none;position:absolute;top:var(--hdr);left:0;right:0;background:rgba(253,246,249,.98);backdrop-filter:blur(12px);flex-direction:column;padding:24px;gap:20px;box-shadow:var(--shadow-md)}
  .nav-links.active{display:flex}
  .mobile-toggle{display:flex}
  .hero{min-height:400px}
  .hero h1{font-size:2rem}
  .hero p{font-size:1rem}
  .btn-cta{width:100%;text-align:center;padding:16px 32px}
  .section{padding:48px 0}
  .section h2{font-size:1.55rem}
  .footer-inner{grid-template-columns:1fr;gap:32px}
  .cta-banner{margin:24px 16px;padding:48px 20px}
  .testimonials-grid,.steps{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero h1{font-size:1.6rem}
  .city-links{justify-content:center}
}
