*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
:root{--wd:#5D4037;--wm:#8D6E63;--wl:#D7CCC8;--cr:#FFF8F0;--ac:#E85A2C;--ad:#C94A1F;--dk:#1a1a1a}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--cr);color:var(--wd);line-height:1.6}
h1,h2,h3,h4,h5,h6{font-family:'Bebas Neue',sans-serif;font-weight:400;text-transform:uppercase;line-height:1.05;letter-spacing:.03em}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-label{display:block;color:var(--ac);font-family:'Bebas Neue',cursive;letter-spacing:.12em;font-size:.9rem;margin-bottom:.5rem}
.section-title{font-size:clamp(2rem,4vw,3.5rem);color:var(--wd);margin-top:.5rem;margin-bottom:1.5rem}
.section-subtitle{font-size:1.15rem;color:var(--wm);max-width:700px}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}

/* LOG BUTTONS */
.logbtn{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border:none;background:none;height:90px;min-width:220px;padding:0;transition:transform .2s,filter .2s;text-decoration:none;vertical-align:middle}
.logbtn:hover{transform:translateY(-3px);filter:brightness(1.08)}
.logbtn:active{transform:translateY(1px)}
.logbtn .lb-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:fill;pointer-events:none;border-radius:0}
.logbtn .lb-text{position:relative;z-index:1;font-family:'Bebas Neue',cursive;font-size:1.6rem;letter-spacing:.05em;line-height:1;text-transform:uppercase;white-space:nowrap;padding:0 1.5rem}
.logbtn-dark .lb-text,.logbtn-orange .lb-text{color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.logbtn-light .lb-text{color:#4A2800}
.logbtn-sm{height:58px;min-width:160px}
.logbtn-sm .lb-text{font-size:1.15rem}

/* TOPBAR */
.topbar{background:var(--wd);color:#fff;padding:.5rem 0;font-size:.85rem;display:none}
@media(min-width:768px){.topbar{display:block}}
.topbar-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center}
.topbar-left{display:flex;gap:1.5rem;align-items:center}
.topbar a{color:#fff;display:flex;align-items:center;gap:.4rem;transition:color .2s}
.topbar a:hover{color:var(--ac)}

/* NAV */
header{position:sticky;top:0;z-index:100;background:#fff;transition:box-shadow .3s}
header.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.1)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;height:88px}
.logo img{height:80px;width:auto}
.desktop-nav{display:none;align-items:center;gap:.25rem}
@media(min-width:1024px){.desktop-nav{display:flex}}
.desktop-nav a{font-family:'Bebas Neue',cursive;font-size:1.2rem;letter-spacing:.06em;color:var(--wd);padding:.5rem .75rem;transition:color .2s;background:none;border:none;cursor:pointer}
.desktop-nav a:hover,.desktop-nav a.active{color:var(--ac)}
.hamburger{background:none;border:none;cursor:pointer;padding:.5rem;display:flex}
@media(min-width:1024px){.hamburger{display:none}}
.hamburger svg{width:26px;height:26px;stroke:var(--wd)}
.mobile-nav{display:none;background:#fff;border-top:1px solid #eee;padding:1rem 1.5rem 1.5rem}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:.75rem 0;font-family:'Bebas Neue',cursive;font-size:1.2rem;letter-spacing:.06em;color:var(--wd);border-bottom:1px solid #f5f5f5}
.mobile-nav a:hover{color:var(--ac)}
.mobile-nav .logbtn{margin-top:1rem;width:100%}

/* HERO */
.hero-desktop{position:relative;width:100%;aspect-ratio:3.2/1;min-height:320px;display:none}
@media(min-width:768px){.hero-desktop{display:block}}
.hero-mobile{display:block}
@media(min-width:768px){.hero-mobile{display:none}}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-content{position:absolute;inset:0;display:flex;align-items:center}
.hero-text{max-width:1280px;width:100%;margin:0 auto;padding:0 4rem}
.hero-h1{font-family:'Bebas Neue',sans-serif;text-transform:uppercase;line-height:.95;letter-spacing:.01em;color:#3B1E0A;font-size:clamp(2.6rem,5.5vw,5.5rem)}
.hero-h1 span{color:var(--ac)}
.hero-sub{margin-top:1rem;color:#3B1E0A;font-size:clamp(.9rem,1.3vw,1.15rem);line-height:1.55}
.hero-mobile-img{width:100%;background-size:cover;background-position:center;aspect-ratio:3/4}
.hero-mobile-h1{font-family:'Bebas Neue',sans-serif;text-transform:uppercase;line-height:.95;color:#3B1E0A;font-size:clamp(2.8rem,13vw,4.5rem)}
.hero-mobile-h1 span{color:var(--ac)}

/* WHY GRID */
.why-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:3rem}
@media(min-width:640px){.why-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.why-grid{grid-template-columns:repeat(4,1fr)}}
.why-card{background:var(--cr);border-radius:1.25rem;padding:2rem;transition:box-shadow .3s,transform .3s}
.why-card:hover{box-shadow:0 20px 40px rgba(0,0,0,.1);transform:translateY(-6px)}
.why-icon{width:64px;height:64px;border-radius:.75rem;background:rgba(232,90,44,.1);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;transition:background .3s}
.why-card:hover .why-icon{background:var(--ac)}
.why-icon svg{width:32px;height:32px;stroke:var(--ac);transition:stroke .3s}
.why-card:hover .why-icon svg{stroke:#fff}
.why-card h3{font-size:1.2rem;color:var(--wd);margin-bottom:.75rem}
.why-card p{color:var(--wm);line-height:1.65;font-size:.95rem}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-top:3rem}
@media(min-width:1024px){.services-grid{grid-template-columns:1fr 1fr}}
.service-card{background:#fff;border-radius:1.75rem;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.08);transition:box-shadow .5s,transform .3s;display:block;cursor:pointer}
.service-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.15);transform:translateY(-4px)}
.service-img-wrap{position:relative;height:288px;overflow:hidden}
.service-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.service-card:hover .service-img-wrap img{transform:scale(1.1)}
.service-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(93,64,55,.8),transparent)}
.service-img-badge{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;display:flex;align-items:center;gap:.75rem}
.service-icon-box{width:48px;height:48px;border-radius:.75rem;background:var(--ac);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.service-icon-box svg{width:24px;height:24px;stroke:#fff}
.service-img-badge h3{font-size:1.4rem;color:#fff}
.service-body{padding:2rem}
.service-body p{color:var(--wm);margin-bottom:1.5rem;line-height:1.65}
.service-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.tag{background:var(--cr);color:var(--wd);padding:.4rem 1rem;border-radius:100px;font-size:.85rem;font-weight:500}
.service-link{color:var(--ac);font-weight:600;display:flex;align-items:center;gap:.5rem}
.service-link svg{width:20px;height:20px;stroke:var(--ac);transition:margin .2s}
.service-card:hover .service-link svg{margin-left:8px}

/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:3rem}
@media(min-width:768px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}
.testimonial-card{background:var(--cr);border-radius:1.25rem;padding:2rem}
.stars{color:var(--ac);font-size:1.1rem;margin-bottom:1rem}
.testimonial-card blockquote{color:var(--wd);font-style:italic;margin-bottom:1.5rem;line-height:1.65}
.reviewer-name{font-weight:600;color:var(--wd)}
.reviewer-loc{color:var(--wm);font-size:.875rem}

/* GALLERY */
.gallery-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}
.gallery-accent-bar{width:4px;height:32px;border-radius:2px}
.gallery-section-header h3{font-size:1.75rem;color:var(--wd)}
.gallery-count{color:var(--wm);font-size:.9rem;font-family:sans-serif;font-weight:normal;text-transform:none;letter-spacing:0}
.masonry{columns:2;column-gap:1rem}
@media(min-width:640px){.masonry{columns:3}}
@media(min-width:1024px){.masonry{columns:4}}
.gitem{break-inside:avoid;margin-bottom:1rem;position:relative;overflow:hidden;border-radius:.75rem;cursor:pointer;opacity:0;transform:translateY(14px);transition:opacity .5s,transform .5s}
.gitem.show{opacity:1;transform:translateY(0)}
.gitem img{width:100%;height:auto;display:block;transition:transform .5s;border-radius:.75rem}
.gitem:hover img{transform:scale(1.05)}
.gbadge{position:absolute;bottom:8px;left:8px;color:#fff;font-family:'Bebas Neue',cursive;font-size:.7rem;letter-spacing:.08em;padding:2px 8px;border-radius:4px}

/* CTA */
.cta-section{position:relative;padding:6rem 0;overflow:hidden}
.cta-bg{position:absolute;inset:0;background-image:url('https://images.unsplash.com/photo-1556909114-44e3e9699e2b?w=1920&q=80');background-size:cover;background-position:center}
.cta-overlay{position:absolute;inset:0;background:rgba(93,64,55,.9)}
.cta-content{position:relative;text-align:center}
.cta-content h2{color:#fff;font-size:clamp(2rem,4vw,3.5rem);margin-bottom:1.5rem}
.cta-content p{color:rgba(255,255,255,.8);font-size:1.2rem;max-width:600px;margin:0 auto 2.5rem}

/* PAGE HERO */
.page-hero{position:relative;padding:6rem 0;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero-overlay{position:absolute;inset:0;background:rgba(93,64,55,.85)}
.page-hero-content{position:relative}
.page-hero h1{color:#fff;font-size:clamp(2.5rem,5vw,4rem);margin-bottom:1rem}
.page-hero p{color:rgba(255,255,255,.8);font-size:1.1rem;max-width:600px}
.page-hero.text-center p,.page-hero-content.text-center p{margin-left:auto;margin-right:auto}
.page-hero-icon svg{width:64px;height:64px;stroke:var(--ac);margin-bottom:1.5rem}

/* ABOUT */
.two-col{display:grid;grid-template-columns:1fr;gap:4rem;align-items:center}
@media(min-width:1024px){.two-col{grid-template-columns:1fr 1fr}}
.about-img-wrap{position:relative}
.about-img-wrap img{border-radius:1.5rem;width:100%;object-fit:cover;box-shadow:0 20px 60px rgba(0,0,0,.15)}
.about-badge{position:absolute;bottom:-1.5rem;right:-1rem;background:var(--ac);color:#fff;padding:1rem 1.5rem;border-radius:1rem}
.about-badge p:first-child{font-size:1.5rem;font-weight:700}
.about-badge p:last-child{font-size:.8rem}
.values-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:3rem}
@media(min-width:640px){.values-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.values-grid{grid-template-columns:repeat(4,1fr)}}
.value-card{background:#fff;border-radius:1.25rem;padding:2rem;text-align:center;box-shadow:0 4px 16px rgba(0,0,0,.06)}
.value-icon{width:64px;height:64px;border-radius:.75rem;background:rgba(232,90,44,.1);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.value-icon svg{width:32px;height:32px;stroke:var(--ac)}
.value-card h3{font-size:1.1rem;color:var(--wd);margin-bottom:.75rem}
.value-card p{color:var(--wm);font-size:.9rem}
.img2col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.img2col img{border-radius:1rem;height:192px;width:100%;object-fit:cover}
.img2col img:nth-child(even){margin-top:2rem}

/* AREAS */
.areas-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:3rem}
@media(min-width:768px){.areas-grid{grid-template-columns:repeat(3,1fr)}}
.area-card{background:#fff;border-radius:1.25rem;padding:2rem;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.area-card h3{font-size:1.1rem;color:var(--wd);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.area-card h3 svg{width:18px;height:18px;stroke:var(--ac);flex-shrink:0}
.area-card ul{list-style:none}
.area-card li{display:flex;align-items:center;gap:.5rem;color:var(--wm);padding:.3rem 0;font-size:.9rem}
.area-card li svg{width:16px;height:16px;stroke:var(--ac);flex-shrink:0}

/* PACKAGES */
.cards-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:3rem}
@media(min-width:640px){.cards-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.cards-grid{grid-template-columns:repeat(3,1fr)}}
.pkg-card{background:#fff;border-radius:1.25rem;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.07);transition:box-shadow .3s,transform .3s}
.pkg-card:hover{box-shadow:0 12px 36px rgba(0,0,0,.12);transform:translateY(-4px)}
.pkg-card img{width:100%;height:200px;object-fit:cover}
.pkg-card-body{padding:1.5rem}
.pkg-card-body h3{color:var(--wd);margin-bottom:.5rem;font-size:1.2rem}
.pkg-card-body p{color:var(--wm);font-size:.9rem;line-height:1.6;margin-bottom:1rem}
.flist{list-style:none;margin-top:.75rem}
.flist li{display:flex;align-items:center;gap:.5rem;color:var(--wm);font-size:.875rem;padding:.2rem 0}
.flist li svg{width:14px;height:14px;stroke:var(--ac);flex-shrink:0}

/* CONSULTATION */
.consult-layout{display:grid;grid-template-columns:1fr;gap:3rem}
@media(min-width:1024px){.consult-layout{grid-template-columns:2fr 1fr}}
.form-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.form-grid{grid-template-columns:1fr 1fr}}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label{font-weight:600;color:var(--wd);font-size:.9rem}
.fg input,.fg select,.fg textarea{border:1.5px solid var(--wl);border-radius:.75rem;padding:.75rem 1rem;font-size:1rem;font-family:inherit;color:var(--wd);background:#fff;outline:none;transition:border-color .2s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--ac)}
.fg.err input,.fg.err select{border-color:#ef4444}
.fg .emsg{color:#ef4444;font-size:.8rem;display:none}
.fg.err .emsg{display:block}
.fg textarea{min-height:120px;resize:vertical}
.sidebar-card{border-radius:1.5rem;padding:2rem;margin-bottom:1.5rem}
.sidebar-dark{background:var(--wd);color:#fff}
.sidebar-white{background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.08)}
.sidebar-card h3{font-size:1.2rem;margin-bottom:1.5rem}
.sidebar-dark h3{color:#fff}
.sidebar-white h3{color:var(--wd)}
.srow{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}
.sicon{width:48px;height:48px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-dark .sicon{background:var(--ac)}
.sidebar-white .sicon{background:var(--cr)}
.sicon svg{width:20px;height:20px;stroke:var(--ac)}
.sidebar-dark .sicon svg{stroke:#fff}
.srow p{font-size:.85rem;opacity:.7}
.srow strong{display:block;font-weight:600}
.sidebar-white .srow strong{color:var(--wd)}

/* MODAL */
.modal-wrap{display:none;position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.5);align-items:center;justify-content:center;padding:1rem}
.modal-wrap.open{display:flex}
.modal-box{background:#fff;border-radius:1.5rem;padding:2.5rem;max-width:400px;width:100%;text-align:center;position:relative}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;cursor:pointer;font-size:1.2rem;color:#aaa}
.modal-icon{width:80px;height:80px;border-radius:50%;background:#dcfce7;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.modal-icon svg{width:40px;height:40px;stroke:#16a34a}
.modal-box h2{color:var(--wd);font-size:2rem;margin-bottom:.75rem}
.modal-box p{color:var(--wm)}

/* LIGHTBOX */
.lightbox{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.9);align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-height:85vh;max-width:90vw;object-fit:contain;border-radius:.75rem}
.lb-close,.lb-prev,.lb-next{position:absolute;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.lb-close{top:1rem;right:1rem}
.lb-prev{left:1rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1rem;top:50%;transform:translateY(-50%)}

/* FOOTER */
footer{background:var(--dk);color:#fff}
.footer-grid{max-width:1280px;margin:0 auto;padding:3rem 1.5rem;display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:640px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1.5fr}}
.footer-logo img{height:80px;width:auto;margin-bottom:1rem}
.footer-logo p{color:var(--wl);font-size:.875rem;line-height:1.6}
footer h4{font-size:1rem;margin-bottom:1rem;color:#fff;font-family:'Bebas Neue',cursive;letter-spacing:.08em}
footer ul{list-style:none}
footer ul li{margin-bottom:.5rem}
footer ul li a{color:var(--wl);font-size:.875rem;transition:color .2s}
footer ul li a:hover{color:var(--ac)}
footer ul li span{color:var(--wl);font-size:.875rem}
.fcontact li{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}
.fcontact li svg{width:16px;height:16px;stroke:var(--ac);flex-shrink:0;margin-top:2px}
.fcontact li a{color:var(--wl);font-size:.875rem;transition:color .2s}
.fcontact li a:hover{color:var(--ac)}
.footer-bottom{border-top:1px solid var(--wm);padding:1.5rem;text-align:center;color:var(--wl);font-size:.875rem}

/* SCROLL TOP */
.scroll-top{position:fixed;bottom:1.5rem;right:1.5rem;z-index:99;width:44px;height:44px;border-radius:50%;background:var(--ac);color:#fff;border:none;cursor:pointer;display:none;align-items:center;justify-content:center}
.scroll-top.show{display:flex}
.scroll-top:hover{background:var(--ad)}

/* FADE-UP ANIMATIONS */
.fu{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fu.vis{opacity:1;transform:none}
