:root{
  --gold:#c9a76b;
  --gold-d:#a8854a;
  --brown:#2b1d14;
  --brown-2:#473023;
  --cream:#fbf6ee;
  --beige:#f3ead7;
  --text:#2b1d14;
  --muted:#6b5a4d;
  --white:#ffffff;
  --shadow:0 12px 40px rgba(43,29,20,.12);
  --grad:linear-gradient(135deg,#c9a76b,#e7c98f);
  --grad-d:linear-gradient(135deg,#a8854a,#c9a76b);
  --font-h:'Playfair Display',serif;
  --font-b:'Poppins',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--text);background:var(--white);line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-h);font-weight:700;color:var(--brown);line-height:1.2}
h1{font-size:clamp(2.2rem,4.5vw,4rem)}
h2{font-size:clamp(1.8rem,3.2vw,2.8rem)}
h3{font-size:1.35rem}
.container{max-width:1240px;margin:0 auto;padding:0 22px}
.section{padding:90px 0;position:relative}
.section.alt{background:var(--cream)}
.eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold-d);font-weight:600;margin-bottom:14px}
.eyebrow:before{content:"";display:inline-block;width:30px;height:2px;background:var(--gold);vertical-align:middle;margin-right:10px}
.muted{color:var(--muted)}
.btn{display:inline-block;padding:14px 30px;border-radius:50px;font-weight:600;letter-spacing:.05em;cursor:pointer;border:none;transition:.3s;font-size:.92rem;text-transform:uppercase}
.btn-gold{background:var(--grad);color:var(--brown);box-shadow:0 10px 25px rgba(201,167,107,.45)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 15px 35px rgba(201,167,107,.6);background:var(--grad-d);color:#fff}
.btn-out{background:transparent;border:2px solid var(--gold);color:var(--gold-d)}
.btn-out:hover{background:var(--gold);color:#fff}

/* HEADER */
.topbar{background:var(--brown);color:#e8d7c0;font-size:.82rem;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.topbar a{color:#e8d7c0;margin-left:14px}
.topbar a:hover{color:var(--gold)}
header.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);box-shadow:0 4px 30px rgba(0,0,0,.06)}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo img{height:62px}
.nav-links{display:flex;gap:34px;align-items:center;list-style:none}
.nav-links a{font-weight:500;font-size:.95rem;color:var(--brown);position:relative;padding:6px 0}
.nav-links a:after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:.3s}
.nav-links a:hover:after,.nav-links a.active:after{width:100%}
.nav-links a.active{color:var(--gold-d)}
.has-drop{position:relative}
.drop{position:absolute;top:100%;left:-20px;background:#fff;min-width:230px;border-radius:12px;box-shadow:var(--shadow);padding:12px 0;opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s;border-top:3px solid var(--gold)}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{display:block;padding:10px 22px;font-size:.9rem}
.drop a:hover{background:var(--cream);color:var(--gold-d);padding-left:30px}
.burger{display:none;font-size:1.6rem;background:none;border:none;color:var(--brown);cursor:pointer}

/* HERO SLIDER */
.hero{position:relative;height:88vh;min-height:560px;overflow:hidden}
.swiper.hero-sw,.swiper.hero-sw .swiper-slide{height:100%}
.hero-slide{position:relative;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:kenburns 12s ease-in-out infinite alternate}
@keyframes kenburns{0%{transform:scale(1)}100%{transform:scale(1.15)}}
.hero-slide:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(43,29,20,.55),rgba(43,29,20,.75))}
.hero-content{position:relative;z-index:2;max-width:880px;padding:0 24px}
.hero-content h1{color:#fff;margin-bottom:18px;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.hero-content p{font-size:1.15rem;color:#f3e7d2;margin-bottom:30px}
.hero-content .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.swiper-pagination-bullet{background:#fff!important;opacity:.5}
.swiper-pagination-bullet-active{background:var(--gold)!important;opacity:1;width:30px;border-radius:5px}

/* FEATURE STRIP */
.fstrip{background:var(--brown);color:#fff;padding:30px 0}
.fstrip-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.fstrip i{font-size:2rem;color:var(--gold);margin-bottom:8px}
.fstrip h4{color:#fff;font-size:1rem;font-family:var(--font-b);font-weight:600}
.fstrip span{color:#bfa78a;font-size:.85rem}

/* ABOUT / SPLIT */
.split{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.split-img{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.split-img img{width:100%;height:520px;object-fit:cover;transition:1s}
.split-img:hover img{transform:scale(1.06)}
.split-img:before{content:"";position:absolute;inset:0;border:2px solid var(--gold);border-radius:18px;transform:translate(20px,20px);z-index:-1}
.split-img.deco{padding:20px}
.split p{margin:14px 0}
.split ul{list-style:none;margin-top:18px}
.split ul li{padding:8px 0 8px 32px;position:relative;color:var(--text)}
.split ul li:before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;left:0;color:var(--gold-d);background:var(--beige);width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem}

/* HEADING */
.s-head{text-align:center;max-width:680px;margin:0 auto 60px}
.s-head p{color:var(--muted);margin-top:10px}

/* SERVICES GRID */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}
.svc{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 8px 30px rgba(43,29,20,.08);transition:.4s;position:relative;border:1px solid #f0e6d2}
.svc:hover{transform:translateY(-12px);box-shadow:0 20px 50px rgba(43,29,20,.18)}
.svc-img{height:230px;overflow:hidden;position:relative}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:.8s}
.svc:hover .svc-img img{transform:scale(1.1)}
.svc-img:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(43,29,20,.55))}
.svc-body{padding:26px}
.svc h3{margin-bottom:8px}
.svc .more{color:var(--gold-d);font-weight:600;font-size:.88rem;margin-top:14px;display:inline-block;letter-spacing:.05em}
.svc .more:after{content:" →";transition:.3s}
.svc:hover .more:after{margin-left:6px}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:26px}
.why{background:#fff;border-radius:16px;padding:32px 24px;text-align:center;box-shadow:0 6px 20px rgba(43,29,20,.06);transition:.4s;border-top:3px solid transparent}
.why:hover{border-top-color:var(--gold);transform:translateY(-8px)}
.why .icon{width:70px;height:70px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:#fff;margin:0 auto 16px;box-shadow:0 8px 20px rgba(201,167,107,.4)}

/* TESTIMONIALS */
.t-sw{padding:30px 10px 60px!important}
.t-card{background:#fff;border-radius:18px;padding:36px 30px;box-shadow:var(--shadow);text-align:center;border:1px solid #f0e6d2;position:relative}
.t-card:before{content:"\201C";font-family:var(--font-h);position:absolute;top:-30px;left:30px;font-size:6rem;color:var(--gold);opacity:.4;line-height:1}
.t-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto 14px;border:3px solid var(--gold)}
.t-card p{font-style:italic;color:var(--muted);margin-bottom:14px}
.t-card h4{font-family:var(--font-b);font-size:1rem;color:var(--brown);font-weight:600}
.t-card .stars{color:#f5b301;margin-top:6px}

/* GALLERY */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gal a{border-radius:14px;overflow:hidden;display:block;position:relative}
.gal img{height:280px;width:100%;object-fit:cover;transition:.8s}
.gal a:hover img{transform:scale(1.15)}
.gal a:after{content:"\f00e";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;inset:0;background:rgba(43,29,20,.5);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.6rem;opacity:0;transition:.3s}
.gal a:hover:after{opacity:1}

/* CTA BAND */
.cta{background:linear-gradient(rgba(43,29,20,.85),rgba(43,29,20,.92)),url('../assets/hero3.jpg') center/cover;color:#fff;text-align:center;padding:90px 0}
.cta h2{color:#fff;margin-bottom:14px}
.cta p{color:#e8d7c0;margin-bottom:26px;max-width:600px;margin-left:auto;margin-right:auto}

/* CONTACT */
.c-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.c-info{background:var(--cream);padding:40px;border-radius:18px}
.c-info .row{display:flex;gap:18px;margin-bottom:22px;align-items:flex-start}
.c-info .icn{min-width:46px;height:46px;background:var(--grad);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center}
form.cf input,form.cf textarea{width:100%;padding:14px 18px;border:1px solid #e0d3b8;border-radius:10px;font-family:inherit;margin-bottom:14px;background:#fff;font-size:.95rem;transition:.3s}
form.cf input:focus,form.cf textarea:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 3px rgba(201,167,107,.15)}
form.cf textarea{min-height:130px;resize:vertical}
.form-msg{margin-top:10px;padding:10px;border-radius:8px;display:none}
.form-msg.ok{background:#e6f7e8;color:#1e7d32;display:block}
.form-msg.err{background:#fde7e9;color:#b3261e;display:block}

/* FOOTER */
footer{background:var(--brown);color:#bfa78a;padding:70px 0 0}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
footer h4{color:#fff;font-family:var(--font-b);font-weight:600;font-size:1.05rem;margin-bottom:18px;position:relative;padding-bottom:10px}
footer h4:after{content:"";position:absolute;left:0;bottom:0;width:36px;height:2px;background:var(--gold)}
footer ul{list-style:none}
footer li{padding:6px 0;font-size:.92rem}
footer a:hover{color:var(--gold)}
.f-soc a{display:inline-flex;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);align-items:center;justify-content:center;margin-right:8px;color:#fff;transition:.3s}
.f-soc a:hover{background:var(--gold);transform:translateY(-3px)}
.f-bot{border-top:1px solid rgba(255,255,255,.08);margin-top:50px;padding:18px 0;text-align:center;font-size:.85rem}

/* PAGE BANNER */
.pbanner{background:linear-gradient(rgba(43,29,20,.7),rgba(43,29,20,.8)),url('../assets/hero1.jpg') center/cover;color:#fff;text-align:center;padding:130px 0 90px;margin-bottom:0}
.pbanner h1{color:#fff}
.crumb{color:#e8d7c0;margin-top:10px;font-size:.9rem;letter-spacing:.1em}
.crumb a{color:var(--gold)}

/* FLOATING */
.fab{position:fixed;right:20px;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;box-shadow:0 10px 30px rgba(0,0,0,.25);z-index:90;animation:pulse 2s infinite}
.fab.wa{background:#25d366;bottom:90px}
.fab.call{background:var(--gold-d);bottom:160px}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.side-tab{position:fixed;right:0;top:45%;transform:translateY(-50%) rotate(-90deg);transform-origin:right top;background:var(--grad);color:var(--brown);padding:10px 24px;font-weight:700;border-radius:6px 6px 0 0;cursor:pointer;letter-spacing:.1em;font-size:.78rem;z-index:90;box-shadow:0 -4px 15px rgba(0,0,0,.15);text-transform:uppercase}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(43,29,20,.7);display:none;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fadeIn .3s}
.modal.show{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.mbox{background:#fff;border-radius:18px;max-width:480px;width:100%;padding:40px 34px;position:relative;animation:scaleIn .3s;border-top:5px solid var(--gold)}
@keyframes scaleIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.mbox .x{position:absolute;top:14px;right:18px;background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--brown)}
.mbox h3{font-size:1.6rem;margin-bottom:6px;text-align:center}
.mbox .sub{text-align:center;color:var(--muted);margin-bottom:22px;font-size:.9rem}

/* FAQ */
.faq{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border-radius:12px;margin-bottom:14px;box-shadow:0 4px 15px rgba(0,0,0,.05);overflow:hidden}
.faq-q{padding:18px 24px;cursor:pointer;font-weight:600;display:flex;justify-content:space-between;align-items:center;color:var(--brown)}
.faq-q i{transition:.3s;color:var(--gold)}
.faq-item.open .faq-q i{transform:rotate(180deg)}
.faq-a{padding:0 24px;max-height:0;overflow:hidden;transition:.4s;color:var(--muted)}
.faq-item.open .faq-a{padding:0 24px 22px;max-height:300px}

/* RESPONSIVE */
@media(max-width:900px){
  .nav-links{position:fixed;top:0;right:-100%;flex-direction:column;background:#fff;width:280px;height:100vh;padding:80px 30px;box-shadow:-10px 0 30px rgba(0,0,0,.1);transition:.4s;align-items:flex-start;gap:18px}
  .nav-links.open{right:0}
  .burger{display:block}
  .has-drop .drop{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;padding-left:18px;display:none}
  .has-drop.open .drop{display:block}
  .split{grid-template-columns:1fr;gap:40px}
  .split.rev{direction:ltr}
  .split-img img{height:380px}
  .fstrip-row{grid-template-columns:repeat(2,1fr);gap:18px}
  .c-grid{grid-template-columns:1fr}
  .f-grid{grid-template-columns:1fr 1fr;gap:30px}
  .gal{grid-template-columns:repeat(2,1fr)}
  .section{padding:60px 0}
  .hero{height:80vh}
}
@media(max-width:560px){
  .f-grid,.gal{grid-template-columns:1fr}
  .fstrip-row{grid-template-columns:1fr 1fr}
  .gal img{height:220px}
}
