@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&display=swap');

:root {
  --purple-50: #faf5ff;
  --purple-100: #f3e8ff;
  --purple-200: #e9d5ff;
  --purple-300: #d8b4fe;
  --purple-400: #c084fc;
  --purple-500: #a855f7;
  --purple-600: #9333ea;
  --purple-700: #7e22ce;
  --purple-800: #6b21a8;
  --purple-900: #581c87;
  --purple-950: #3b0764;

  --neutral-50: #fafafa;
  --neutral-100: #f5f5f5;
  --neutral-200: #e5e5e5;
  --neutral-300: #d4d4d4;
  --neutral-400: #a3a3a3;
  --neutral-500: #737373;
  --neutral-600: #525252;
  --neutral-700: #404040;
  --neutral-800: #262626;
  --neutral-900: #171717;

  --gold: #d4a853;
  --bg: #fff;
  --text: var(--neutral-800);
  --text-light: var(--neutral-500);
  --border: var(--neutral-200);
  --radius: 12px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.08);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.12);
  --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
}

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

html{scroll-behavior:smooth;font-size:16px}

body{
  font-family:'DM Sans',sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

h1,h2,h3,h4{
  font-family:'Playfair Display',serif;
  line-height:1.25;
  color:var(--neutral-900);
}

a{text-decoration:none;color:inherit;transition:var(--transition)}
img{max-width:100%;display:block}
ul{list-style:none}

.container{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
}

/* ── HEADER ── */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:var(--transition);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.logo{
  font-family:'Playfair Display',serif;
  font-size:1.6rem;font-weight:700;
  color:var(--purple-700);
  letter-spacing:-0.02em;
}
.logo span{color:var(--gold)}

.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{
  font-size:0.9rem;font-weight:500;
  color:var(--neutral-600);
  position:relative;
  padding:4px 0;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:2px;background:var(--purple-600);
  transition:var(--transition);
}
.nav-links a:hover{color:var(--purple-700)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--purple-700);font-weight:600}
.nav-links a.active::after{width:100%}

.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:8px;
}
.hamburger span{
  width:24px;height:2px;background:var(--neutral-800);
  transition:var(--transition);display:block;
}

/* ── HERO ── */
.hero{
  padding:80px 0 60px;
  background:linear-gradient(135deg,var(--purple-50) 0%,#fff 50%,var(--purple-100) 100%);
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-120px;right:-120px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,var(--purple-200) 0%,transparent 70%);
  opacity:.5;
}
.hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  position:relative;z-index:1;
}
.hero-content h1{
  font-size:3rem;margin-bottom:16px;
  background:linear-gradient(135deg,var(--purple-900),var(--purple-600));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-content .subtitle{
  font-size:1.15rem;color:var(--neutral-600);margin-bottom:24px;
  max-width:480px;
}
.hero-price{
  font-size:2rem;font-weight:700;color:var(--purple-700);
  margin-bottom:28px;
}
.hero-price small{font-size:.9rem;color:var(--neutral-500);font-weight:400;margin-left:4px}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;border-radius:50px;
  font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:600;
  cursor:pointer;border:none;transition:var(--transition);
}
.btn-primary{
  background:linear-gradient(135deg,var(--purple-600),var(--purple-700));
  color:#fff;box-shadow:0 4px 20px rgba(147,51,234,.3);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(147,51,234,.4);
}
.btn-outline{
  background:transparent;color:var(--purple-700);
  border:2px solid var(--purple-300);
}
.btn-outline:hover{
  background:var(--purple-50);border-color:var(--purple-500);
}

.hero-image{
  position:relative;display:flex;justify-content:center;
}
.hero-image img{
  width:100%;max-width:420px;border-radius:20px;
  box-shadow:var(--shadow-lg);
}

/* ── SECTIONS ── */
.section{padding:80px 0}
.section-alt{background:var(--neutral-50)}
.section-purple{background:var(--purple-50)}

.section-header{text-align:center;margin-bottom:56px}
.section-header h2{font-size:2.2rem;margin-bottom:12px}
.section-header p{color:var(--neutral-500);font-size:1.05rem;max-width:560px;margin:0 auto}

/* ── GALLERY ── */
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
}
.gallery-grid img{
  width:100%;aspect-ratio:1;object-fit:cover;
  border-radius:var(--radius);
  transition:var(--transition);cursor:pointer;
  border:2px solid var(--border);
}
.gallery-grid img:hover{
  transform:scale(1.03);box-shadow:var(--shadow-md);
  border-color:var(--purple-300);
}

/* ── BENEFITS ── */
.benefits-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;
}
.benefit-card{
  background:#fff;border-radius:var(--radius);padding:32px 28px;
  border:1px solid var(--border);transition:var(--transition);
}
.benefit-card:hover{
  border-color:var(--purple-300);box-shadow:var(--shadow-md);
  transform:translateY(-4px);
}
.benefit-icon{
  width:52px;height:52px;border-radius:14px;
  background:var(--purple-100);color:var(--purple-700);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin-bottom:16px;
}
.benefit-card h3{font-size:1.15rem;margin-bottom:8px;font-family:'DM Sans',sans-serif;font-weight:600}
.benefit-card p{color:var(--neutral-500);font-size:.9rem}

/* ── REVIEWS ── */
.reviews-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;
}
.review-card{
  background:#fff;border-radius:var(--radius);padding:28px;
  border:1px solid var(--border);
}
.review-stars{color:var(--gold);font-size:1rem;margin-bottom:12px;letter-spacing:2px}
.review-text{font-size:.95rem;color:var(--neutral-600);margin-bottom:16px;font-style:italic;line-height:1.7}
.review-author{font-weight:600;font-size:.9rem}
.review-city{color:var(--neutral-400);font-size:.82rem}

/* ── FAQ ── */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;cursor:pointer;font-weight:600;
  font-size:1rem;background:none;border:none;width:100%;
  text-align:left;font-family:'DM Sans',sans-serif;color:var(--neutral-800);
}
.faq-question .icon{
  font-size:1.4rem;color:var(--purple-500);transition:var(--transition);
  flex-shrink:0;margin-left:16px;
}
.faq-answer{
  max-height:0;overflow:hidden;transition:max-height .35s ease;
}
.faq-answer-inner{
  padding:0 0 20px;color:var(--neutral-600);font-size:.95rem;line-height:1.7;
}
.faq-item.open .faq-answer{max-height:300px}
.faq-item.open .icon{transform:rotate(45deg)}

/* ── ORDER FORM ── */
.order-section{
  background:linear-gradient(135deg,var(--purple-700),var(--purple-900));
  color:#fff;padding:80px 0;
}
.order-section h2{color:#fff}
.order-section p{color:var(--purple-200)}
.order-form{
  max-width:520px;margin:0 auto;
  display:flex;flex-direction:column;gap:16px;
}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.85rem;font-weight:500;color:var(--purple-200)}
.form-group input,.form-group textarea,.form-group select{
  padding:14px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.1);color:#fff;
  font-family:'DM Sans',sans-serif;font-size:.95rem;
  transition:var(--transition);
}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.4)}
.form-group input:focus,.form-group textarea:focus{
  outline:none;border-color:var(--purple-300);
  background:rgba(255,255,255,.15);
}
.form-submit{
  margin-top:8px;padding:16px;border-radius:50px;
  background:#fff;color:var(--purple-700);
  font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:700;
  border:none;cursor:pointer;transition:var(--transition);
}
.form-submit:hover{
  transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.2);
}

/* ── CONTACT INFO BAR ── */
.contact-bar{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;
  padding:40px 0;
}
.contact-item{display:flex;align-items:flex-start;gap:14px}
.contact-icon{
  width:44px;height:44px;border-radius:12px;
  background:var(--purple-100);color:var(--purple-700);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:1.1rem;
}
.contact-item h4{font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:600;margin-bottom:2px}
.contact-item p{color:var(--neutral-500);font-size:.85rem}

/* ── FOOTER ── */
.site-footer{
  background:var(--neutral-900);color:var(--neutral-400);
  padding:60px 0 0;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid var(--neutral-700);
}
.footer-brand .logo{font-size:1.4rem;margin-bottom:12px;display:inline-block}
.footer-brand p{font-size:.85rem;line-height:1.7;max-width:300px;color:var(--neutral-400)}
.footer-col h4{
  font-family:'DM Sans',sans-serif;font-size:.85rem;
  font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--neutral-200);margin-bottom:16px;
}
.footer-col a{display:block;font-size:.88rem;color:var(--neutral-400);padding:4px 0}
.footer-col a:hover{color:var(--purple-400)}
.footer-bottom{
  padding:24px 0;display:flex;justify-content:space-between;
  align-items:center;font-size:.8rem;
}

/* ── PAGE HEADER ── */
.page-header{
  background:linear-gradient(135deg,var(--purple-50),var(--purple-100));
  padding:48px 0;text-align:center;
  border-bottom:1px solid var(--border);
}
.page-header h1{font-size:2.4rem;margin-bottom:8px}
.page-header p{color:var(--neutral-500);font-size:1rem}

/* ── CONTENT PAGES ── */
.content-section{padding:60px 0}
.content-narrow{max-width:780px;margin:0 auto}
.content-narrow h2{font-size:1.6rem;margin:36px 0 12px;color:var(--purple-800)}
.content-narrow h3{font-size:1.2rem;margin:28px 0 8px;font-family:'DM Sans',sans-serif;font-weight:600}
.content-narrow p{margin-bottom:16px;color:var(--neutral-600);font-size:.95rem}
.content-narrow ul{margin:12px 0 20px 20px}
.content-narrow ul li{
  margin-bottom:8px;color:var(--neutral-600);font-size:.95rem;
  position:relative;padding-left:20px;
}
.content-narrow ul li::before{
  content:'';position:absolute;left:0;top:10px;
  width:6px;height:6px;border-radius:50%;background:var(--purple-500);
}

/* ── CONTACT FORM (page) ── */
.contact-form{
  max-width:560px;margin:0 auto;
}
.contact-form .form-group input,
.contact-form .form-group textarea{
  background:var(--neutral-50);color:var(--text);
  border:1px solid var(--border);
}
.contact-form .form-group input:focus,
.contact-form .form-group textarea:focus{
  border-color:var(--purple-400);outline:none;
  box-shadow:0 0 0 3px var(--purple-100);
}
.contact-form .form-group label{color:var(--neutral-700)}
.contact-form .form-submit{
  background:linear-gradient(135deg,var(--purple-600),var(--purple-700));
  color:#fff;
}

/* ── PRODUCT SPECS ── */
.specs-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  align-items:start;margin:40px 0;
}
.specs-image img{
  border-radius:var(--radius);border:2px solid var(--border);
}
.specs-list{display:flex;flex-direction:column;gap:16px}
.spec-row{
  display:flex;justify-content:space-between;
  padding:12px 0;border-bottom:1px solid var(--border);
  font-size:.95rem;
}
.spec-row .label{color:var(--neutral-500)}
.spec-row .value{font-weight:600;color:var(--neutral-800)}

/* ── SUCCESS PAGE ── */
.success-wrap{
  min-height:60vh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:60px 24px;
}
.success-box{max-width:520px}
.success-icon{
  width:80px;height:80px;border-radius:50%;
  background:var(--purple-100);color:var(--purple-600);
  display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;margin:0 auto 24px;
}
.success-box h1{font-size:2rem;margin-bottom:12px}
.success-box p{color:var(--neutral-500);font-size:1.05rem;margin-bottom:28px}

/* ── COOKIE BANNER ── */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:var(--neutral-900);color:var(--neutral-200);
  padding:20px 24px;
  display:flex;align-items:center;justify-content:center;gap:24px;
  font-size:.88rem;
  transform:translateY(100%);transition:transform .4s ease;
}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner p{max-width:600px}
.cookie-banner a{color:var(--purple-400);text-decoration:underline}
.cookie-btn{
  padding:10px 24px;border-radius:50px;
  background:var(--purple-600);color:#fff;border:none;
  font-family:'DM Sans',sans-serif;font-weight:600;
  cursor:pointer;white-space:nowrap;font-size:.88rem;
}
.cookie-btn:hover{background:var(--purple-500)}

/* ── MOBILE NAV ── */
.mobile-nav{
  display:none;position:fixed;top:72px;left:0;right:0;
  background:#fff;border-bottom:1px solid var(--border);
  padding:16px 24px;z-index:999;
  flex-direction:column;gap:12px;
  box-shadow:var(--shadow-lg);
}
.mobile-nav.open{display:flex}
.mobile-nav a{
  font-size:1rem;padding:10px 0;font-weight:500;
  color:var(--neutral-700);border-bottom:1px solid var(--neutral-100);
}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:40px;text-align:center}
  .hero-content h1{font-size:2.2rem}
  .hero-content .subtitle{margin:0 auto 24px}
  .hero-image{order:-1}
  .hero-image img{max-width:300px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .specs-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .hamburger{display:flex}
}
@media(max-width:600px){
  .hero{padding:48px 0 40px}
  .section{padding:56px 0}
  .hero-content h1{font-size:1.8rem}
  .hero-price{font-size:1.6rem}
  .section-header h2{font-size:1.7rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .contact-bar{grid-template-columns:1fr}
  .cookie-banner{flex-direction:column;gap:12px;text-align:center}
}
