:root {
  --primary:#E91E63;
  --secondary:#00BCD4;
  --accent:#FF6B6B;
  --pink:#E91E63;
  --teal:#00BCD4;
  --cream:#FFF9F5;
  --warm-white:#FEFEFE;
  --soft-gray:#F8F9FA;
  --brown:#2C3E50;
  --text-dark:#1A1A1A;
  --text-medium:#4A4A4A;
  --text-light:#6B6B6B;
  --success:#27AE60;
  --warning:#F39C12;
  --font-heading:'Great Vibes', cursive;
  --font-body:'Poppins', sans-serif;
  --shadow-soft:0 4px 20px rgba(0,0,0,0.08);
  --shadow-medium:0 8px 30px rgba(0,0,0,0.12);
  --border-radius:12px;
  --transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

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

body{
  font-family:var(--font-body);
  background:
    radial-gradient(circle at 20% 80%, rgba(233, 30, 99, 0.03) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(0, 188, 212, 0.03) 0%, transparent 50%),
    linear-gradient(135deg, var(--warm-white) 0%, var(--cream) 100%);
  color:var(--text-dark);
  line-height:1.7;
  font-weight:400;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
header{
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(10px);
  position:sticky;
  top:0;
  z-index:1000;
  box-shadow:var(--shadow-soft);
  border-bottom:1px solid rgba(233,30,99,0.1);
}
.container{max-width:1200px;margin:auto;padding:0 1.5rem;}
.header-container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:1.2rem 0;
  gap:2rem;
}
.logo{
  font-family:var(--font-heading);
  font-size:2.2rem;
  color:var(--primary);
  text-decoration:none;
  font-weight:400;
  transition:var(--transition);
}
.logo:hover{color:var(--accent);transform:scale(1.05);}
nav ul{display:flex;list-style:none;gap:2.5rem;}
nav a{
  text-decoration:none;
  color:var(--text-dark);
  font-weight:500;
  position:relative;
  padding:0.5rem 0;
  transition:var(--transition);
  font-size:1.1rem;
}
nav a::after{
  content:"";
  position:absolute;
  bottom:0;
  left:50%;
  width:0;
  height:2px;
  background:linear-gradient(90deg,var(--primary),var(--secondary));
  transition:var(--transition);
  transform:translateX(-50%);
  border-radius:2px;
}
nav a:hover{color:var(--primary);}
nav a:hover::after,nav a.active::after{width:100%}
.open-status{
  margin-left:auto;
  font-weight:600;
  color:var(--success);
  opacity:0;
  transition:var(--transition);
  padding:0.5rem 1rem;
  background:rgba(39,174,96,0.1);
  border-radius:20px;
  font-size:0.9rem;
}
.open-status.visible{opacity:1}
.hero{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:75vh;
  text-align:center;
  color:#fff;
  position:relative;
  background-attachment:fixed;
  overflow:hidden;
  background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
}
.hero video{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:-1;
  opacity:0.8;
}
.hero::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:linear-gradient(135deg, rgba(233,30,99,0.7) 0%, rgba(0,188,212,0.6) 100%);
  z-index:0;
}
.hero-content{
  position:relative;
  z-index:1;
  max-width:800px;
  padding:2rem;
}
.hero h1{
  font-family:var(--font-heading);
  font-size:clamp(2.5rem, 5vw, 4rem);
  margin-bottom:1rem;
  text-shadow:2px 2px 4px rgba(0,0,0,0.3);
  line-height:1.2;
}
.hero p{
  font-size:clamp(1.1rem, 2vw, 1.3rem);
  margin-bottom:2rem;
  opacity:0.95;
  font-weight:300;
}
.hero-buttons{
  display:flex;
  gap:1rem;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:2rem;
}
.btn{
  display:inline-block;
  padding:1rem 2.5rem;
  border-radius:50px;
  font-weight:600;
  text-decoration:none;
  transition:var(--transition);
  font-size:1rem;
  border:none;
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.btn::before{
  content:'';
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition:var(--transition);
}
.btn:hover::before{left:100%;}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-medium);}
/* Button Variants */
.btn.primary{
  background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  color:#fff;
  box-shadow:var(--shadow-soft);
}
.btn.secondary{
  background:rgba(255,255,255,0.2);
  color:#fff;
  border:2px solid rgba(255,255,255,0.3);
  backdrop-filter:blur(10px);
}
.btn.secondary:hover{
  background:rgba(255,255,255,0.3);
  border-color:rgba(255,255,255,0.5);
}

section{
  padding:5rem 0;
  position:relative;
}
section:nth-child(even){
  background:rgba(248,249,250,0.5);
}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:2rem;
}
.product-card{
  background:var(--warm-white);
  border-radius:var(--border-radius);
  box-shadow:var(--shadow-soft);
  overflow:hidden;
  transition:var(--transition);
  border:1px solid rgba(233,30,99,0.1);
  position:relative;
}
.product-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg, var(--primary), var(--secondary));
  transform:scaleX(0);
  transition:var(--transition);
}
.product-card:hover::before{transform:scaleX(1);}
.product-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-medium);
}
.product-card img{
  width:100%;
  height:220px;
  object-fit:cover;
  transition:var(--transition);
}
.product-card:hover img{transform:scale(1.05);}
.product-card h3{
  text-align:center;
  padding:1.5rem 1rem;
  font-family:var(--font-heading);
  font-size:1.8rem;
  color:var(--brown);
  font-weight:400;
}
.social{display:flex;gap:.5rem;margin-top:1rem}
.social a{color:#fff;font-size:1.4rem}
.gallery-grid img{cursor:pointer;border-radius:10px;}
.lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:2000;}
.lightbox img{max-width:90%;max-height:80%;border-radius:10px;}
.lightbox .close{position:absolute;top:20px;right:30px;font-size:2rem;color:#fff;cursor:pointer;}

/* Testimonials */
.testimonials{
  background:linear-gradient(135deg, var(--cream) 0%, rgba(255,249,245,0.8) 100%);
  position:relative;
}
.testimonials::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:url('../assets/bg-sprinkles.svg') repeat;
  opacity:0.05;
  pointer-events:none;
}
.testimonial{
  background:var(--warm-white);
  border-radius:var(--border-radius);
  box-shadow:var(--shadow-soft);
  padding:2rem;
  margin-bottom:2rem;
  position:relative;
  border-left:4px solid var(--primary);
  transition:var(--transition);
}
.testimonial:hover{
  transform:translateX(5px);
  box-shadow:var(--shadow-medium);
}
.testimonial p{
  margin-bottom:1rem;
  font-style:italic;
  color:var(--text-medium);
  font-size:1.1rem;
  line-height:1.6;
}
.testimonial .author{
  font-weight:600;
  text-align:right;
  color:var(--primary);
  font-size:0.95rem;
}

/* Subscribe & Forms */
.subscribe{
  background:linear-gradient(135deg, var(--secondary) 0%, var(--primary) 100%);
  color:#fff;
  text-align:center;
  padding:3rem 2rem;
  margin:3rem 0;
  border-radius:var(--border-radius);
  position:relative;
  overflow:hidden;
}
.subscribe::before{
  content:'';
  position:absolute;
  top:-50%;
  left:-50%;
  width:200%;
  height:200%;
  background:radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%);
  animation:float 6s ease-in-out infinite;
}
@keyframes float{
  0%, 100%{transform:translateY(0px);}
  50%{transform:translateY(-20px);}
}
.subscribe input[type=email]{
  padding:1rem 1.5rem;
  border:none;
  border-radius:50px;
  margin-right:1rem;
  max-width:300px;
  font-size:1rem;
  box-shadow:var(--shadow-soft);
  transition:var(--transition);
}
.subscribe input[type=email]:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(255,255,255,0.3);
}
.subscribe button{
  padding:1rem 2rem;
  border:none;
  border-radius:50px;
  background:rgba(255,255,255,0.2);
  color:#fff;
  cursor:pointer;
  font-weight:600;
  transition:var(--transition);
  backdrop-filter:blur(10px);
  border:2px solid rgba(255,255,255,0.3);
}
.subscribe button:hover{
  background:rgba(255,255,255,0.3);
  transform:translateY(-2px);
}

/* order table */
.order-table{width:100%;border-collapse:collapse;margin-top:1rem}
.order-table th,.order-table td{border:1px solid #ddd;padding:.5rem;text-align:left}
.order-table th{background:var(--cream)}

/* why choose us */
.why-list{list-style:disc;padding-left:1.2rem;margin:1rem 0;line-height:1.6}
.why-list li{margin-bottom:.5rem}

/* events */
.events p{text-align:center;max-width:700px;margin:0 auto;font-weight:500}

/* hero buttons */
.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}
.btn.primary{background:var(--pink);color:#fff}
.btn.secondary{background:transparent;color:#fff;border:2px solid #fff}
.btn.secondary:hover{background:#fff;color:var(--brown)}

/* process steps */
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}
.step{text-align:center;padding:1.5rem}
.step-number{width:60px;height:60px;border-radius:50%;background:var(--pink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:bold;margin:0 auto 1rem}
.step h3{font-family:var(--font-heading);font-size:1.5rem;margin-bottom:.5rem;color:var(--brown)}

/* services list */
.services-list{list-style:none;padding:0;margin:2rem 0}
.services-list li{padding:.8rem 0;border-bottom:1px solid #eee;font-size:1.1rem}
.services-list li:last-child{border-bottom:none}

/* product configurators */
.product-configurator{background:#fff;border-radius:15px;box-shadow:0 4px 20px rgba(0,0,0,0.1);margin:2rem 0;padding:2rem;border:1px solid #f0f0f0}
.product-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}
.product-header img{width:120px;height:120px;object-fit:cover;border-radius:10px;flex-shrink:0}
.product-info h3{font-family:var(--font-heading);font-size:2rem;color:var(--brown);margin-bottom:.5rem}
.product-info p{color:#666;font-size:1.1rem}

.configurator-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}
.option-group{display:flex;flex-direction:column}
.option-group label{font-weight:600;color:var(--brown);margin-bottom:.5rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}
.config-select{padding:.8rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:#fff;transition:.3s}
.config-select:focus{border-color:var(--pink);outline:none;box-shadow:0 0 0 3px rgba(209,77,114,0.1)}

.generate-sku-btn{background:var(--teal);color:#fff;border:none;padding:1rem 2rem;border-radius:25px;font-weight:600;cursor:pointer;transition:.3s;margin-top:1rem;width:100%}
.generate-sku-btn:hover{background:var(--pink);transform:translateY(-2px)}

.sku-display{
  margin-top:1rem;
  padding:1.5rem;
  background:linear-gradient(135deg, var(--cream) 0%, rgba(255,249,245,0.8) 100%);
  border-radius:12px;
  border-left:4px solid var(--pink);
  display:none;
  box-shadow:var(--shadow-soft);
  transition:var(--transition);
}
.sku-display.show{
  display:block;
  animation:slideIn 0.3s ease-out;
}
@keyframes slideIn{
  from{opacity:0;transform:translateY(-10px);}
  to{opacity:1;transform:translateY(0);}
}
.sku-display strong{
  color:var(--brown);
  font-family:monospace;
  font-size:1.1rem;
  display:block;
  margin-bottom:0.5rem;
}

/* additional products */
.additional-products{margin-top:4rem;padding-top:2rem;border-top:2px solid #f0f0f0}
.simple-product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}
.simple-product{background:#fff;padding:1.5rem;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,0.1);border-left:4px solid var(--teal)}
.simple-product h4{font-family:var(--font-heading);font-size:1.3rem;color:var(--brown);margin-bottom:.5rem}
.simple-product p{font-weight:600;color:var(--pink);margin-bottom:.5rem}
.simple-product small{color:#666;font-style:italic}

/* quote summary */
.quote-summary{background:linear-gradient(135deg,var(--pink),var(--teal));color:#fff;padding:2rem;border-radius:15px;margin-top:3rem}
.quote-summary h3{font-family:var(--font-heading);font-size:2rem;margin-bottom:1rem;text-align:center}
.quote-item{background:rgba(255,255,255,0.1);padding:1rem;border-radius:8px;margin-bottom:1rem;backdrop-filter:blur(10px)}
.quote-item strong{display:block;margin-bottom:.5rem}
.quote-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}
.quote-actions .btn{min-width:200px}

/* scroll to top */
#scrollTop{position:fixed;bottom:20px;right:20px;width:40px;height:40px;display:none;align-items:center;justify-content:center;background:var(--pink);color:#fff;border-radius:50%;cursor:pointer;z-index:1500;transition:all 0.3s ease;}
#scrollTop:hover{background:var(--teal);transform:translateY(-2px);}

/* Performance optimizations */
*{will-change:auto;}
.hero video{transform:translateZ(0);}
.product-card{transform:translateZ(0);}

/* Accessibility improvements */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;}
  .hero video{animation:none;}
}

/* Print styles */
@media print {
  .hero video,.social,.subscribe,#scrollTop{display:none !important;}
  body{background:white !important;color:black !important;}
  .container{max-width:100% !important;}
}

/* New Homepage Sections */
.featured-products{padding:4rem 0;background:#fff;}
.featured-products h2{font-family:var(--font-heading);font-size:2.5rem;text-align:center;margin-bottom:3rem;color:var(--brown);}
.products-showcase{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;}
.product-feature{background:#fff;border-radius:15px;box-shadow:0 5px 20px rgba(0,0,0,0.1);overflow:hidden;transition:transform 0.3s ease;}
.product-feature:hover{transform:translateY(-5px);}
.product-feature img{width:100%;height:250px;object-fit:cover;}
.product-info{padding:1.5rem;}
.product-info h3{font-family:var(--font-heading);font-size:1.8rem;color:var(--brown);margin-bottom:0.5rem;}
.product-info p{color:#666;line-height:1.6;margin-bottom:1rem;}
.product-info .price{font-weight:600;color:var(--pink);font-size:1.1rem;}

.about-intro{padding:4rem 0;background:var(--cream);}
.about-content{display:grid;grid-template-columns:2fr 1fr;gap:3rem;align-items:center;}
.about-text h2{font-family:var(--font-heading);font-size:2.5rem;color:var(--brown);margin-bottom:1rem;}
.about-text p{color:#666;line-height:1.7;margin-bottom:1rem;}
.about-image img{width:100%;border-radius:15px;box-shadow:0 5px 20px rgba(0,0,0,0.1);}

.how-it-works{padding:4rem 0;background:#fff;}
.how-it-works h2{font-family:var(--font-heading);font-size:2.5rem;text-align:center;margin-bottom:3rem;color:var(--brown);}
.process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;}
.process-step{text-align:center;padding:2rem;}
.step-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--pink),var(--teal));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:#fff;font-size:2rem;}
.process-step h3{font-family:var(--font-heading);font-size:1.5rem;color:var(--brown);margin-bottom:1rem;}
.process-step p{color:#666;line-height:1.6;}

.why-choose-us{padding:4rem 0;background:var(--cream);}
.why-choose-us h2{font-family:var(--font-heading);font-size:2.5rem;text-align:center;margin-bottom:3rem;color:var(--brown);}
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;}
.benefit{text-align:center;padding:2rem;background:#fff;border-radius:15px;box-shadow:0 5px 20px rgba(0,0,0,0.1);}
.benefit i{font-size:3rem;color:var(--pink);margin-bottom:1rem;}
.benefit h3{font-family:var(--font-heading);font-size:1.3rem;color:var(--brown);margin-bottom:1rem;}
.benefit p{color:#666;line-height:1.6;}

.testimonials-preview{padding:4rem 0;background:#fff;}
.testimonials-preview h2{font-family:var(--font-heading);font-size:2.5rem;text-align:center;margin-bottom:3rem;color:var(--brown);}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem;}
.testimonial-card{background:#fff;border-radius:15px;box-shadow:0 5px 20px rgba(0,0,0,0.1);padding:2rem;text-align:center;}
.testimonial-card .stars{color:#ffd700;font-size:1.2rem;margin-bottom:1rem;}
.testimonial-card p{color:#666;font-style:italic;line-height:1.6;margin-bottom:1rem;}
.testimonial-card .author{font-weight:600;color:var(--brown);}
.testimonials-cta{text-align:center;}

/* Responsive Design for New Sections */
@media (max-width: 768px) {
  .about-content{grid-template-columns:1fr;text-align:center;}
  .products-showcase{grid-template-columns:1fr;}
  .process-grid{grid-template-columns:1fr;}
  .benefits-grid{grid-template-columns:1fr;}
  .testimonials-grid{grid-template-columns:1fr;}
  .featured-products h2,.about-text h2,.how-it-works h2,.why-choose-us h2,.testimonials-preview h2{font-size:2rem;}
}

/* wave divider */
.section-divider{display:block;height:80px;background:url('../assets/wave.svg') center/cover no-repeat;}

footer{
  background:linear-gradient(135deg, var(--text-dark) 0%, #1a252f 100%);
  color:#fff;
  padding:5rem 0 2rem;
  margin-top:3rem;
  position:relative;
}
.footer-wave{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:80px;
  background:url('../assets/wave.svg') top/cover no-repeat;
  transform:translateY(-100%);
  opacity:0.8;
}
.footer .wrapper{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:3rem;
}
.footer h4{
  margin-bottom:1rem;
  font-family:var(--font-heading);
  font-size:1.8rem;
  color:var(--accent);
  font-weight:400;
}
.footer a{
  color:rgba(255,255,255,0.8);
  text-decoration:none;
  transition:var(--transition);
}
.footer a:hover{
  color:var(--accent);
  transform:translateX(5px);
}
.footer small{
  display:block;
  text-align:center;
  margin-top:3rem;
  opacity:0;
  transition:var(--transition);
  color:rgba(255,255,255,0.6);
  font-size:0.9rem;
}
.footer.visible small{opacity:1;}
.social{
  display:flex;
  gap:1rem;
  margin-top:1.5rem;
}
.social a{
  display:flex;
  align-items:center;
  justify-content:center;
  width:45px;
  height:45px;
  background:rgba(255,255,255,0.1);
  border-radius:50%;
  color:#fff;
  font-size:1.2rem;
  transition:var(--transition);
  backdrop-filter:blur(10px);
}
.social a:hover{
  background:var(--primary);
  transform:translateY(-3px) scale(1.1);
  box-shadow:var(--shadow-medium);
}

/* responsive design */
@media (max-width: 768px) {
  .product-header{flex-direction:column;text-align:center}
  .product-header img{width:100px;height:100px}
  .configurator-options{grid-template-columns:1fr}
  .hero-buttons{flex-direction:column;align-items:center}
  .process-steps{grid-template-columns:1fr}
  .simple-product-grid{grid-template-columns:1fr}
  .quote-actions{flex-direction:column}
  .quote-actions .btn{min-width:auto;width:100%}
}

/* contact page styles */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2rem}
.contact-methods{background:#fff;padding:2rem;border-radius:15px;box-shadow:0 4px 20px rgba(0,0,0,0.1)}
.contact-method{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1rem;border-radius:10px;background:var(--cream)}
.method-icon{font-size:2rem;width:60px;text-align:center}
.method-info h3{font-family:var(--font-heading);color:var(--brown);margin-bottom:.5rem}
.method-info p{margin-bottom:.3rem}
.method-info small{color:#666;font-style:italic}

.process-list{padding-left:1.5rem;line-height:1.8}
.process-list li{margin-bottom:.8rem}

.quick-contact-form{background:#fff;padding:2rem;border-radius:15px;box-shadow:0 4px 20px rgba(0,0,0,0.1)}
.contact-form .form-group{margin-bottom:1.5rem}
.contact-form label{display:block;font-weight:600;color:var(--brown);margin-bottom:.5rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:.8rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit;transition:.3s}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--pink);outline:none;box-shadow:0 0 0 3px rgba(209,77,114,0.1)}
.contact-form textarea{resize:vertical;min-height:100px}

.location-info{margin-top:4rem}
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2rem}
.hours-info{background:#fff;padding:2rem;border-radius:15px;box-shadow:0 4px 20px rgba(0,0,0,0.1)}
.hours-info h3{font-family:var(--font-heading);color:var(--brown);margin-bottom:1rem}
.hours{list-style:none;padding:0}
.hours li{padding:.5rem 0;border-bottom:1px solid #eee}
.hours li:last-child{border-bottom:none}

.pickup-notes{margin-top:2rem}
.pickup-notes h4{font-family:var(--font-heading);color:var(--brown);margin-bottom:.8rem}
.pickup-notes ul{padding-left:1.2rem}
.pickup-notes li{margin-bottom:.5rem;line-height:1.6}

.map-container{background:#fff;padding:1rem;border-radius:15px;box-shadow:0 4px 20px rgba(0,0,0,0.1)}

.faq-section{margin-top:4rem;padding-top:2rem;border-top:2px solid #f0f0f0}
.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-top:2rem}
.faq-item{background:#fff;padding:1.5rem;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,0.1);border-left:4px solid var(--teal)}
.faq-item h4{font-family:var(--font-heading);font-size:1.2rem;color:var(--brown);margin-bottom:.8rem}
.faq-item p{line-height:1.6;color:#555}

@media (max-width: 768px) {
  .product-header{flex-direction:column;text-align:center}
  .product-header img{width:100px;height:100px}
  .configurator-options{grid-template-columns:1fr}
  .hero-buttons{flex-direction:column;align-items:center}
  .process-steps{grid-template-columns:1fr}
  .simple-product-grid{grid-template-columns:1fr}
  .quote-actions{flex-direction:column}
  .quote-actions .btn{min-width:auto;width:100%}
  .contact-grid{grid-template-columns:1fr}
  .location-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
}

/* testimonials page styles */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(350px,1fr));
  gap:2rem;
  margin-top:3rem;
}
.testimonial-card{
  background:var(--warm-white);
  border-radius:var(--border-radius);
  box-shadow:var(--shadow-soft);
  padding:2rem;
  border-left:4px solid var(--primary);
  transition:var(--transition);
  position:relative;
}
.testimonial-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-medium);
}
.testimonial-card .stars{
  color:var(--warning);
  margin-bottom:1rem;
  font-size:1.1rem;
}
.testimonial-card p{
  font-style:italic;
  line-height:1.7;
  color:var(--text-medium);
  margin-bottom:1.5rem;
  font-size:1.05rem;
}
.testimonial-card .author{
  border-top:1px solid rgba(233,30,99,0.1);
  padding-top:1rem;
}
.testimonial-card .author strong{
  color:var(--brown);
  display:block;
  margin-bottom:0.3rem;
  font-size:1.1rem;
}
.testimonial-card .author small{
  color:var(--text-light);
  font-style:italic;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:2rem;
  margin-top:2rem;
}
.stat-item{
  text-align:center;
  padding:2rem 1rem;
  background:var(--warm-white);
  border-radius:var(--border-radius);
  box-shadow:var(--shadow-soft);
  transition:var(--transition);
}
.stat-item:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-medium);
}
.stat-number{
  font-size:3rem;
  font-weight:700;
  color:var(--primary);
  font-family:var(--font-heading);
  line-height:1;
  margin-bottom:0.5rem;
}
.stat-label{
  color:var(--text-medium);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.5px;
  font-size:0.9rem;
}

@media (max-width: 480px) {
  .product-configurator{padding:1rem}
  .product-header{gap:1rem}
  .step{padding:1rem}
  .step-number{width:50px;height:50px;font-size:1.2rem}
  .contact-methods,.quick-contact-form,.hours-info,.map-container{padding:1rem}
  .contact-method{flex-direction:column;text-align:center}
  .method-icon{margin-bottom:.5rem}
  .testimonials-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-number{font-size:2.5rem}
}

/* Review links */
.review-link{
  display:inline-block;
  margin-top:1rem;
  padding:0.4rem 1rem;
  background:var(--primary);
  color:#fff;
  text-decoration:none;
  border-radius:20px;
  font-size:0.85rem;
  font-weight:500;
  transition:var(--transition);
  text-align:center;
}
.review-link:hover{
  background:var(--secondary);
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
}
.testimonial-card .review-link{
  margin-top:1.5rem;
  display:block;
  width:fit-content;
  margin-left:auto;
  margin-right:auto;
}
