/* Lashea Creative Studio, Mecha Data LLC */
:root{
  --black:#0a0a0a;
  --black-soft:#161616;
  --gold:#c9a961;
  --gold-bright:#e6c178;
  --white:#ffffff;
  --pink:#f4c2d7;
  --pink-deep:#e89bbd;
  --gray:#8a8a8a;
  --radius:4px;
  --max:1200px;
  --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  background:radial-gradient(circle at 50% 0%,#4d1432 0%,var(--black) 70%);
  background-attachment:fixed;
  color:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:'Playfair Display',Georgia,serif;
  font-weight:700;
  line-height:1.15;
  margin:0 0 .5em;
  letter-spacing:.5px;
}
h1{font-size:clamp(2.4rem,6vw,4.5rem)}
h2{font-size:clamp(1.8rem,4vw,3rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
p{margin:0 0 1rem}
a{color:var(--gold);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--gold-bright)}
img{max-width:100%;display:block;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-alt{background:radial-gradient(circle at 70% 50%,#3a1025 0%,var(--black-soft) 65%)}

/* Buttons */
.btn{
  display:inline-block;
  padding:.95rem 2.2rem;
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:.95rem;
  letter-spacing:1.5px;
  text-transform:uppercase;
  border:2px solid var(--gold);
  background:transparent;
  color:var(--gold);
  cursor:pointer;
  transition:all .3s var(--ease);
  border-radius:0;
}
.btn:hover{background:var(--gold);color:var(--black)}
.btn-primary{background:var(--gold);color:var(--black)}
.btn-primary:hover{background:var(--gold-bright);border-color:var(--gold-bright);color:var(--black)}
.btn-pink{border-color:var(--pink);color:var(--pink)}
.btn-pink:hover{background:var(--pink);color:var(--black)}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(244,194,215,.12);
}
.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-top:1.1rem;
  padding-bottom:1.1rem;
}
.logo{display:flex;align-items:center;gap:.75rem}
.logo img{height:44px;width:auto}
.logo-text{
  font-family:'Playfair Display',serif;
  font-size:1.25rem;
  color:var(--gold);
  letter-spacing:2px;
  text-transform:uppercase;
}
.nav{display:flex;gap:2.2rem;align-items:center}
.nav a{
  color:var(--white);
  font-size:.85rem;
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-weight:500;
  position:relative;
}
.nav a::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:-6px;
  height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transition:transform .3s var(--ease);
}
.nav a:hover,.nav a.active{color:var(--gold)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}
.nav-toggle{
  display:none;
  background:none;
  border:0;
  color:var(--gold);
  font-size:1.6rem;
  cursor:pointer;
}

/* Hero */
.hero{
  position:relative;
  min-height:85vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  background:radial-gradient(circle at 50% 60%,#4d1432 0%,var(--black) 70%);
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:url('../images/gold-dipped-strawberries-cupcakes.jpg');
  background-size:cover;
  background-position:center;
  opacity:.25;
}
.hero::after{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 0%,var(--black) 85%);
}
.hero-content{position:relative;z-index:2;padding:2rem;max-width:900px}
.hero h1{color:var(--white)}
.hero h1 span{color:var(--gold);font-style:italic}
.hero .tagline{
  font-size:clamp(1rem,1.5vw,1.15rem);
  color:var(--pink);
  letter-spacing:4px;
  text-transform:uppercase;
  margin-bottom:1.5rem;
}
.hero .lead{font-size:1.15rem;color:var(--gray);margin:1.5rem auto 2rem;max-width:620px}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Page header (non-home) */
.page-header{
  text-align:center;
  padding:8rem 1.5rem 4rem;
  background:radial-gradient(circle at 50% 80%,#4d1432 0%,var(--black) 65%);
  border-bottom:1px solid rgba(201,169,97,.15);
}
.page-header .crumb{
  color:var(--pink);
  letter-spacing:4px;
  text-transform:uppercase;
  font-size:.8rem;
  margin-bottom:1rem;
}
.page-header p{color:var(--gray);max-width:640px;margin:0 auto}

/* Section heads */
.section-head{text-align:center;margin-bottom:3.5rem}
.section-head .eyebrow{
  display:inline-block;
  color:var(--gold);
  letter-spacing:4px;
  text-transform:uppercase;
  font-size:.8rem;
  margin-bottom:1rem;
}
.section-head h2{color:var(--white)}
.section-head h2 span{color:var(--gold);font-style:italic}
.section-head p{color:var(--gray);max-width:640px;margin:1rem auto 0}

/* Cards */
.grid{display:grid;gap:2rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:radial-gradient(circle at 50% 100%,#3a1025 0%,var(--black-soft) 70%);
  border:1px solid rgba(244,194,215,.15);
  padding:2.5rem 2rem;
  text-align:center;
  transition:all .4s var(--ease);
}
.card:hover{
  border-color:var(--pink);
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(244,194,215,.1);
}
.card-img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  margin-bottom:1.5rem;
  border:1px solid rgba(201,169,97,.2);
}
.card .icon{
  width:60px;height:60px;
  margin:0 auto 1.5rem;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--gold);
  border-radius:50%;
  color:var(--gold);
  font-size:1.6rem;
}
.card h3{color:var(--white)}
.card p{color:var(--gray);font-size:.95rem}

/* Gallery */
.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
}
.gallery-item{
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--black-soft);
  cursor:pointer;
  border:1px solid rgba(201,169,97,.15);
}
.gallery-item img,.gallery-placeholder{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s var(--ease);
}
.gallery-placeholder{
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--black-soft),var(--black));
  color:var(--gold);
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:1.1rem;
  letter-spacing:2px;
}
.gallery-item:hover img,.gallery-item:hover .gallery-placeholder{transform:scale(1.08)}
.gallery-item::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(10,10,10,.85) 100%);
  opacity:0;
  transition:opacity .3s var(--ease);
}
.gallery-item:hover::after{opacity:1}
.gallery-item .label{
  position:absolute;
  bottom:1rem;left:1rem;right:1rem;
  color:var(--gold);
  font-size:.85rem;
  letter-spacing:2px;
  text-transform:uppercase;
  z-index:2;
  opacity:0;
  transform:translateY(10px);
  transition:all .3s var(--ease);
}
.gallery-item:hover .label{opacity:1;transform:translateY(0)}

/* Filters */
.filters{
  display:flex;
  gap:.75rem;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:2.5rem;
}
.filter-btn{
  background:transparent;
  border:1px solid rgba(201,169,97,.3);
  color:var(--white);
  padding:.6rem 1.4rem;
  font-size:.8rem;
  letter-spacing:2px;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .3s var(--ease);
}
.filter-btn:hover,.filter-btn.active{
  background:var(--gold);
  color:var(--black);
  border-color:var(--gold);
}

/* Lightbox */
.lightbox{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.95);
  z-index:200;
  align-items:center;
  justify-content:center;
  padding:2rem;
}
.lightbox.open{display:flex}
.lightbox img,.lightbox .lb-placeholder{
  max-width:90vw;
  max-height:85vh;
  border:2px solid var(--gold);
}
.lightbox .lb-placeholder{
  width:600px;height:600px;
  display:flex;align-items:center;justify-content:center;
  background:var(--black-soft);
  color:var(--gold);
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:1.4rem;
}
.lightbox .close{
  position:absolute;
  top:1.5rem;right:1.5rem;
  background:none;border:0;
  color:var(--gold);
  font-size:2.5rem;
  cursor:pointer;
  line-height:1;
}

/* Testimonials */
.testimonial{
  background:radial-gradient(circle at 0% 100%,#3a1025 0%,var(--black-soft) 70%);
  border-left:3px solid var(--pink);
  padding:2.5rem;
  position:relative;
}
.testimonial::before{
  content:'\201C';
  position:absolute;
  top:-.5rem;left:1.5rem;
  font-family:'Playfair Display',serif;
  font-size:5rem;
  color:var(--gold);
  line-height:1;
}
.testimonial p{
  color:var(--white);
  font-style:italic;
  font-size:1.05rem;
  margin-top:1.5rem;
}
.testimonial .author{
  color:var(--gold);
  font-weight:600;
  font-style:normal;
  letter-spacing:1px;
  text-transform:uppercase;
  font-size:.85rem;
  margin-top:1rem;
}
.stars{color:var(--gold-bright);letter-spacing:3px;font-size:1.1rem}

/* About */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}
.about-image{
  aspect-ratio:4/5;
  background:linear-gradient(135deg,var(--black-soft),var(--pink));
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);
  font-family:'Playfair Display',serif;
  font-style:italic;
  border:1px solid rgba(201,169,97,.3);
}
.about-content h2{color:var(--white)}
.about-content h2 span{color:var(--gold);font-style:italic}
.about-content p{color:var(--gray)}
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:2rem}
.values div strong{color:var(--gold);display:block;margin-bottom:.3rem;letter-spacing:1px;text-transform:uppercase;font-size:.85rem}
.values div span{color:var(--gray);font-size:.9rem}

/* Contact */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:3.5rem;
}
.contact-info h3{color:var(--gold);margin-top:2rem}
.contact-info h3:first-child{margin-top:0}
.contact-info p,.contact-info a{color:var(--gray)}
.contact-info a:hover{color:var(--gold)}
.socials{display:flex;gap:1rem;margin-top:1rem}
.socials a{
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--gold);
  color:var(--gold);
  border-radius:50%;
  font-size:.9rem;
  font-weight:600;
}
.socials a:hover{background:var(--gold);color:var(--black)}
.form{display:grid;gap:1.2rem}
.form label{
  display:block;
  color:var(--gold);
  font-size:.75rem;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:.5rem;
}
.form input,.form select,.form textarea{
  width:100%;
  background:var(--black-soft);
  border:1px solid rgba(201,169,97,.3);
  color:var(--white);
  padding:.95rem 1rem;
  font-family:inherit;
  font-size:1rem;
  border-radius:0;
  transition:border-color .2s var(--ease);
}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:0;
  border-color:var(--gold);
}
.form textarea{min-height:150px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}

/* CTA band */
.cta-band{
  text-align:center;
  padding:5rem 1.5rem;
  background:radial-gradient(circle at 50% 50%,#4d1432 0%,var(--black) 65%);
  border-top:1px solid rgba(244,194,215,.15);
  border-bottom:1px solid rgba(244,194,215,.15);
}
.cta-band h2{color:var(--white)}
.cta-band h2 span{color:var(--pink);font-style:italic}

/* Footer */
.site-footer{
  background:radial-gradient(circle at 50% 0%,#3a1025 0%,var(--black) 60%);
  border-top:1px solid rgba(244,194,215,.15);
  padding:3.5rem 0 1.5rem;
  color:var(--gray);
  font-size:.9rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:2.5rem;
  margin-bottom:2.5rem;
}
.site-footer h4{
  color:var(--gold);
  font-family:'Inter',sans-serif;
  font-size:.85rem;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:1rem;
}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin-bottom:.5rem}
.site-footer ul a{color:var(--gray)}
.site-footer ul a:hover{color:var(--gold)}
.copyright{
  text-align:center;
  padding-top:1.5rem;
  border-top:1px solid rgba(201,169,97,.1);
  font-size:.8rem;
  letter-spacing:1px;
}

/* Responsive */
@media (max-width:900px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media (max-width:768px){
  .section{padding:3.5rem 0}
  .nav-toggle{display:block}
  .nav{
    position:absolute;
    top:100%;left:0;right:0;
    background:var(--black);
    flex-direction:column;
    padding:1.5rem;
    gap:1.2rem;
    border-bottom:1px solid rgba(201,169,97,.2);
    display:none;
  }
  .nav.open{display:flex}
  .hero{min-height:70vh}
  .page-header{padding:5rem 1.5rem 3rem}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
}
@media (max-width:480px){
  .grid-3,.grid-2{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-cta{flex-direction:column;align-items:stretch}
}
