@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg: hsl(30,10%,8%);
  --fg: hsl(40,20%,88%);
  --card: hsl(30,8%,12%);
  --primary: hsl(0,72%,50%);
  --primary-fg: hsl(30,10%,8%);
  --muted: hsl(30,10%,50%);
  --border: hsl(30,8%,18%);
  --font-display: 'Cormorant Garamond', serif;
  --font-body: 'DM Sans', sans-serif;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--font-body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.container{max-width:80rem;margin:0 auto;padding:0 1.5rem}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:hsla(30,10%,8%,.8);backdrop-filter:blur(12px);border-bottom:1px solid hsla(30,8%,18%,.5)}
.nav-inner{max-width:80rem;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:inline-flex;align-items:center;line-height:0}
.nav-logo img{height:2.9rem;width:auto;object-fit:contain}
.footer .nav-logo img{height:2.25rem}
.nav-links{display:flex;gap:2rem}
.nav-links a{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.nav-links a:hover{color:var(--primary)}
.nav-toggle{display:none;background:none;border:none;color:var(--fg);cursor:pointer}
.mobile-menu{display:none;flex-direction:column;gap:1rem;padding:1.5rem;border-top:1px solid hsla(30,8%,18%,.5);background:hsla(30,10%,8%,.95);backdrop-filter:blur(12px)}
.mobile-menu a{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.mobile-menu a:hover{color:var(--primary)}
.mobile-menu.open{display:flex}

@media(max-width:768px){
  .nav-links{display:none}
  .nav-toggle{display:block}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2rem;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:all .3s;border:none;font-family:var(--font-body)}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-primary:hover{opacity:.9}
.btn-outline{background:transparent;border:1px solid var(--primary);color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:var(--primary-fg)}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding-bottom:6rem}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:hsla(30,10%,8%,.6)}
.hero-content{position:relative;z-index:1;width:100%}
.hero h1{font-size:clamp(2.5rem,7vw,6rem);font-weight:300;line-height:.95;letter-spacing:-.02em}
.hero-sub{margin-top:1.5rem;color:var(--muted);font-size:clamp(1rem,2vw,1.25rem);max-width:28rem;line-height:1.6}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}

/* Sections */
.section{padding:6rem 0}
.section-alt{background:var(--card)}
.label{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--primary)}
.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:300;margin-top:.75rem;line-height:1.1}
.text-muted{color:var(--muted);line-height:1.7;margin-top:1rem;max-width:32rem}
.text-xs{font-size:.75rem}
.link{color:var(--primary);transition:opacity .3s}
.link:hover{text-decoration:underline}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:4rem}
@media(min-width:768px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}}
.gallery-item{position:relative;overflow:hidden;display:block}
.gallery-item img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .5s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-overlay{position:absolute;inset:0;background:transparent;transition:background .3s;display:flex;align-items:flex-end;padding:1rem}
.gallery-item:hover .gallery-overlay{background:hsla(30,10%,8%,.4)}
.gallery-overlay span{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;opacity:0;transform:translateY(.5rem);transition:all .3s}
.gallery-item:hover .gallery-overlay span{opacity:1;transform:translateY(0)}

/* About */
.about-grid{display:grid;gap:4rem;align-items:center}
@media(min-width:768px){.about-grid{grid-template-columns:1fr 1fr}}
.about-stats{display:flex;align-items:center;justify-content:center}
.stats-box{border:1px solid hsla(30,8%,18%,.5);padding:3rem;text-align:center;width:100%;max-width:20rem;aspect-ratio:1}
.stat-number{font-family:var(--font-display);font-size:clamp(3rem,5vw,4.5rem);font-weight:300;color:var(--primary);line-height:1}
.stat-label{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}
.stat-divider{width:3rem;height:1px;background:var(--border);margin:1.5rem auto}

/* Styles */
.styles-grid{display:grid;gap:2rem;margin-top:4rem}
@media(min-width:768px){.styles-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.styles-grid{grid-template-columns:repeat(3,1fr)}}
.style-card{border:1px solid hsla(30,8%,18%,.5);padding:2rem;transition:border-color .3s}
.style-card:hover{border-color:hsla(0,72%,50%,.3)}
.style-card h3{font-size:1.5rem;font-weight:300}
.style-card p{color:var(--muted);font-size:.875rem;margin-top:1rem;line-height:1.6}

/* Contact */
.contact-grid{display:grid;gap:4rem}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.contact-info p{font-size:.875rem}
.contact-form{display:flex;flex-direction:column;gap:1.5rem}
.form-group label{display:block;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.form-group input,.form-group textarea{width:100%;background:transparent;border:none;border-bottom:1px solid hsla(30,8%,18%,.5);padding:.75rem 0;color:var(--fg);font-family:var(--font-body);font-size:1rem;outline:none;transition:border-color .3s;resize:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:hsla(30,10%,50%,.5)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--primary)}
.form-status{min-height:1.25rem;font-size:.8rem;line-height:1.4;color:var(--muted);margin-top:-.25rem}
.form-status.error{color:var(--primary)}
.form-status.success{color:hsl(130,45%,65%)}

/* Footer */
.footer{padding:3rem 0;border-top:1px solid hsla(30,8%,18%,.5)}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:1rem}
@media(min-width:768px){.footer-inner{flex-direction:row;justify-content:space-between}}
.footer-links{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;justify-content:center}
@media(min-width:768px){.footer-links{justify-content:flex-end}}
.footer-link{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.footer-link:hover{color:var(--primary)}

/* Animations */
@keyframes reveal-up{
  from{opacity:0;transform:translateY(20px);filter:blur(4px)}
  to{opacity:1;transform:translateY(0);filter:blur(0)}
}
.reveal{opacity:0;animation:reveal-up .7s cubic-bezier(.16,1,.3,1) forwards}
.reveal-delay-1{animation-delay:.1s}
.reveal-delay-2{animation-delay:.2s}
.reveal-delay-3{animation-delay:.3s}

.scroll-reveal{opacity:0;transform:translateY(20px);filter:blur(4px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1),filter .7s cubic-bezier(.16,1,.3,1)}
.scroll-reveal.visible{opacity:1;transform:translateY(0);filter:blur(0)}
