/* ===== KIKI VINTAGE DESIGN SYSTEM ===== */
:root {
  --primary: #C2185B;
  --primary-light: #E91E63;
  --primary-dark: #880E4F;
  --secondary: #F8BBD0;
  --accent: #FF6F00;
  --accent-dark: #E65100;
  --bg: #FFF8F0;
  --surface: #FFFFFF;
  --text: #3E2723;
  --text-muted: #795548;
  --star: #FFB300;
  --radius: 16px;
  --pill: 50px;
  --max-w: 1200px;
  --shadow-sm: 0 2px 8px rgba(62,39,35,.08);
  --shadow-md: 0 4px 16px rgba(62,39,35,.12);
  --shadow-lg: 0 8px 32px rgba(62,39,35,.16);
  --transition: .25s cubic-bezier(.4,0,.2,1);
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Nunito Sans',system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg);line-height:1.7;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--accent)}
h1,h2,h3,h4,h5,h6{font-family:'Fredoka',system-ui,sans-serif;line-height:1.25;color:var(--text)}
h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700}
h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:600}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:600}
p{margin-bottom:1rem}
ul,ol{padding-left:1.5rem}
button{cursor:pointer;font-family:inherit;border:none;background:none}

/* ===== LAYOUT ===== */
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.25rem}
.section{padding:4rem 0}
.section--alt{background:var(--surface)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;font-size:1rem;font-weight:700;border-radius:var(--pill);transition:all var(--transition);text-align:center;line-height:1.3}
.btn--primary{background:var(--accent);color:#fff;box-shadow:0 4px 12px rgba(255,111,0,.3)}
.btn--primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,111,0,.4);color:#fff}
.btn--secondary{background:var(--primary);color:#fff}
.btn--secondary:hover{background:var(--primary-dark);color:#fff}
.btn--outline{border:2px solid var(--primary);color:var(--primary);background:transparent}
.btn--outline:hover{background:var(--primary);color:#fff}
.btn--sm{padding:.625rem 1.25rem;font-size:.875rem}
.btn--lg{padding:1rem 2.5rem;font-size:1.125rem}
.btn--full{width:100%}

/* ===== BADGE ===== */
.badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--pill);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.badge--primary{background:var(--primary);color:#fff}
.badge--gold{background:linear-gradient(135deg,#FFD700,#FFA000);color:#3E2723}
.badge--accent{background:var(--accent);color:#fff}

/* ===== STARS ===== */
.stars{display:inline-flex;gap:2px;color:var(--star);font-size:1rem}
.stars svg{width:1em;height:1em;fill:currentColor}

/* ===== CARDS ===== */
.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}

/* ===== HEADER ===== */
.header{background:var(--surface);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}
.header__inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;gap:1rem}
.header__logo{font-family:'Fredoka',sans-serif;font-size:1.5rem;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:.5rem}
.header__logo:hover{color:var(--primary-dark)}
.header__nav{display:flex;align-items:center;gap:.25rem}
.header__nav a{padding:.5rem .75rem;border-radius:var(--radius);font-weight:500;color:var(--text);font-size:.9rem;transition:all var(--transition)}
.header__nav a:hover{background:var(--secondary);color:var(--primary)}
.header__menu-btn{display:none;padding:.5rem;background:none;border:none;cursor:pointer}
.header__menu-btn span{display:block;width:24px;height:2px;background:var(--text);margin:5px 0;transition:all var(--transition)}

@media(max-width:768px){
  .header__nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--surface);box-shadow:var(--shadow-md);padding:1rem;gap:.25rem}
  .header__nav.active{display:flex}
  .header__nav a{padding:.75rem 1rem;width:100%}
  .header__menu-btn{display:block}
}

/* ===== FOOTER ===== */
.footer{background:var(--text);color:#fff;padding:3rem 0 1.5rem}
.footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer h4{font-family:'Fredoka',sans-serif;color:var(--secondary);margin-bottom:1rem;font-size:1.1rem}
.footer a{color:rgba(255,255,255,.8);transition:color var(--transition)}
.footer a:hover{color:var(--secondary)}
.footer ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.5rem}
.footer__bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:1.5rem;text-align:center;color:rgba(255,255,255,.6);font-size:.85rem}

/* ===== HERO ===== */
.hero{padding:3rem 0 4rem;text-align:center;position:relative;overflow:hidden}
.hero__badge{display:inline-block;background:var(--secondary);color:var(--primary-dark);padding:.5rem 1.25rem;border-radius:var(--pill);font-weight:700;font-size:.9rem;margin-bottom:1.5rem}
.hero h1{margin-bottom:1rem;max-width:800px;margin-left:auto;margin-right:auto}
.hero__subtitle{font-size:1.15rem;color:var(--text-muted);max-width:600px;margin:0 auto 2rem}
.hero__img{max-width:700px;margin:0 auto 2rem;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.hero__ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== URGENCY BAR ===== */
.urgency{background:linear-gradient(90deg,var(--primary),var(--primary-light));color:#fff;text-align:center;padding:.625rem 1rem;font-size:.875rem;font-weight:600}
.urgency__inner{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap}

/* ===== PRODUCT GRID ===== */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}

/* ===== PRODUCT CARD ===== */
.product-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition);display:flex;flex-direction:column}
.product-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.product-card__img-wrap{position:relative;aspect-ratio:1;overflow:hidden;background:#f5f0eb}
.product-card__img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}
.product-card:hover .product-card__img-wrap img{transform:scale(1.05)}
.product-card__badge{position:absolute;top:.75rem;left:.75rem;z-index:2}
.product-card__body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.product-card__name{font-family:'Fredoka',sans-serif;font-size:1.1rem;font-weight:600;margin-bottom:.25rem;color:var(--text)}
.product-card__subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}
.product-card__rating{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.85rem}
.product-card__rating span{color:var(--text-muted)}
.product-card__prices{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1rem}
.product-card__price{font-family:'Fredoka',sans-serif;font-size:1.4rem;font-weight:700;color:var(--primary)}
.product-card__compare{font-size:.9rem;color:var(--text-muted);text-decoration:line-through}
.product-card__cta{margin-top:auto}

/* ===== ZIGZAG / FEATURE BLOCKS ===== */
.zigzag{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;padding:3rem 0}
.zigzag:nth-child(even){direction:rtl}
.zigzag:nth-child(even) > *{direction:ltr}
.zigzag__img{border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden}
.zigzag__img img{width:100%;height:auto;display:block}
.zigzag__content h3{margin-bottom:.75rem}
.zigzag__content p{color:var(--text-muted);margin-bottom:1rem}
.zigzag__stat{background:var(--secondary);border-left:4px solid var(--primary);padding:1rem 1.25rem;border-radius:0 var(--radius) var(--radius) 0;font-size:.9rem;color:var(--text);margin-top:1rem}
.zigzag__stat strong{display:block;margin-bottom:.25rem;color:var(--primary)}
@media(max-width:768px){
  .zigzag{grid-template-columns:1fr;gap:1.5rem}
  .zigzag:nth-child(even){direction:ltr}
}

/* ===== EXPERT QUOTE ===== */
.expert-quote{background:var(--surface);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-sm);border-left:4px solid var(--primary);max-width:800px;margin:2rem auto}
.expert-quote blockquote{font-style:italic;font-size:1.1rem;line-height:1.6;color:var(--text);margin-bottom:1rem}
.expert-quote cite{font-style:normal;font-weight:600;color:var(--primary);display:block}

/* ===== TESTIMONIALS ===== */
.testimonials{padding:3rem 0}
.testimonials__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.testimonial-card{background:var(--surface);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm)}
.testimonial-card__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.testimonial-card__avatar{width:48px;height:48px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;font-family:'Fredoka',sans-serif;font-weight:700;color:var(--primary);font-size:1.2rem}
.testimonial-card__name{font-weight:700}
.testimonial-card__date{font-size:.8rem;color:var(--text-muted)}
.testimonial-card__body{color:var(--text-muted);font-size:.95rem;line-height:1.6}

/* ===== REVIEWS PAGE ===== */
.review-card{background:var(--surface);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:1.25rem}
.review-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}
.review-card__author{font-weight:700}
.review-card__product{font-size:.85rem;color:var(--primary);font-weight:500}
.review-card__verified{font-size:.75rem;color:#2E7D32;font-weight:600}
.review-card__title{font-weight:600;margin-bottom:.5rem}
.review-card__body{color:var(--text-muted);line-height:1.6}

/* ===== BLOG ===== */
.blog-card{display:block;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition)}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);color:var(--text)}
.blog-card__img{aspect-ratio:16/9;overflow:hidden}
.blog-card__img img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}
.blog-card:hover .blog-card__img img{transform:scale(1.05)}
.blog-card__body{padding:1.25rem}
.blog-card__date{font-size:.8rem;color:var(--text-muted)}
.blog-card__title{font-family:'Fredoka',sans-serif;font-size:1.15rem;font-weight:600;margin:.5rem 0;color:var(--text)}
.blog-card__excerpt{font-size:.9rem;color:var(--text-muted);line-height:1.5}

/* ===== BLOG ARTICLE ===== */
.article{max-width:800px;margin:0 auto;padding:2rem 1.25rem 4rem}
.article__header{text-align:center;margin-bottom:2rem}
.article__meta{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}
.article__hero-img{border-radius:var(--radius);margin:0 -1.25rem 2rem;overflow:hidden;box-shadow:var(--shadow-md)}
.article__hero-img img{width:100%;height:auto}
.article__content h2{margin-top:2.5rem;margin-bottom:1rem;padding-top:1.5rem;border-top:1px solid var(--secondary)}
.article__content h3{margin-top:2rem;margin-bottom:.75rem}
.article__content p{margin-bottom:1.25rem;line-height:1.8}
.article__content ul,.article__content ol{margin-bottom:1.25rem}
.article__content li{margin-bottom:.5rem;line-height:1.6}
.article__content blockquote{border-left:4px solid var(--primary);padding:1rem 1.5rem;background:var(--secondary);border-radius:0 var(--radius) var(--radius) 0;margin:1.5rem 0;font-style:italic}

/* ===== PRODUCT PAGE ===== */
.product-page{padding:2rem 0 4rem}
.product-page__grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.product-page__gallery{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}
.product-page__gallery img{width:100%;height:auto}
.product-page__info h1{font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:.5rem}
.product-page__subtitle{font-size:1.1rem;color:var(--text-muted);margin-bottom:1rem}
.product-page__rating{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem}
.product-page__prices{display:flex;align-items:baseline;gap:.75rem;margin-bottom:1.5rem}
.product-page__price{font-family:'Fredoka',sans-serif;font-size:2rem;font-weight:700;color:var(--primary)}
.product-page__compare{font-size:1.1rem;color:var(--text-muted);text-decoration:line-through}
.product-page__save{background:#E8F5E9;color:#2E7D32;padding:.25rem .75rem;border-radius:var(--pill);font-size:.85rem;font-weight:700}
.product-page__details{margin:1.5rem 0}
.product-page__details dt{font-weight:700;color:var(--text);margin-bottom:.25rem}
.product-page__details dd{color:var(--text-muted);margin-bottom:1rem;padding-left:0}
.product-page__reassurance{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.5rem 0;text-align:center}
.product-page__reassurance-item{padding:1rem .5rem;background:var(--secondary);border-radius:var(--radius);font-size:.85rem;font-weight:600;color:var(--primary-dark)}
@media(max-width:768px){
  .product-page__grid{grid-template-columns:1fr}
  .product-page__reassurance{grid-template-columns:1fr}
}

/* ===== CONTACT FORM ===== */
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem 1rem;border:2px solid var(--secondary);border-radius:var(--radius);font-family:inherit;font-size:1rem;color:var(--text);background:var(--surface);transition:border-color var(--transition)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}
.form-group textarea{resize:vertical;min-height:150px}

/* ===== LEGAL ===== */
.legal{max-width:800px;margin:0 auto;padding:2rem 1.25rem 4rem}
.legal h1{margin-bottom:1.5rem}
.legal h2{margin-top:2rem;margin-bottom:.75rem;font-size:1.3rem}
.legal p,.legal li{line-height:1.8;color:var(--text-muted)}

/* ===== DISCLOSURE ===== */
.disclosure{background:var(--secondary);border-radius:var(--radius);padding:1rem 1.25rem;font-size:.85rem;color:var(--text-muted);line-height:1.6;max-width:var(--max-w);margin:0 auto 0;text-align:center}

/* ===== REASSURANCE ===== */
.reassurance{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;padding:2rem 0}
.reassurance__item{text-align:center;padding:1.5rem;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.reassurance__icon{font-size:2rem;margin-bottom:.75rem}
.reassurance__title{font-family:'Fredoka',sans-serif;font-weight:600;margin-bottom:.25rem}
.reassurance__text{font-size:.875rem;color:var(--text-muted)}

/* ===== AGGREGATE RATING SUMMARY ===== */
.rating-summary{background:var(--surface);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-sm);text-align:center;margin-bottom:2rem}
.rating-summary__score{font-family:'Fredoka',sans-serif;font-size:3rem;font-weight:700;color:var(--primary)}
.rating-summary__count{color:var(--text-muted);margin-top:.5rem}

/* ===== SCROLL TOP ===== */
.scroll-top{position:fixed;bottom:1.5rem;right:1.5rem;width:48px;height:48px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all var(--transition);z-index:50;font-size:1.25rem}
.scroll-top.visible{opacity:1;visibility:visible}
.scroll-top:hover{background:var(--primary-dark);transform:translateY(-2px);color:#fff}

/* ===== BREADCRUMB ===== */
.breadcrumb{padding:1rem 0;font-size:.85rem;color:var(--text-muted)}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb span{margin:0 .5rem}

/* ===== UTILS ===== */
.text-center{text-align:center}
.mb-1{margin-bottom:.5rem}
.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:1.5rem}
.mb-4{margin-bottom:2rem}
.mt-2{margin-top:1rem}
.mt-4{margin-top:2rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
