/* style.css - simple, elegant styles for demo */
:root{
  --primary:#ebd1d1;
  --accent:#300c0c;
  --burgundy:#4f2222;
  --highlight:#ed9a9a;
  --muted:#8b6e6e;
  --card:#fff;
  --glass: rgba(255,255,255,0.7);
  --maxw:1200px;
  font-family: 'Poppins', sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--primary);color:var(--burgundy);min-height:100vh;}
.hidden{display:none}

/* layout */
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.hero{height:420px;background:linear-gradient(180deg,rgba(63,10,10,0.9),rgba(79,34,34,0.9)),url('http://static.photos/beauty/1200x630/42') center/cover no-repeat;display:flex;align-items:center;justify-content:center}
.hero-inner{text-align:center;color:var(--primary)}
.hero-inner h1{font-size:48px;margin:0 0 12px}
.hero-inner p{font-size:18px;margin:0 0 20px;color:var(--primary)}
.btn{display:inline-block;padding:12px 22px;border-radius:28px;text-decoration:none;font-weight:600}
.btn-primary{background:var(--highlight);color:var(--accent);margin-right:12px}
.btn-outline{background:transparent;border:2px solid var(--highlight);color:var(--highlight)}

.section{padding:48px 0}
.deals{padding:40px 0;text-align:center}
.muted{color:var(--muted)}
.offer-slider{
  margin-top:30px;
  border-radius:36px;
  background:linear-gradient(180deg,#fff8f8 0%,#f1d4d4 100%);
  padding:28px 22px 70px;
  position:relative;
  box-shadow:0 30px 80px rgba(79,34,34,0.18);
}
.offer-viewport{
  overflow:hidden;
  border-radius:28px;
  width:100%;
}
.offer-track{
  display:flex;
  align-items:stretch;
  transition:transform .6s ease;
  will-change:transform;
}
.offer-slide{
  flex:0 0 100%;
  background:#fff;
  border-radius:26px;
  overflow:hidden;
  box-shadow:0 25px 45px rgba(79,34,34,0.12);
  display:flex;
  flex-direction:column;
  margin:0;
  cursor:pointer;
  color:inherit;
  text-decoration:none;
}
.offer-media{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#f4dada;
  padding:18px;
}
.offer-media img{
  display:block;
  max-width:90%;
  height:auto;
  border-radius:22px;
  box-shadow:0 18px 40px rgba(0,0,0,0.08);
}
.offer-info{
  padding:26px 32px 32px;
  text-align:left;
}
.offer-kicker{
  font-size:0.8rem;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:#a76565;
  margin:0 0 8px;
}
.offer-title{
  margin:0 0 6px;
  font-size:1.7rem;
  color:#3f1b1b;
}
.offer-meta{
  margin:0;
  font-size:1rem;
  color:#6a3d3d;
}
.offer-phone{
  display:inline-flex;
  gap:6px;
  align-items:center;
  margin-top:14px;
  font-weight:600;
  color:#b92f2f;
}
.offer-phone::before{
  content:"☎";
  font-size:0.95rem;
}
.offer-nav{
  position:absolute;
  inset:0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  pointer-events:none;
}
.offer-arrow{
  pointer-events:auto;
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid rgba(79,34,34,0.2);
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(6px);
  font-size:1.3rem;
  color:#512727;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  display:flex;
  align-items:center;
  justify-content:center;
}
.offer-arrow:hover{
  transform:scale(1.08);
  box-shadow:0 12px 26px rgba(79,34,34,0.15);
  background:#fff;
}
.offer-dots{
  position:absolute;
  bottom:26px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
}
.offer-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  border:1px solid rgba(79,34,34,0.25);
  background:rgba(255,255,255,0.7);
  cursor:pointer;
  transition:all .3s ease;
}
.offer-dot.active{
  width:32px;
  background:#4f2222;
  border-color:#4f2222;
}
.offer-slide::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,0.45);
  opacity:0;
  pointer-events:none;
  transition:opacity .4s ease;
}
.offer-slide:hover::after{
  opacity:1;
}
.offer-slide:hover .offer-media img{
  transform:scale(1.01);
}
@media(max-width:640px){
  .offer-slider{padding:18px 12px 60px;}
  .offer-info{padding:20px 20px 26px;}
  .offer-title{font-size:1.4rem;}
}
@media(prefers-reduced-motion:reduce){
  .offer-track,.offer-media,.offer-media img,.offer-arrow,.offer-dot,.offer-slide::after{transition:none !important;}
}

/* cards */
.card{background:var(--card);border-radius:14px;padding:20px;box-shadow:0 6px 20px rgba(0,0,0,0.06)}
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}

/* small components */
.service-list{list-style:none;padding:0;margin:0}
.service-list li{padding:8px 0;border-bottom:1px dashed #f1dede;color:#3f1b1b}
.product-card{display:flex;flex-direction:column;gap:12px}
.product-card img{height:180px;object-fit:cover;border-radius:10px}
.price{font-weight:700;color:var(--burgundy)}

/* footer */
.site-footer{padding:24px 0;text-align:center;color:var(--muted)}

/* nav placeholder for when not using shadow; actual nav lives in component */

/* PWA install banner */
.install-banner{
  position:fixed;
  bottom:20px;
  right:20px;
  background:rgba(255,255,255,0.95);
  border-radius:16px;
  box-shadow:0 18px 45px rgba(0,0,0,0.18);
  padding:18px 22px;
  display:flex;
  gap:16px;
  align-items:center;
  border:1px solid rgba(237,154,154,0.4);
  max-width:320px;
  opacity:0;
  transform:translateY(20px);
  pointer-events:none;
  transition:opacity .35s ease, transform .35s ease;
  z-index:10000;
}
.install-banner.show{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.install-banner__text{
  display:flex;
  flex-direction:column;
  gap:4px;
  color:var(--burgundy);
  font-size:14px;
}
.install-banner__text strong{
  font-size:16px;
}
.install-banner__actions{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.install-banner__button{
  border:none;
  border-radius:10px;
  padding:8px 12px;
  font-weight:600;
  cursor:pointer;
}
.install-banner__button.primary{
  background:var(--highlight);
  color:var(--accent);
}
.install-banner__button.secondary{
  background:transparent;
  border:1px solid rgba(79,34,34,0.2);
  color:var(--burgundy);
}
@media(max-width:600px){
  .install-banner{
    left:20px;
    right:20px;
  }
  .install-banner__actions{
    flex-direction:row;
  }
  .install-banner__button{
    flex:1;
  }
}
