:root{
  --bg:#0b0b0b;
  --panel:rgba(255,255,255,.06);
  --gold:#d4af37;
  --gold2:#f5e6a7;
  --text:#f4f4f4;
  --muted:#b9b9b9;
  --border:rgba(212,175,55,.28);
  --shadow:0 20px 60px rgba(0,0,0,.55);
  --radius:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Poppins',sans-serif;
  overflow-x:hidden;
}
a{color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 18px}
.section{padding:78px 0}
.mt{margin-top:14px}
.center{text-align:center;margin-top:18px}

.section-title{text-align:center;margin-bottom:34px}
.section-title h2{
  margin:0;
  font-family:'Playfair Display',serif;
  font-size:38px;
  color:var(--gold);
}
.section-title p{
  margin:10px auto 0;
  max-width:900px;
  color:var(--muted);
  font-size:14px;
  line-height:1.7;
}

/* ✅ Splash */
.splash{
  position:fixed; inset:0;
  background:rgba(0,0,0,.86);
  display:flex; align-items:center; justify-content:center;
  z-index:99999;
  padding:18px;
}
.splash.hidden{display:none}
.splash-card{
  width:min(520px, 92vw);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(212,175,55,.28);
  border-radius:22px;
  box-shadow:0 30px 120px rgba(0,0,0,.75);
  padding:22px;
  text-align:center;
  backdrop-filter: blur(14px);
}
.splash-logo{
  width:96px;height:96px;object-fit:contain;
  filter: drop-shadow(0 14px 45px rgba(212,175,55,.25));
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.06)}
}
.splash-title{
  margin-top:10px;
  font-family:'Playfair Display',serif;
  font-size:34px;
  color:var(--gold);
}
.splash-sub{opacity:.9;margin-top:6px}
.splash-btn{margin-top:14px}
.splash-note{margin-top:10px;color:var(--muted);font-size:12px}

/* Header */
.site-header{
  position:sticky; top:0; z-index:999;
  background:rgba(0,0,0,.68);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:12px}
.brand{display:flex;align-items:center;gap:12px;min-width:250px;text-decoration:none}
.brand-logo{width:54px;height:54px;object-fit:contain}
.brand-name{
  font-family:'Playfair Display',serif;
  font-size:22px;
  letter-spacing:1.5px;
  background:linear-gradient(90deg,var(--gold),#fff,var(--gold));
  -webkit-background-clip:text;
  color:transparent;
}
.brand-sub{font-size:12px;color:var(--muted)}

.nav{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:flex-end}
.nav a{
  text-decoration:none;
  color:var(--gold);
  font-weight:600;
  font-size:14px;
  transition:.25s;
  opacity:.95;
}
.nav a:hover{color:#fff;opacity:1}

.nav-toggle{
  display:none;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
}

/* Hero */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  border-bottom:1px solid var(--border);
}
.hero-slides{position:absolute;inset:0}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transform:scale(1.05);
  transition:opacity 1s ease, transform 1.6s ease;
  filter:saturate(1.05) contrast(1.02);
}
.hero-slide.active{opacity:1;transform:scale(1.0)}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.65), rgba(0,0,0,.85));
  z-index:1;
}
.hero-content{position:relative;z-index:2;padding:78px 0 54px}
.hero-title{
  margin:0;
  font-family:'Playfair Display',serif;
  font-size:54px;
  line-height:1.05;
  background:linear-gradient(90deg,var(--gold),#fff,var(--gold));
  -webkit-background-clip:text;
  color:transparent;
  text-shadow:0 12px 55px rgba(0,0,0,.55);
}
.hero-desc{margin:14px 0 0;color:#e9e9e9;max-width:820px;font-size:18px}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.badge{
  font-size:12px;color:#f1f1f1;
  padding:7px 10px;border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px;align-items:center}

/* Search box */
.searchbox{
  margin-top:20px;
  max-width:820px;
  display:flex;gap:10px;flex-wrap:wrap;
  padding:12px;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  backdrop-filter:blur(10px);
}
.searchbox input{
  flex:1;min-width:220px;
  border:none;outline:none;
  background:transparent;color:#fff;
  font-size:14px;padding:10px 12px;
}
.searchbox select{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.35);
  color:#fff;border-radius:12px;
  padding:10px 12px;outline:none;
}

/* Buttons */
.btn{
  border:none;
  cursor:pointer;
  padding:12px 18px;
  border-radius:12px;
  font-weight:700;
  transition:.25s;
  display:inline-flex;align-items:center;gap:10px;
  text-decoration:none;
}
.btn-primary{
  background:linear-gradient(90deg,var(--gold),var(--gold2));
  color:#111;
  box-shadow:0 12px 30px rgba(212,175,55,.18);
}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  color:#fff;
}
.btn-ghost:hover{transform:translateY(-2px);background:rgba(255,255,255,.08)}

/* Cards */
.two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:stretch}
.grid-cards{display:grid;grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));gap:16px}
.card-link{ text-decoration:none; color:inherit; }
.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(14px);
  transition:.3s;
}
.card:hover{transform:translateY(-6px)}
.card h3{margin:0 0 8px;color:#fff;font-size:16px;font-weight:700}
.card p{margin:0;color:var(--muted);font-size:13px;line-height:1.65}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}
.stat{
  padding:14px;border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
}
.stat-num{display:block;color:var(--gold);font-size:18px;font-weight:800}
.stat-text{color:var(--muted);font-size:12px}

/* Chips */
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.28);
  font-size:12px;color:#eaeaea;
}
.note{margin-top:12px;color:var(--muted);font-size:13px;line-height:1.6}
.muted{color:var(--muted)}

/* Preview Gallery (crop fixed) */
.preview-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:14px;
  margin-top:18px;
}
.preview-gallery img{
  width:100%;
  height:180px;
  object-fit:cover;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  transition:.25s;
}
.preview-gallery img:hover{
  transform:translateY(-6px);
  border-color:rgba(212,175,55,.45);
}

/* Contact */
.contact-form { margin-top: 14px; }
.form-grid{ display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:14px; }
.form-field label{ display:block; margin-bottom:6px; opacity:.85; font-weight:700; }
.form-field input, .form-field select, .form-field textarea{
  width:100%; padding:12px 12px; border-radius:12px;
  border:1px solid rgba(212,175,55,0.22);
  background: rgba(0,0,0,0.35); color:#fff; outline:none;
}
.form-field textarea{ resize: vertical; }
.form-field.full{ grid-column:1/-1; }
.map{width:100%;height:280px;border:0;border-radius:16px;overflow:hidden;margin-top:14px;}
.link{color:var(--gold);text-decoration:none}
.link:hover{color:#fff}

/* Footer */
.footer{
  padding:26px 0;
  border-top:1px solid rgba(255,255,255,.08);
  color:var(--muted);
  font-size:12px;
  background:#070707;
}
.footer-inner{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}
.footer-links a{color:var(--gold);text-decoration:none}
.footer-links a:hover{color:#fff}

/* ✅ Social FAB (radial) */
.social-fab{
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 64px;
  height: 64px;
  z-index: 9999;
}
.social-fab .toggle{
  width:64px; height:64px; border-radius:50%;
  border:1px solid rgba(212,175,55,0.35);
  background: rgba(0,0,0,0.70);
  color:#d4af37; font-size:24px; cursor:pointer;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  transition: transform .4s ease;
}
.social-fab.active .toggle{ transform: rotate(360deg); }
.social-fab .item{
  position:absolute;
  left:50%; top:50%;
  transform: translate(-50%, -50%);
  width:52px; height:52px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; font-weight:900; font-size:14px;
  border:1px solid rgba(212,175,55,0.25);
  background: rgba(255,255,255,0.08);
  color:#fff;
  opacity:0; pointer-events:none;
  transition: transform .45s ease, opacity .35s ease;
}
.social-fab.active .item{ opacity:1; pointer-events:auto; }
.social-fab.active .wa   { transform: translate(-50%, -50%) translate(-95px,  0px); }
.social-fab.active .call { transform: translate(-50%, -50%) translate(-70px, -70px); }
.social-fab.active .ig   { transform: translate(-50%, -50%) translate( 0px,  -95px); }
.social-fab.active .fb   { transform: translate(-50%, -50%) translate(-70px,  70px); }
.social-fab.active .yt   { transform: translate(-50%, -50%) translate( 0px,   95px); }
.social-fab .wa{ background: rgba(37,211,102,0.18); }
.social-fab .ig{ background: rgba(225,48,108,0.18); }
.social-fab .fb{ background: rgba(24,119,242,0.18); }
.social-fab .yt{ background: rgba(255,0,0,0.18); }
.social-fab .call{ background: rgba(212,175,55,0.16); }

/* Responsive */
@media(max-width:980px){
  .two-col{grid-template-columns:1fr}
  .hero-title{font-size:42px}
  .nav-toggle{display:inline-flex}
  .nav{
    display:none;
    flex-direction:column;
    align-items:flex-start;
    background:rgba(0,0,0,.85);
    padding:12px;
    border:1px solid var(--border);
    border-radius:16px;
  }
  .nav.open{display:flex}
}
@media (max-width: 720px){
  .form-grid{ grid-template-columns: 1fr; }
}
@media(max-width:520px){
  .hero-title{font-size:36px}
  .social-fab{ right: 14px; bottom: 14px; }
}
