/* Layout helpers */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 1rem;
}
@media (min-width: 640px){ .container{ padding:0 1.5rem; } }
@media (min-width: 1024px){ .container{ padding:0 2rem; } }

.shadow-sm{ box-shadow:var(--shadow-sm); }
.shadow-lg{ box-shadow:var(--shadow-lg); }

.rounded{ border-radius:var(--radius); }
.rounded-lg{ border-radius:var(--radius-lg); }

.text-center{ text-align:center; }
.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;
}

/* Header */
.site-header{
  position:fixed;
  top:0; left:0; right:0;
  background:rgba(255,255,255,.95);
  backdrop-filter: blur(10px);
  z-index:50;
  box-shadow:var(--shadow-sm);
}
.header-row{
  height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.brand{
  font-family:var(--font-serif);
  font-size:1.5rem;
  color:var(--pink-600);
  margin:0;
}
.nav-desktop{
  display:none;
  gap:2rem;
}
.nav-desktop button{
  background:transparent;
  border:0;
  cursor:pointer;
  color:var(--gray-700);
  padding:.25rem .25rem;
  transition: color .2s ease;
}
.nav-desktop button:hover{ color:var(--pink-600); }

.menu-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:12px;
  border:0;
  background:transparent;
  cursor:pointer;
  color:var(--gray-700);
}
.menu-btn:hover{ color:var(--pink-600); background: rgba(219,39,119,.06); }

.nav-mobile{
  display:none;
  padding: .5rem 0 1rem;
}
.nav-mobile.is-open{ display:block; }
.nav-mobile button{
  width:100%;
  text-align:left;
  background:transparent;
  border:0;
  cursor:pointer;
  padding:.75rem 1rem;
  border-radius:12px;
  color:var(--gray-700);
  transition: background .2s ease, color .2s ease;
}
.nav-mobile button:hover{
  background:var(--pink-50);
  color:var(--pink-600);
}

@media (min-width: 768px){
  .nav-desktop{ display:flex; }
  .menu-btn{ display:none; }
  .nav-mobile{ display:none !important; }
}

/* Spacing so content isn't hidden by fixed header */
main{ padding-top:64px; }

/* Hero */
.hero{
  position:relative;
  height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-bg img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.5);
}
.hero-content{
  position:relative;
  z-index:1;
  text-align:center;
  padding:0 1rem;
  max-width:64rem;
}
.hero h1{
  color:white;
  margin:0 0 1.25rem;
  font-size:2.25rem;
  line-height:1.15;
  font-weight:700;
}
.hero .brand-inline{
  font-family:var(--font-serif);
  color:var(--pink-300);
}
.hero p{
  color:rgba(255,255,255,.9);
  font-size:1.125rem;
  margin:0 0 2rem;
}
.hero .cta{
  background:var(--pink-600);
  border:0;
  color:white;
  padding:.85rem 2rem;
  border-radius:999px;
  cursor:pointer;
  font-size:1.125rem;
  box-shadow:var(--shadow-lg);
  transition: background .2s ease;
}
.hero-features {
  margin: 10px 0 35px 0;
  font-size: 20px;
  color: rgba(255,255,255,0.9);
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  letter-spacing: 0.5px;
}
.hero-features span {
  position: relative;
  padding: 0 10px;
}
.hero-features span:not(:last-child)::after {
  content: "•";
  position: absolute;
  right: -8px;
  color: #ff6aa2; /* rosa elegante */
  font-weight: bold;
}

.hero .cta:hover{ background:var(--pink-700); }
@media (min-width:640px){
  .hero h1{ font-size:3rem; }
  .hero p{ font-size:1.35rem; }
}
@media (min-width:768px){
  .hero h1{ font-size:3.6rem; }
}

/* Section scaffolding */
.section{
  padding:5rem 0;
}
.section-title{
  margin:0 0 .75rem;
  font-size:2.25rem;
  line-height:1.2;
  font-weight:700;
}
.section-subtitle{
  margin:0;
  font-size:1.25rem;
  color:var(--muted);
}

/* Products grid */
.products{ background:white; }
.grid{
  display:grid;
  gap:2rem;
}
@media (min-width:768px){ .grid.cols-2{ grid-template-columns:repeat(2, minmax(0,1fr)); } }
@media (min-width:1024px){ .grid.cols-3{ grid-template-columns:repeat(3, minmax(0,1fr)); } }

.card{
  border-radius:var(--radius);
  overflow:hidden;
  background:white;
  border:1px solid rgba(0,0,0,.06);
  box-shadow: 0 0 0 rgba(0,0,0,0);
  transition: box-shadow .2s ease, transform .2s ease;
}
.card:hover{
  box-shadow: 0 12px 30px rgba(0,0,0,.14);
  transform: translateY(-1px);
}
.card-media{
  height:16rem;
  overflow:hidden;
}
.card-media img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1);
  transition: transform .35s ease;
}
.card:hover .card-media img{ transform:scale(1.05); }

.card-body{
  padding:1.1rem 1.25rem 1.25rem;
}
.card-title{
  margin:0 0 .35rem;
  color:var(--pink-600);
  font-weight:700;
  font-size:1.15rem;
}
.card-desc{
  margin:0;
  color:var(--muted);
  line-height:1.5;
}

/* About */
.about{ background:var(--pink-50); }
.features{
  margin-top:3rem;
  margin-bottom:3rem;
}
.feature{
  text-align:center;
  padding:1.25rem;
}
.icon-pill{
  width:64px; height:64px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--pink-600);
  color:white;
  margin-bottom:1rem;
}
.feature h3{
  margin:.25rem 0 .35rem;
  font-size:1.25rem;
  font-weight:700;
}
.feature p{
  margin:0;
  color:var(--muted);
  line-height:1.55;
}
.about-card{
  background:white;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  padding:2rem;
}
@media (min-width:768px){
  .about-card{ padding:3rem; }
}

/* Contact */
.contact{ background:white; }
.contact-grid{
  display:grid;
  gap:3rem;
}
@media (min-width:768px){
  .contact-grid{ grid-template-columns: 1fr 1fr; }
}
.contact-item{
  display:flex;
  gap:1rem;
  align-items:flex-start;
}
.icon-box{
  width:48px; height:48px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--pink-100);
  color:var(--pink-600);
  flex: 0 0 auto;
}
.contact-item h3{
  margin:0 0 .25rem;
  font-size:1.05rem;
  font-weight:700;
}
.contact-item p{
  margin:0;
  color:var(--muted);
  line-height:1.5;
}

.form-card{
  background:var(--pink-50);
  border-radius:var(--radius);
  padding:2rem;
}
.form-card h3{
  margin:0 0 1.25rem;
  font-size:1.6rem;
  font-weight:800;
}
.field label{
  display:block;
  margin:0 0 .5rem;
  font-size:.95rem;
  color:var(--gray-700);
  font-weight:600;
}
.field input, .field textarea{
  width:100%;
  padding:.65rem .9rem;
  border:1px solid var(--gray-300);
  border-radius:12px;
  outline:none;
  background:white;
}
.field input:focus, .field textarea:focus{
  border-color:rgba(219,39,119,.45);
  box-shadow:0 0 0 3px rgba(219,39,119,.18);
}
.field textarea{ resize:none; }
.form-submit{
  width:100%;
  margin-top:.5rem;
  background:var(--pink-600);
  color:white;
  border:0;
  border-radius:12px;
  padding:.9rem 1rem;
  font-weight:700;
  cursor:pointer;
  transition: background .2s ease;
}
.form-submit:hover{ background:var(--pink-700); }

.social{
  margin-top:2rem;
  padding-top:2rem;
  border-top:1px solid rgba(219,39,119,.25);
}
.social h4{
  margin:0 0 1rem;
  font-size:1.05rem;
  font-weight:800;
}
.social-links{
  display:flex;
  gap:1rem;
}
.social-btn{
  width:40px; height:40px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--pink-600);
  color:white;
  transition: background .2s ease;
}
.social-btn:hover{ background:var(--pink-700); }

/* Footer */
.site-footer{
  background:var(--gray-900);
  color:white;
  padding:2rem 0;
}
.footer-title{
  font-family:var(--font-serif);
  color:var(--pink-300);
  margin:0 0 .75rem;
  font-size:1.5rem;
}
.footer-desc{
  margin:0 0 .75rem;
  color:var(--gray-400);
}
.footer-copy{
  margin:0;
  color:var(--gray-500);
  font-size:.9rem;
}

/* Toast */
.toast-region{
  position:fixed;
  right: 1rem;
  bottom: 1rem;
  display:flex;
  flex-direction:column;
  gap:.75rem;
  z-index:1000;
}
.toast{
  min-width: 260px;
  max-width: 360px;
  background: rgba(17,24,39,.96);
  color: white;
  border-radius: 14px;
  padding: .9rem 1rem;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  display:flex;
  gap:.75rem;
  align-items:flex-start;
}
.toast .toast-title{
  font-weight:800;
  margin:0 0 .15rem;
  font-size: .98rem;
}
.toast .toast-desc{
  margin:0;
  color: rgba(255,255,255,.82);
  line-height:1.35;
  font-size:.92rem;
}
.toast .toast-close{
  margin-left:auto;
  background: transparent;
  border:0;
  color: rgba(255,255,255,.7);
  cursor:pointer;
  padding:.1rem .25rem;
  border-radius:10px;
}
.toast .toast-close:hover{ color:white; background: rgba(255,255,255,.08); }

/* Small utility for hidden elements */
.is-hidden{ display:none !important; }
