@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --white: #ffffff;
  --cream: #FDF8F4;
  --beige: #F5EDE4;
  --beige-dark: #E8DDD2;
  --gold: #C9A96E;
  --gold-light: #D4BA8A;
  --gold-dark: #B8944F;
  --skin: #E8C9A8;
  --skin-light: #F0DCC8;
  --text-dark: #2C2420;
  --text-medium: #5A4A3C;
  --text-light: #8B7A6B;
  --shadow: rgba(44,36,32,0.08);
  --shadow-md: rgba(44,36,32,0.12);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:'Inter',sans-serif;color:var(--text-dark);background:var(--white);overflow-x:hidden;line-height:1.7}
body.loading{overflow:hidden}
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.3}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* GRAIN OVERLAY */
body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0.03;
background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ── LOADING SCREEN ── */
.loader{position:fixed;inset:0;z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--cream),var(--white),var(--beige));transition:opacity .6s,visibility .6s}
.loader.hidden{opacity:0;visibility:hidden}
.loader-text{font-family:'Playfair Display',serif;font-size:clamp(1.4rem,3vw,2rem);color:var(--text-dark);margin-bottom:32px;position:relative;overflow:hidden}
.loader-text::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.3),transparent);animation:shimmer 1.5s infinite}
@keyframes shimmer{to{left:100%}}
.loader-bar{width:200px;height:3px;background:var(--beige);border-radius:4px;overflow:hidden}
.loader-bar-fill{width:0;height:100%;background:linear-gradient(90deg,var(--gold-light),var(--gold));border-radius:4px;animation:loadBar 1.8s ease-in-out forwards}
@keyframes loadBar{to{width:100%}}
.loader-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.loader-particle{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--gold-light);opacity:0;animation:floatP 3s infinite}
@keyframes floatP{0%{opacity:0;transform:translateY(0)}30%{opacity:.4}100%{opacity:0;transform:translateY(-120px)}}

/* ── NAVBAR ── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;background:transparent;transition:all .4s;border-bottom:1px solid transparent}
.navbar.scrolled{padding:12px 0;background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--beige);box-shadow:0 4px 30px var(--shadow)}
.nav-inner{display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:600;color:var(--text-dark);text-decoration:none;letter-spacing:1px}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{text-decoration:none;color:var(--text-medium);font-size:.88rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase;position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--gold);transition:width .3s ease}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--gold);color:var(--white);padding:10px 28px;border-radius:50px;text-decoration:none;font-size:.85rem;font-weight:600;letter-spacing:.5px;transition:all .3s;border:2px solid var(--gold)}
.nav-cta:hover{background:transparent;color:var(--gold)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--text-dark);transition:all .3s;border-radius:2px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-nav{display:none;position:fixed;top:0;left:0;width:100%;height:100vh;z-index:999;background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-nav.active{display:flex}
.mobile-nav a{font-size:1.2rem;color:var(--text-dark);text-decoration:none;font-weight:500;letter-spacing:1px;text-transform:uppercase;transition:color .3s}
.mobile-nav a:hover{color:var(--gold)}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;background:linear-gradient(135deg,var(--cream) 0%,var(--beige) 50%,var(--skin-light) 100%);overflow:hidden}
.hero::before{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(201,169,110,0.12),transparent 70%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-30%;left:-10%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(240,220,200,0.2),transparent 70%);pointer-events:none}
.hero-flex{display:flex;align-items:center;gap:48px;padding-top:110px;padding-bottom:70px}
.hero-content{position:relative;z-index:2;flex:1 1 52%;min-width:0;opacity:0;animation:fadeUp .9s .3s ease forwards}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.hero-content{transform:translateY(40px)}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(201,169,110,0.1);border:1px solid rgba(201,169,110,0.25);padding:8px 20px;border-radius:50px;font-size:.78rem;font-weight:600;color:var(--gold-dark);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:28px}
.hero h1{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:600;color:var(--text-dark);margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--gold);display:block}
.hero p{font-size:1.05rem;color:var(--text-light);margin-bottom:36px;max-width:480px}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}
.btn-primary{background:var(--gold);color:var(--white);padding:16px 40px;border-radius:50px;text-decoration:none;font-size:.9rem;font-weight:600;letter-spacing:.5px;transition:all .3s;display:inline-flex;align-items:center;gap:8px;box-shadow:0 8px 30px rgba(201,169,110,0.3);position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;inset:-2px;border-radius:50px;background:var(--gold);opacity:0;filter:blur(12px);transition:opacity .3s;z-index:-1}
.btn-primary:hover{background:var(--gold-dark);transform:translateY(-2px) scale(1.03);box-shadow:0 12px 40px rgba(201,169,110,0.45)}
.btn-primary:hover::before{opacity:.5}
.btn-secondary{background:transparent;color:var(--text-dark);padding:16px 40px;border-radius:50px;text-decoration:none;font-size:.9rem;font-weight:600;letter-spacing:.5px;border:2px solid var(--beige-dark);transition:all .3s}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px) scale(1.03)}

/* HERO IMAGE */
.hero-image{flex:1 1 45%;min-width:0;position:relative;opacity:0;animation:zoomIn 1s .5s ease forwards}
@keyframes zoomIn{from{opacity:0;transform:scale(0.92)}to{opacity:1;transform:scale(1)}}
.hero-image::before{content:'';position:absolute;inset:-20px;border-radius:28px;background:radial-gradient(circle at center,rgba(201,169,110,0.2),transparent 65%);filter:blur(30px);z-index:0}
.hero-image img{width:100%;height:500px;object-fit:cover;display:block;border-radius:20px;position:relative;z-index:1;box-shadow:0 24px 60px rgba(44,36,32,0.15)}

/* STATS GLASSMORPHISM */
.hero-stats{display:flex;gap:20px;margin-top:44px;padding-top:0}
.stat{background:rgba(255,255,255,0.45);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.6);border-radius:16px;padding:20px 24px;text-align:center;box-shadow:0 8px 32px rgba(44,36,32,0.06);transition:transform .3s,box-shadow .3s;flex:1}
.stat:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(44,36,32,0.1)}
.stat h3{font-size:1.8rem;color:var(--gold);font-family:'Playfair Display',serif;margin-bottom:4px}
.stat p{font-size:.72rem;color:var(--text-light);text-transform:uppercase;letter-spacing:1.2px;font-weight:500}

/* ── SECTIONS ── */
.section{padding:100px 0}
.section-header{text-align:center;margin-bottom:60px}
.section-badge{display:inline-block;font-size:.75rem;font-weight:600;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-bottom:12px}
.section-header h2{font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--text-dark);margin-bottom:16px}
.section-header p{color:var(--text-light);max-width:560px;margin:0 auto;font-size:1rem}
.bg-cream{background:var(--cream)}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.service-card{background:var(--white);border-radius:20px;overflow:hidden;transition:all .4s ease;box-shadow:0 4px 20px var(--shadow);border:1px solid var(--beige)}
.service-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px var(--shadow-md)}
.service-img{width:100%;height:260px;object-fit:cover;transition:transform .6s ease}
.service-card:hover .service-img{transform:scale(1.05)}
.service-img-wrap{overflow:hidden}
.service-body{padding:28px}
.service-body h3{font-size:1.4rem;margin-bottom:12px;color:var(--text-dark)}
.service-body p{font-size:.92rem;color:var(--text-light);margin-bottom:20px}
.service-link{color:var(--gold);text-decoration:none;font-weight:600;font-size:.88rem;display:inline-flex;align-items:center;gap:6px;transition:gap .3s}
.service-link:hover{gap:12px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-img-wrap{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px var(--shadow-md)}
.about-img-wrap img{width:100%;height:500px;object-fit:cover;display:block}
.about-img-badge{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,0.92);backdrop-filter:blur(10px);padding:16px 24px;border-radius:14px;box-shadow:0 8px 30px var(--shadow)}
.about-img-badge h4{font-size:1.6rem;color:var(--gold)}
.about-img-badge p{font-size:.78rem;color:var(--text-light)}
.about-content h2{font-size:clamp(1.8rem,3vw,2.4rem);margin-bottom:20px}
.about-content>p{color:var(--text-light);margin-bottom:28px;font-size:1rem}
.about-features{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}
.about-feature{display:flex;align-items:center;gap:14px;padding:14px 20px;background:var(--cream);border-radius:12px;transition:all .3s}
.about-feature:hover{background:var(--beige);transform:translateX(6px)}
.about-feature .icon{width:42px;height:42px;border-radius:50%;background:var(--gold);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.about-feature span{font-weight:500;font-size:.95rem;color:var(--text-dark)}

/* BEFORE/AFTER */
.ba-wrapper{max-width:700px;margin:0 auto}
.ba-slider{position:relative;overflow:hidden;border-radius:20px;box-shadow:0 20px 60px var(--shadow-md);cursor:col-resize;user-select:none}
.ba-slider img{width:100%;display:block}
.ba-after{position:absolute;top:0;left:0;width:50%;height:100%;overflow:hidden}
.ba-after img{position:absolute;top:0;left:0;width:200%;max-width:none}
.ba-handle{position:absolute;top:0;left:50%;width:4px;height:100%;background:var(--gold);transform:translateX(-50%);z-index:10;cursor:col-resize}
.ba-handle::after{content:'⟨⟩';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:var(--gold);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;box-shadow:0 4px 20px rgba(201,169,110,0.4)}
.ba-labels{display:flex;justify-content:space-between;margin-top:16px}
.ba-labels span{font-size:.82rem;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:2px}

/* FAQ */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--beige);overflow:hidden}
.faq-question{width:100%;padding:24px 0;background:none;border:none;font-family:'Inter',sans-serif;font-size:1.05rem;font-weight:500;color:var(--text-dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;transition:color .3s}
.faq-question:hover{color:var(--gold)}
.faq-question .icon{width:32px;height:32px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0;font-size:1.2rem}
.faq-item.active .faq-question .icon{background:var(--gold);color:var(--white);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.active .faq-answer{max-height:300px}
.faq-answer p{padding:0 0 24px;color:var(--text-light);font-size:.95rem;line-height:1.8}

/* INSTAGRAM */
.insta-header{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px}
.insta-header h2{margin-bottom:0}
.insta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.insta-item{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:1;background:var(--beige)}
.insta-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.insta-item:hover img{transform:scale(1.1)}
.insta-overlay{position:absolute;inset:0;background:rgba(201,169,110,0.7);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.insta-item:hover .insta-overlay{opacity:1}
.insta-overlay span{color:var(--white);font-size:1.8rem}
.insta-follow{text-align:center;margin-top:32px}
.insta-follow a{display:inline-flex;align-items:center;gap:10px;color:var(--gold);text-decoration:none;font-weight:600;font-size:1rem;padding:14px 36px;border:2px solid var(--gold);border-radius:50px;transition:all .3s}
.insta-follow a:hover{background:var(--gold);color:var(--white);transform:scale(1.03)}

/* CTA BANNER */
.cta-banner{background:linear-gradient(135deg,var(--text-dark) 0%,#3D312A 100%);padding:80px 0;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;top:-50%;right:-20%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(201,169,110,0.15),transparent 70%)}
.cta-banner h2{color:var(--white);font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:16px}
.cta-banner p{color:rgba(255,255,255,0.6);margin-bottom:36px;font-size:1.05rem}
.cta-banner .btn-primary{font-size:1rem;padding:18px 48px}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.contact-info h3{font-size:1.6rem;margin-bottom:20px}
.contact-info>p{color:var(--text-light);margin-bottom:32px}
.contact-detail{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}
.contact-detail .icon{width:48px;height:48px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.1rem;flex-shrink:0;transition:all .3s}
.contact-detail:hover .icon{background:var(--gold);color:var(--white);transform:scale(1.08)}
.contact-detail h4{font-size:.95rem;margin-bottom:4px;font-family:'Inter',sans-serif;font-weight:600}
.contact-detail p{color:var(--text-light);font-size:.9rem}
.contact-detail a{color:var(--gold);text-decoration:none}
.contact-form{background:var(--white);padding:40px;border-radius:20px;box-shadow:0 10px 40px var(--shadow);border:1px solid var(--beige)}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-medium);margin-bottom:8px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 18px;border:1.5px solid var(--beige);border-radius:12px;font-family:'Inter',sans-serif;font-size:.95rem;color:var(--text-dark);transition:border-color .3s,box-shadow .3s;background:var(--cream);outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,110,0.1)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{width:100%;padding:16px;background:var(--gold);color:var(--white);border:none;border-radius:50px;font-family:'Inter',sans-serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;letter-spacing:.5px}
.form-submit:hover{background:var(--gold-dark);transform:scale(1.03);box-shadow:0 8px 30px rgba(201,169,110,0.3)}

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

/* FOOTER */
.footer{background:var(--text-dark);color:rgba(255,255,255,0.5);padding:60px 0 30px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand .nav-logo{color:var(--white);display:inline-block;margin-bottom:16px}
.footer-brand p{font-size:.9rem;line-height:1.8;max-width:320px}
.footer h4{color:var(--white);font-family:'Inter',sans-serif;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:20px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer ul a{color:rgba(255,255,255,0.5);text-decoration:none;font-size:.9rem;transition:color .3s}
.footer ul a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:24px;text-align:center;font-size:.82rem}

/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* RESPONSIVE */
@media(max-width:992px){
  .hero-flex{flex-direction:column;gap:30px;padding-top:100px}
  .hero-image{margin-left:0;width:100%}
  .hero-image img{height:320px}
  .hero-content{max-width:100%}
  .hero-stats{flex-wrap:wrap}
  .stat{min-width:120px}
  .services-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .about-grid{grid-template-columns:1fr}
  .about-img-wrap{order:-1}
  .about-img-wrap img{height:360px}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .insta-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
}
@media(max-width:600px){
  .section{padding:70px 0}
  .hero{min-height:auto;padding:0}
  .hero-flex{padding-top:100px;padding-bottom:40px}
  .hero-stats{gap:12px}
  .stat{padding:14px 12px}
  .stat h3{font-size:1.4rem}
  .hero-buttons{flex-direction:column}
  .hero-buttons a{text-align:center;justify-content:center}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:24px}
}
