:root{
  --noir:#0a0a0a;
  --noir-soft:#141414;
  --or:#c9a875;
  --or-light:#d9bc8a;
  --or-dark:#a88a5e;
  --blanc:#ffffff;
  --gris:#e8e6e1;
  --gris-soft:#f7f5f1;
  --gris-text:#666;
  --border:rgba(201,168,117,0.25);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--noir);background:var(--blanc);line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:400;letter-spacing:-0.5px;line-height:1.15}
h1{font-size:clamp(2.5rem,6vw,5rem)}
h2{font-size:clamp(2rem,4vw,3.5rem)}
h3{font-size:clamp(1.3rem,2vw,1.8rem)}
a{color:inherit;text-decoration:none;transition:all .3s ease}
img{max-width:100%;display:block}
.container{max-width:1280px;margin:0 auto;padding:0 5%}

/* HEADER */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:24px 5%;display:flex;justify-content:space-between;align-items:center;transition:all .4s ease;background:transparent}
.header.scrolled{background:rgba(10,10,10,0.95);backdrop-filter:blur(12px);padding:16px 5%;box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.logo{font-family:'Playfair Display',serif;font-size:26px;color:var(--blanc);letter-spacing:2px;font-weight:500}
.logo span{color:var(--or)}
.nav{display:flex;gap:40px;align-items:center}
.nav a{color:var(--blanc);font-size:13px;text-transform:uppercase;letter-spacing:2px;font-weight:500;position:relative}
.nav a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--or);transition:width .3s ease}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav a:hover{color:var(--or)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001}
.burger span{width:28px;height:2px;background:var(--blanc);transition:all .3s ease}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

/* HERO */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--blanc);overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,10,10,0.65) 0%,rgba(10,10,10,0.45) 50%,rgba(10,10,10,0.75) 100%);z-index:1}
.hero-bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1534438327276-14e5300c3a48?w=1920&q=80') center/cover no-repeat;z-index:0;animation:slowZoom 20s ease-in-out infinite alternate}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.1)}}
.hero-content{position:relative;z-index:2;max-width:900px;padding:0 5%}
.hero-pretitle{font-size:13px;letter-spacing:6px;text-transform:uppercase;color:var(--or);margin-bottom:28px;opacity:0;animation:fadeUp .9s .3s forwards}
.hero h1{margin-bottom:32px;opacity:0;animation:fadeUp 1s .5s forwards}
.hero h1 em{color:var(--or);font-style:italic;font-weight:400}
.hero-sub{font-size:clamp(15px,1.4vw,18px);max-width:620px;margin:0 auto 48px;opacity:0;animation:fadeUp 1s .7s forwards;color:rgba(255,255,255,0.85);font-weight:300}
.hero-cta{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp 1s .9s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:2;color:var(--blanc);font-size:11px;letter-spacing:3px;text-transform:uppercase;opacity:.7;display:flex;flex-direction:column;align-items:center;gap:12px}
.scroll-indicator::after{content:'';width:1px;height:40px;background:var(--blanc);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* BUTTONS */
.btn{display:inline-block;padding:16px 38px;font-size:12px;text-transform:uppercase;letter-spacing:3px;font-weight:600;cursor:pointer;transition:all .4s ease;border:none}
.btn-primary{background:var(--or);color:var(--noir);position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;inset:0;background:var(--or-light);transform:translateX(-100%);transition:transform .4s ease;z-index:0}
.btn-primary:hover::before{transform:translateX(0)}
.btn-primary span{position:relative;z-index:1}
.btn-outline{background:transparent;color:var(--blanc);border:1px solid var(--blanc)}
.btn-outline:hover{background:var(--blanc);color:var(--noir)}
.btn-dark{background:var(--noir);color:var(--blanc)}
.btn-dark:hover{background:var(--or);color:var(--noir)}

/* SECTIONS */
section{padding:120px 0;position:relative}
.section-pretitle{font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--or);margin-bottom:16px;font-weight:600}
.section-title{margin-bottom:24px}
.section-title em{color:var(--or);font-style:italic}
.section-intro{max-width:640px;color:var(--gris-text);font-size:16px;font-weight:300;margin-bottom:60px}
.section-head{text-align:center;margin-bottom:80px}
.section-head .section-intro{margin-left:auto;margin-right:auto}

/* ABOUT */
.about{background:var(--gris-soft)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img{position:relative;overflow:hidden}
.about-img img{width:100%;height:600px;object-fit:cover;transition:transform .8s ease}
.about-img:hover img{transform:scale(1.05)}
.about-img::after{content:'';position:absolute;inset:20px;border:1px solid var(--or);pointer-events:none;transition:inset .4s ease}
.about-img:hover::after{inset:30px}
.about-text p{color:var(--gris-text);margin-bottom:20px;font-size:16px;font-weight:300}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px;padding-top:40px;border-top:1px solid var(--border)}
.stat-num{font-family:'Playfair Display',serif;font-size:42px;color:var(--or);margin-bottom:4px}
.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--gris-text)}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.service-card{background:var(--blanc);padding:0;overflow:hidden;transition:all .5s ease;border:1px solid var(--border);position:relative;cursor:pointer}
.service-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(0,0,0,0.12)}
.service-img{height:280px;overflow:hidden;position:relative}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.service-card:hover .service-img img{transform:scale(1.08)}
.service-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,0.4),transparent 60%)}
.service-body{padding:36px 32px}
.service-icon{width:48px;height:48px;margin-bottom:20px;color:var(--or)}
.service-card h3{margin-bottom:14px}
.service-card p{color:var(--gris-text);font-size:14px;font-weight:300;margin-bottom:20px}
.service-price{display:flex;align-items:baseline;gap:8px;padding-top:20px;border-top:1px solid var(--border)}
.price-num{font-family:'Playfair Display',serif;font-size:28px;color:var(--or)}
.price-unit{font-size:12px;color:var(--gris-text);letter-spacing:1px}

/* WHY US */
.why{background:var(--noir);color:var(--blanc);position:relative;overflow:hidden}
.why::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(201,168,117,0.15),transparent 70%);pointer-events:none}
.why .section-intro{color:rgba(255,255,255,0.7)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.why-item{text-align:center;padding:30px 20px}
.why-icon{width:56px;height:56px;margin:0 auto 24px;color:var(--or)}
.why-item h4{font-size:18px;margin-bottom:12px;color:var(--blanc)}
.why-item p{color:rgba(255,255,255,0.65);font-size:14px;font-weight:300}

/* GALLERY PREVIEW */
.gallery-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.gallery-item{position:relative;overflow:hidden;aspect-ratio:1;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-item::after{content:'';position:absolute;inset:0;background:rgba(10,10,10,0);transition:background .3s ease}
.gallery-item:hover::after{background:rgba(10,10,10,0.3)}

/* TESTIMONIALS */
.testimonials{background:var(--gris-soft)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.testi-card{background:var(--blanc);padding:40px;border:1px solid var(--border);position:relative;transition:all .4s ease}
.testi-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,0.08)}
.quote-mark{font-family:'Playfair Display',serif;font-size:80px;color:var(--or);line-height:1;position:absolute;top:10px;right:20px;opacity:.3}
.testi-text{color:var(--gris-text);font-style:italic;font-weight:300;margin-bottom:24px;position:relative;z-index:1}
.testi-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--border)}
.testi-avatar{width:50px;height:50px;border-radius:50%;background:var(--or);color:var(--blanc);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:18px}
.testi-name{font-weight:600;font-size:14px}
.testi-role{font-size:12px;color:var(--gris-text);letter-spacing:1px}

/* CTA BAND */
.cta-band{background:var(--noir);color:var(--blanc);text-align:center;padding:100px 5%;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1571019614242-c5c5dee9f50b?w=1920&q=80') center/cover;opacity:.2;z-index:0}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{margin-bottom:24px}
.cta-band p{color:rgba(255,255,255,0.75);max-width:600px;margin:0 auto 40px;font-weight:300}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-info p{color:var(--gris-text);margin-bottom:32px;font-weight:300}
.contact-list{list-style:none;margin-bottom:40px}
.contact-list li{display:flex;align-items:flex-start;gap:20px;padding:20px 0;border-bottom:1px solid var(--border)}
.contact-list svg{width:24px;height:24px;color:var(--or);flex-shrink:0;margin-top:2px}
.contact-list strong{display:block;font-size:12px;text-transform:uppercase;letter-spacing:2px;color:var(--noir);margin-bottom:4px}
.contact-list span{color:var(--gris-text);font-weight:300}
.form-card{background:var(--gris-soft);padding:50px}
.form-group{margin-bottom:24px}
.form-group label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;color:var(--noir);font-weight:600}
.form-group input,.form-group textarea{width:100%;padding:14px 0;background:transparent;border:none;border-bottom:1px solid var(--border);font-family:inherit;font-size:15px;color:var(--noir);transition:border-color .3s ease}
.form-group input:focus,.form-group textarea:focus{outline:none;border-bottom-color:var(--or)}
.form-group textarea{resize:vertical;min-height:120px}
.form-msg{padding:16px;margin-top:20px;font-size:14px;text-align:center;display:none}
.form-msg.success{display:block;background:rgba(201,168,117,0.15);color:var(--or-dark);border:1px solid var(--or)}
.form-msg.error{display:block;background:#fde8e8;color:#c53030;border:1px solid #fbb6b6}

/* PAGE HEADER (interior pages) */
.page-header{height:60vh;min-height:480px;background:var(--noir);position:relative;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--blanc);overflow:hidden;margin-top:0}
.page-header::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,10,10,0.7),rgba(10,10,10,0.5));z-index:1}
.page-header-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:slowZoom 20s ease-in-out infinite alternate}
.page-header-content{position:relative;z-index:2;padding:0 5%;padding-top:80px}
.page-header h1{margin-bottom:16px}
.page-header p{color:rgba(255,255,255,0.8);max-width:600px;margin:0 auto;font-weight:300}
.breadcrumb{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--or);margin-bottom:20px}

/* FOOTER */
.footer{background:var(--noir);color:rgba(255,255,255,0.7);padding:80px 5% 30px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
.footer-brand .logo{margin-bottom:20px;display:inline-block}
.footer-brand p{font-weight:300;font-size:14px;max-width:320px}
.footer h4{font-family:'Inter',sans-serif;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--blanc);margin-bottom:24px;font-weight:600}
.footer ul{list-style:none}
.footer ul li{margin-bottom:12px;font-size:14px;font-weight:300}
.footer ul a:hover{color:var(--or)}
.footer-bottom{padding-top:30px;border-top:1px solid rgba(255,255,255,0.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:12px;letter-spacing:1px}

/* REVEAL ANIM */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease,transform .9s ease;animation:revealFallback .8s ease 1s forwards}
.reveal.visible{opacity:1;transform:translateY(0);animation:none}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;background:var(--noir);color:var(--blanc);padding:18px 24px;display:none;align-items:center;justify-content:space-between;gap:20px;z-index:9999;flex-wrap:wrap;border:1px solid var(--or);max-width:1200px;margin:0 auto}
.cookie-banner.show{display:flex}
.cookie-banner p{font-size:13px;font-weight:300;margin:0;flex:1;min-width:250px}
.cookie-banner button{padding:10px 24px;background:var(--or);color:var(--noir);border:none;font-size:11px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;font-weight:600}

/* RESPONSIVE */
@media(max-width:1024px){
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:50px}
  .services-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .gallery-preview{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  section{padding:80px 0}
  .nav{position:fixed;top:0;right:-100%;width:80%;max-width:340px;height:100vh;background:var(--noir);flex-direction:column;justify-content:center;padding:40px;transition:right .4s ease;gap:30px}
  .nav.open{right:0}
  .nav a{font-size:16px}
  .burger{display:flex}
  .services-grid,.testi-grid,.why-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .gallery-preview{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(3,1fr);gap:15px}
  .stat-num{font-size:30px}
  .form-card{padding:30px}
  .footer-bottom{flex-direction:column;text-align:center}
  .about-img img{height:400px}
  .hero{min-height:600px}
}
