*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--cream:#F5F0E8;--sage:#7A8B6F;--sage-light:#A8B89E;--sage-dark:#5A6B4F;--wood:#B8956A;--wood-light:#D4B896;--bark:#6B4D3A;--forest:#3D4F35;--moss:#8B9E6B;--white:#FEFCF7;--charcoal:#2C2C2C;--warm-gray:#8A8478}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--charcoal);overflow-x:hidden}
img{display:block;max-width:100%}a{text-decoration:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 5%;display:flex;justify-content:space-between;align-items:center;transition:all .4s ease}
.nav.scrolled{background:rgba(254,252,247,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:12px 5%;box-shadow:0 2px 20px rgba(0,0,0,.06)}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--cream);letter-spacing:.2em;transition:color .4s ease}
.nav.scrolled .nav-logo{color:var(--charcoal)}
.nav-links{display:flex;gap:30px;list-style:none}
.nav-links a{font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:var(--cream);font-weight:400;transition:all .4s ease;opacity:.85}
.nav.scrolled .nav-links a{color:var(--charcoal)}
.nav-links a:hover{opacity:1;color:var(--sage)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:200;background:none;border:none;padding:5px}
.hamburger span{display:block;width:25px;height:1.5px;background:var(--cream);transition:all .3s ease}
.nav.scrolled .hamburger span{background:var(--charcoal)}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-image:url('../img/studio/artista-trabajando.jpg');background-size:cover;background-position:center;filter:brightness(.35);transform:scale(1.05);animation:heroZoom 20s ease-in-out infinite alternate}
@keyframes heroZoom{0%{transform:scale(1.05)}100%{transform:scale(1.12)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(61,79,53,.3) 0%,rgba(44,44,44,.6) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;padding:2rem;max-width:800px}
.hero-content h1{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,8vw,6rem);font-weight:300;color:var(--cream);letter-spacing:.15em;line-height:1.1;margin-bottom:.5rem;animation:fadeUp 1.2s ease-out}
.hero-content .subtitle{font-size:clamp(.85rem,2vw,1.1rem);color:var(--sage-light);letter-spacing:.35em;text-transform:uppercase;font-weight:300;margin-bottom:2.5rem;animation:fadeUp 1.2s ease-out .3s both}
.hero-cta{display:inline-flex;align-items:center;gap:10px;padding:16px 40px;background:var(--sage);color:var(--cream);font-family:'DM Sans',sans-serif;font-size:.9rem;letter-spacing:.15em;text-transform:uppercase;border:1px solid var(--sage-light);transition:all .4s ease;animation:fadeUp 1.2s ease-out .6s both}
.hero-cta:hover{background:var(--sage-dark);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.hero-cta svg{width:18px;height:18px}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;animation:bounce 2s ease infinite}
.hero-scroll span{display:block;width:1px;height:50px;background:var(--sage-light);opacity:.6}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(10px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* SECTIONS */
section{padding:100px 5%}
.section-label{font-size:.75rem;letter-spacing:.35em;text-transform:uppercase;color:var(--sage);margin-bottom:1rem;font-weight:500}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:300;color:var(--charcoal);line-height:1.2;margin-bottom:1.5rem}

/* === SOBRE NOSOTRAS === */
.about {
  background: var(--white);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
  max-width: 1400px; margin: 0 auto; padding: 100px 5%;
}

.about-text p {
  font-size: 1.05rem; line-height: 1.9;
  color: var(--warm-gray); margin-bottom: 1.2rem; font-weight: 300;
}
.about-text p strong { color: var(--charcoal); font-weight: 500; }

.about-images { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }

.about-images img {
  width: 100%; height: 250px; object-fit: cover; border-radius: 4px;
}
.about-images img:first-child { grid-column: 1 / -1; height: 300px; }

/* STYLES */
.styles-section{background:var(--forest);text-align:center}
.styles-section .section-label{color:var(--sage-light)}
.styles-section .section-title{color:var(--cream)}
.styles-section .section-desc{color:var(--sage-light);font-size:1.05rem;font-weight:300;max-width:600px;margin:0 auto 3rem;line-height:1.8}
.styles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;max-width:1100px;margin:0 auto}
.style-card{padding:30px 16px;border:1px solid rgba(168,184,158,.2);border-radius:4px;transition:all .4s ease;cursor:pointer;position:relative}
.style-card:hover,.style-card.active{background:rgba(168,184,158,.15);border-color:var(--sage);transform:translateY(-4px)}
.style-card.active{border-color:var(--sage-light);box-shadow:0 4px 20px rgba(0,0,0,.2)}
.style-card h3{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:400;color:var(--cream);letter-spacing:.05em}
.style-card .style-hint{display:block;margin-top:8px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage-light);opacity:.5;transition:opacity .3s ease}
.style-card:hover .style-hint{opacity:1}
.style-showcase{max-width:1100px;margin:0 auto;overflow:hidden;max-height:0;opacity:0;transition:max-height .6s cubic-bezier(.4,0,.2,1),opacity .4s ease,margin-top .4s ease;margin-top:0}
.style-showcase.open{max-height:900px;opacity:1;margin-top:30px}
.showcase-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 5px}
.showcase-header h4{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:400;color:var(--cream)}
.showcase-close{background:none;border:1px solid rgba(168,184,158,.3);color:var(--sage-light);width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;font-family:'Cormorant Garamond',serif}
.showcase-close:hover{background:rgba(168,184,158,.15);border-color:var(--sage-light);color:var(--cream)}
.showcase-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.showcase-item{aspect-ratio:3/4;border-radius:4px;overflow:hidden;cursor:pointer;position:relative}
.showcase-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.showcase-item:hover img{transform:scale(1.06)}
.showcase-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(44,44,44,.3) 0%,transparent 40%);opacity:0;transition:opacity .3s ease}
.showcase-item:hover::after{opacity:1}

/* GALLERY */
.gallery-section{background:var(--cream);text-align:center}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:15px;max-width:1200px;margin:2rem auto 0}
.gallery-item{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:3/4;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(44,44,44,.4) 0%,transparent 50%);opacity:0;transition:opacity .4s ease}
.gallery-item:hover::after{opacity:1}

/* PROCESS */
.process-section{background:var(--white);text-align:center}
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px;max-width:1100px;margin:3rem auto 0}
.step{padding:0 15px}
.step-number{font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:300;color:var(--sage-light);opacity:.4;line-height:1;margin-bottom:1rem}
.step h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;margin-bottom:.8rem;color:var(--charcoal)}
.step p{font-size:.95rem;line-height:1.7;color:var(--warm-gray);font-weight:300}

/* VALUES */
.values-section{background:linear-gradient(135deg,var(--sage-dark) 0%,var(--forest) 100%);text-align:center;position:relative;overflow:hidden}
.values-section::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(168,184,158,.08) 0%,transparent 50%)}
.values-section .section-label{color:var(--moss)}
.values-section .section-title{color:var(--cream)}
.values-text{max-width:700px;margin:0 auto;position:relative;z-index:1}
.values-text p{font-size:1.1rem;line-height:2;color:var(--sage-light);font-weight:300;margin-bottom:1.5rem}
.values-text p em{color:var(--cream);font-style:normal;font-weight:400}

/* SHOP */
.shop-section{background:var(--cream);text-align:center}
.shop-section p{font-size:1.05rem;line-height:1.8;color:var(--warm-gray);font-weight:300;max-width:600px;margin:0 auto 2rem}

/* TESTIMONIALS */
.testimonials-section{background:var(--cream);text-align:center;padding:100px 5%}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;max-width:1100px;margin:3rem auto 0}
.testimonial-card{background:var(--white);padding:35px 30px;border-radius:4px;border:1px solid rgba(122,139,111,.1);transition:all .4s ease}
.testimonial-card:hover{border-color:var(--sage-light);transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,.06)}
.testimonial-stars{color:var(--wood);font-size:1.2rem;margin-bottom:1rem;letter-spacing:2px}
.testimonial-text{font-size:1rem;line-height:1.8;color:var(--warm-gray);font-weight:300;margin-bottom:1.2rem;font-style:italic}
.testimonial-author{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--sage-dark);font-weight:500}

/* FAQ */
.faq-section{background:var(--white);text-align:center;padding:100px 5%}
.faq-container{max-width:800px;margin:3rem auto 0;text-align:left}
.faq-item{border-bottom:1px solid rgba(122,139,111,.15);margin-bottom:0}
.faq-question{width:100%;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;background:none;border:none;cursor:pointer;text-align:left;transition:all .3s ease}
.faq-question span{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--charcoal);line-height:1.4}
.faq-question:hover span{color:var(--sage-dark)}
.faq-icon{min-width:24px;width:24px;height:24px;color:var(--sage);transition:transform .3s ease}
.faq-question[aria-expanded="true"] .faq-icon{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-answer p{font-size:1rem;line-height:1.8;color:var(--warm-gray);font-weight:300;margin:0}
.faq-answer a{color:var(--sage-dark);text-decoration:none;border-bottom:1px solid var(--sage-light)}
.faq-answer a:hover{color:var(--sage);border-color:var(--sage)}
.faq-item.active .faq-answer{max-height:500px;padding-bottom:24px}

/* CTA */
.cta-section{background:var(--charcoal);text-align:center;padding:80px 5%}
.cta-section .section-title{color:var(--cream);margin-bottom:1rem}
.cta-section p{color:var(--warm-gray);font-size:1.05rem;font-weight:300;margin-bottom:2.5rem;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.8}
.cta-button{display:inline-flex;align-items:center;gap:12px;padding:18px 50px;background:var(--sage);color:var(--cream);font-family:'DM Sans',sans-serif;font-size:.95rem;letter-spacing:.15em;text-transform:uppercase;border:none;transition:all .4s ease;cursor:pointer}
.cta-button:hover{background:var(--sage-dark);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.cta-button svg{width:20px;height:20px;fill:currentColor}

/* FOOTER */
footer{background:#1a1a1a;padding:40px 5%;text-align:center}
footer p{color:var(--warm-gray);font-size:.8rem;letter-spacing:.1em}
footer a{color:var(--sage-light);text-decoration:none}
footer a:hover{color:var(--cream)}

/* LIGHTBOX */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:1000;align-items:center;justify-content:center;cursor:pointer}
.lightbox.active{display:flex;animation:fadeIn .3s ease}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px}
.lightbox-close{position:absolute;top:20px;right:30px;font-size:2rem;color:var(--cream);cursor:pointer;font-weight:300;font-family:'Cormorant Garamond',serif;background:none;border:none;line-height:1}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:900px){
.about{grid-template-columns:1fr;gap:40px}
.hamburger{display:flex}
.nav-links{display:none;position:fixed;inset:0;background:var(--forest);flex-direction:column;align-items:center;justify-content:center;gap:30px;z-index:150}
.nav-links.open{display:flex}
.nav-links.open a{color:var(--cream)!important;font-size:1.1rem}
.nav:has(.nav-links.open){background:var(--forest)!important;inset:0;position:fixed}
.gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}
.process-steps{grid-template-columns:1fr;gap:30px}
.styles-grid{grid-template-columns:repeat(2,1fr)}
.showcase-grid{grid-template-columns:repeat(2,1fr);gap:10px}
}
@media(max-width:500px){
.gallery-grid{grid-template-columns:1fr 1fr}
.styles-grid{grid-template-columns:1fr 1fr}
.showcase-grid{grid-template-columns:1fr 1fr}
section{padding:70px 5%}
.hero-content h1{letter-spacing:.08em}
}
