*{margin:0;padding:0;box-sizing:border-box}
:root{
  --noir:#0a0a0a;
  --noir-soft:#1a1a1a;
  --or:#c9a961;
  --or-light:#e4c989;
  --beige:#f5f0e8;
  --blanc:#ffffff;
  --gris:#6b6b6b;
  --gris-light:#e8e4dd;
}
html{scroll-behavior:smooth}
body{font-family:'Cormorant Garamond',Georgia,serif;color:var(--noir);background:var(--blanc);line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;letter-spacing:0.02em}
.sans{font-family:'Montserrat','Helvetica Neue',sans-serif}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:25px 5%;display:flex;justify-content:space-between;align-items:center;transition:all 0.4s ease;background:transparent}
.navbar.scrolled{background:rgba(10,10,10,0.95);backdrop-filter:blur(10px);padding:15px 5%;box-shadow:0 2px 20px rgba(0,0,0,0.1)}
.logo{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;color:#fff;text-transform:uppercase;letter-spacing:4px;text-decoration:none;line-height:1.1}
.logo span{display:block;font-size:11px;letter-spacing:6px;color:var(--or);margin-top:2px}
.nav-links{display:flex;gap:45px;list-style:none}
.nav-links a{color:#fff;text-decoration:none;font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:400;position:relative;transition:color 0.3s}
.nav-links a::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:1px;background:var(--or);transition:width 0.3s}
.nav-links a:hover{color:var(--or)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--or);color:var(--noir)!important;padding:12px 26px;letter-spacing:2px;font-weight:500;transition:all 0.3s}
.nav-cta:hover{background:var(--or-light);color:var(--noir)!important}
.nav-cta::after{display:none}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001}
.hamburger span{display:block;width:28px;height:1px;background:#fff;transition:all 0.3s}

/* HERO SLIDER */
.hero{position:relative;height:100vh;width:100%;overflow:hidden}
.slider{position:absolute;inset:0;width:100%;height:100%}
.slide{position:absolute;inset:0;width:100%;height:100%;opacity:0;transition:opacity 1.5s ease;background-size:cover;background-position:center}
.slide.active{opacity:1}
.slide::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,0.3) 0%,rgba(10,10,10,0.6) 100%)}
.hero-content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:#fff;padding:0 5%}
.hero-tag{font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:8px;color:var(--or);margin-bottom:30px;text-transform:uppercase;animation:fadeUp 1.2s ease}
.hero h1{font-size:clamp(48px,7vw,98px);font-weight:300;line-height:1.05;margin-bottom:30px;animation:fadeUp 1.4s ease}
.hero h1 em{font-style:italic;color:var(--or);font-weight:300}
.hero p{font-family:'Montserrat',sans-serif;font-size:15px;letter-spacing:1px;max-width:600px;margin-bottom:50px;opacity:0.95;font-weight:300;animation:fadeUp 1.6s ease}
.hero-btns{display:flex;gap:20px;animation:fadeUp 1.8s ease;flex-wrap:wrap;justify-content:center}
.btn{display:inline-block;padding:18px 42px;font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;text-decoration:none;font-weight:500;transition:all 0.4s ease;cursor:pointer;border:none}
.btn-or{background:var(--or);color:var(--noir)}
.btn-or:hover{background:var(--or-light);transform:translateY(-2px);box-shadow:0 10px 30px rgba(201,169,97,0.3)}
.btn-outline{background:transparent;color:#fff;border:1px solid #fff}
.btn-outline:hover{background:#fff;color:var(--noir)}
.btn-dark{background:var(--noir);color:#fff}
.btn-dark:hover{background:var(--or);color:var(--noir)}

.slider-dots{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;gap:12px;z-index:3}
.dot{width:30px;height:2px;background:rgba(255,255,255,0.4);cursor:pointer;transition:all 0.3s}
.dot.active{background:var(--or);width:50px}

.scroll-indicator{position:absolute;bottom:30px;right:5%;color:#fff;font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:3px;writing-mode:vertical-rl;z-index:3;animation:scrollBounce 2s ease infinite}
@keyframes scrollBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(10px)}}

@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}

/* SECTIONS */
section{padding:120px 5%}
.section-head{text-align:center;margin-bottom:80px}
.section-tag{display:inline-block;font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:5px;color:var(--or);text-transform:uppercase;margin-bottom:20px;position:relative}
.section-tag::before,.section-tag::after{content:'';position:absolute;top:50%;width:30px;height:1px;background:var(--or)}
.section-tag::before{right:calc(100% + 15px)}
.section-tag::after{left:calc(100% + 15px)}
.section-head h2{font-size:clamp(36px,5vw,62px);font-weight:300;line-height:1.1;margin-bottom:20px}
.section-head h2 em{font-style:italic;color:var(--or)}
.section-head p{font-family:'Montserrat',sans-serif;font-size:14px;color:var(--gris);max-width:600px;margin:0 auto;font-weight:300;letter-spacing:0.5px}

/* INTRO */
.intro{background:var(--beige);position:relative;overflow:hidden}
.intro-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.intro-img{position:relative;height:600px;overflow:hidden}
.intro-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease}
.intro-img:hover img{transform:scale(1.05)}
.intro-img::before{content:'';position:absolute;inset:20px;border:1px solid var(--or);z-index:2;pointer-events:none}
.intro-text .section-tag{margin-left:0}
.intro-text .section-tag::before{display:none}
.intro-text h2{text-align:left;font-size:clamp(34px,4vw,52px)}
.intro-text p{font-family:'Cormorant Garamond',serif;font-size:19px;color:var(--gris);margin:30px 0;line-height:1.8;font-weight:300}
.intro-stats{display:flex;gap:60px;margin-top:50px;padding-top:40px;border-top:1px solid var(--gris-light)}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:54px;color:var(--or);font-weight:300;line-height:1}
.stat .label{font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gris);margin-top:8px}

/* SERVICES CARDS */
.services-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.service-card{background:#fff;border:1px solid var(--gris-light);padding:50px 35px;text-align:center;transition:all 0.5s ease;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--or);transform:scaleX(0);transition:transform 0.5s ease;transform-origin:left}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{transform:translateY(-10px);box-shadow:0 30px 60px rgba(0,0,0,0.08)}
.service-icon{width:70px;height:70px;margin:0 auto 30px;display:flex;align-items:center;justify-content:center;border:1px solid var(--or);border-radius:50%;color:var(--or);transition:all 0.4s}
.service-card:hover .service-icon{background:var(--or);color:#fff;transform:rotate(360deg)}
.service-card h3{font-size:26px;margin-bottom:18px;font-weight:400}
.service-card p{font-family:'Montserrat',sans-serif;font-size:13px;color:var(--gris);line-height:1.8;font-weight:300}

/* EXPERTISE / PROCESS */
.expertise{background:var(--noir);color:#fff;position:relative;overflow:hidden}
.expertise::before{content:'';position:absolute;top:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--or),transparent)}
.expertise .section-head h2{color:#fff}
.expertise .section-head p{color:rgba(255,255,255,0.6)}
.process-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.process-card{text-align:center;padding:40px 20px;position:relative}
.process-num{font-family:'Cormorant Garamond',serif;font-size:80px;color:var(--or);opacity:0.3;line-height:1;margin-bottom:20px;font-weight:300}
.process-card h4{font-size:24px;margin-bottom:15px;font-weight:400}
.process-card p{font-family:'Montserrat',sans-serif;font-size:12px;color:rgba(255,255,255,0.65);line-height:1.8;font-weight:300}

/* GALLERY GRID */
.gallery-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gallery-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/5}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:all 0.7s ease}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,10,10,0.85) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:30px;opacity:0;transition:opacity 0.5s}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay h4{color:#fff;font-size:24px;margin-bottom:8px;font-weight:400}
.gallery-overlay span{color:var(--or);font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:3px;text-transform:uppercase}

/* GALLERY FEATURED (home) */
.featured{background:var(--beige)}
.featured-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,250px);gap:15px}
.featured-item{position:relative;overflow:hidden;cursor:pointer}
.featured-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.featured-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s}
.featured-item:hover img{transform:scale(1.08)}
.featured-item .gallery-overlay{opacity:1;background:linear-gradient(180deg,transparent 60%,rgba(10,10,10,0.8) 100%)}

/* TESTIMONIALS */
.testimonials{background:#fff}
.testi-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.testi-card{padding:50px 40px;border:1px solid var(--gris-light);position:relative;transition:all 0.4s}
.testi-card:hover{border-color:var(--or);box-shadow:0 20px 50px rgba(0,0,0,0.05)}
.quote-mark{font-family:'Cormorant Garamond',serif;font-size:90px;color:var(--or);line-height:0.5;position:absolute;top:25px;left:30px;opacity:0.3}
.testi-card p{font-family:'Cormorant Garamond',serif;font-size:18px;line-height:1.7;color:var(--noir);margin:30px 0;font-style:italic;font-weight:300}
.testi-author{display:flex;align-items:center;gap:15px;padding-top:25px;border-top:1px solid var(--gris-light)}
.testi-avatar{width:50px;height:50px;border-radius:50%;background:var(--or);display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Cormorant Garamond',serif;font-size:22px}
.testi-author .name{font-family:'Montserrat',sans-serif;font-size:13px;letter-spacing:1px;font-weight:500;text-transform:uppercase}
.testi-author .city{font-family:'Montserrat',sans-serif;font-size:11px;color:var(--gris);letter-spacing:1px;margin-top:3px}
.stars{color:var(--or);margin-bottom:10px;font-size:14px;letter-spacing:3px}

/* CTA BAND */
.cta-band{background:var(--noir);color:#fff;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-1564501049412-61c2a3083791?w=1600') center/cover;opacity:0.15;filter:grayscale(100%)}
.cta-band > *{position:relative;z-index:2}
.cta-band h2{font-size:clamp(36px,5vw,58px);font-weight:300;margin-bottom:25px}
.cta-band h2 em{color:var(--or);font-style:italic}
.cta-band p{font-family:'Montserrat',sans-serif;font-size:14px;letter-spacing:1px;opacity:0.8;max-width:600px;margin:0 auto 40px;font-weight:300}

/* CONTACT */
.contact-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px}
.contact-info h3{font-size:36px;margin-bottom:25px;font-weight:300}
.contact-info h3 em{color:var(--or);font-style:italic}
.contact-info > p{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--gris);margin-bottom:50px;line-height:1.8;font-weight:300}
.info-item{display:flex;gap:20px;margin-bottom:35px;align-items:flex-start}
.info-icon{width:45px;height:45px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--or);color:var(--or);border-radius:50%}
.info-item h4{font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gris);margin-bottom:8px;font-weight:500}
.info-item p{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--noir);font-weight:400}
.contact-form{background:var(--beige);padding:60px 50px}
.contact-form h3{font-size:30px;margin-bottom:35px;font-weight:300}
.form-group{margin-bottom:25px}
.form-group label{display:block;font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gris);margin-bottom:10px;font-weight:500}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:15px 0;background:transparent;border:none;border-bottom:1px solid var(--gris-light);font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--noir);transition:border-color 0.3s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--or)}
.form-group textarea{resize:vertical;min-height:100px}
.contact-form .btn{width:100%;margin-top:15px}

/* MAP */
.map-section{padding:0;height:500px;width:100%}
.map-section iframe{width:100%;height:100%;border:0;filter:grayscale(70%) contrast(1.1)}

/* PAGE HEADER */
.page-header{height:60vh;min-height:450px;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.page-header::before{content:'';position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.page-header::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,0.4),rgba(10,10,10,0.7));z-index:1}
.page-header > *{position:relative;z-index:2;padding:0 5%}
.page-header h1{font-size:clamp(48px,7vw,84px);font-weight:300;margin-bottom:20px}
.page-header h1 em{color:var(--or);font-style:italic}
.page-header p{font-family:'Montserrat',sans-serif;font-size:13px;letter-spacing:4px;text-transform:uppercase;opacity:0.9}
.breadcrumb{margin-top:30px;font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;opacity:0.7}
.breadcrumb a{color:var(--or);text-decoration:none}

/* SERVICES DETAIL */
.service-detail{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:120px}
.service-detail:nth-child(even) .service-detail-img{order:2}
.service-detail-img{height:500px;overflow:hidden;position:relative}
.service-detail-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s}
.service-detail-img:hover img{transform:scale(1.05)}
.service-detail-text .section-tag{margin-left:0}
.service-detail-text .section-tag::before{display:none}
.service-detail-text h2{font-size:clamp(32px,4vw,48px);font-weight:300;margin-bottom:25px}
.service-detail-text h2 em{color:var(--or);font-style:italic}
.service-detail-text p{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--gris);line-height:1.8;margin-bottom:25px;font-weight:300}
.service-list{list-style:none;margin:30px 0}
.service-list li{font-family:'Montserrat',sans-serif;font-size:13px;color:var(--noir);padding:12px 0;border-bottom:1px solid var(--gris-light);display:flex;align-items:center;gap:15px;font-weight:300}
.service-list li::before{content:'';width:30px;height:1px;background:var(--or);flex-shrink:0}

/* VALUES */
.values-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.value-card{text-align:center;padding:40px 25px}
.value-icon{width:60px;height:60px;margin:0 auto 25px;color:var(--or)}
.value-card h4{font-size:22px;margin-bottom:15px;font-weight:400}
.value-card p{font-family:'Montserrat',sans-serif;font-size:12px;color:var(--gris);line-height:1.8;font-weight:300}

/* FOOTER */
footer{background:var(--noir);color:#fff;padding:80px 5% 30px;position:relative}
.footer-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.1)}
.footer-col h5{font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--or);margin-bottom:25px;font-weight:500}
.footer-col .logo{margin-bottom:25px;color:#fff}
.footer-col p{font-family:'Montserrat',sans-serif;font-size:13px;color:rgba(255,255,255,0.6);line-height:1.9;font-weight:300}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:12px}
.footer-col ul a{font-family:'Montserrat',sans-serif;font-size:13px;color:rgba(255,255,255,0.6);text-decoration:none;transition:color 0.3s;font-weight:300}
.footer-col ul a:hover{color:var(--or)}
.footer-bot{max-width:1300px;margin:0 auto;padding-top:30px;display:flex;justify-content:space-between;align-items:center;font-family:'Montserrat',sans-serif;font-size:11px;color:rgba(255,255,255,0.4);letter-spacing:1px}

/* REVEAL ANIMATIONS */
.reveal{opacity:0;transform:translateY(40px);transition:all 1s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}
.reveal{animation:revealFallback 0.8s ease 0.3s forwards}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(10,10,10,0.95);z-index:9999;display:none;align-items:center;justify-content:center;padding:5%}
.lightbox.active{display:flex}
.lightbox img{max-width:90%;max-height:90%;object-fit:contain}
.lightbox-close{position:absolute;top:30px;right:30px;color:#fff;font-size:40px;cursor:pointer;background:none;border:none;font-weight:100}

/* RESPONSIVE */
@media(max-width:1024px){
  .intro-grid,.contact-grid,.service-detail{grid-template-columns:1fr;gap:40px}
  .service-detail:nth-child(even) .service-detail-img{order:0}
  .intro-img,.service-detail-img{height:400px}
  .services-grid,.process-grid,.values-grid{grid-template-columns:repeat(2,1fr)}
  .featured-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(4,200px)}
  .featured-item:nth-child(1){grid-column:span 2;grid-row:span 2}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr;max-width:600px}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-links{position:fixed;top:0;right:-100%;width:80%;height:100vh;background:var(--noir);flex-direction:column;justify-content:center;align-items:center;gap:30px;transition:right 0.4s ease;padding:60px 20px}
  .nav-links.open{right:0}
  .hamburger{display:flex}
  .hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .hamburger.open span:nth-child(2){opacity:0}
  .hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  section{padding:80px 5%}
  .section-head{margin-bottom:50px}
  .services-grid,.process-grid,.values-grid,.featured-grid,.gallery-grid{grid-template-columns:1fr}
  .featured-grid{grid-template-rows:none}
  .featured-item:nth-child(1){grid-column:span 1;grid-row:span 1}
  .featured-item{height:300px}
  .intro-stats{flex-direction:column;gap:30px}
  .contact-form{padding:40px 25px}
  .footer-grid{grid-template-columns:1fr;gap:40px}
  .footer-bot{flex-direction:column;gap:15px;text-align:center}
  .hero-btns{flex-direction:column;width:100%;padding:0 30px}
  .hero-btns .btn{width:100%}
}
