html,body{max-width:100vw;overflow-x:clip}
/* =========================================
   Full House Staging — Main Styles (v1.0.0)
   Based 1:1 on provided HTML/CSS, with hero text visibility fixes.
   ========================================= */

/* 1. VARIABLES & RESET */
:root {
    --fhs-logo-maxw: 260px; /* prevents overflow */
  --royal-blue:#001530;
  --royal-dark:#000c1c;
  --gold:#C5A059;
  --gold-hover:#D4AF37;
  --gold-gradient:linear-gradient(135deg,#b08d48 0%,#E6C786 50%,#b08d48 100%);

  --white:#ffffff;
  --offwhite:#f8f9fa;
  --text-dark:#1a1a1a;
  --text-light:#666666;
  --text-gray:#888888;

  --font-heading:'Playfair Display',serif;
  --font-body:'Manrope',sans-serif;

  --transition-slow:all .6s cubic-bezier(.22,1,.36,1);
  --transition-fast:all .3s ease;

  --container-width:1320px;
  --shadow-luxury:0 20px 80px rgba(0,0,0,.15);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-body);
  background-color:var(--white);
  color:var(--text-dark);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* 2. TYPOGRAPHY & UTILS */
h1,h2,h3,h4,h5{font-family:var(--font-heading);color:var(--royal-blue);line-height:1.1;font-weight:500}
h1{font-size:clamp(3rem,5vw,5.5rem);color:var(--white)}
.lux-title{font-size:clamp(2.5rem,4vw,4rem);margin-bottom:2rem}

.text-gold{color:var(--gold)}
.text-white{color:var(--white)}
.text-light{color:rgba(255,255,255,.7)}
.italic-font{font-style:italic;font-weight:400}

.overline{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.3em;color:var(--gold);margin-bottom:1rem;font-weight:700}
.bg-white{background:var(--white)}
.bg-offwhite{background:var(--offwhite)}
.bg-royal{background:var(--royal-blue);color:var(--white)}
.bg-royal-dark{background:var(--royal-dark)}
.mt-4{margin-top:2rem}
.mt-5{margin-top:3rem;display:inline-block}
.mb-4{margin-bottom:2rem}
.mb-5{margin-bottom:3rem}
.text-center{text-align:center}

.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}

/* 3. BUTTONS */
.btn-solid-gold{
  display:inline-block;padding:18px 40px;background:var(--gold-gradient);color:var(--royal-blue);
  text-transform:uppercase;font-size:.8rem;font-weight:700;letter-spacing:.15em;
  text-decoration:none;transition:var(--transition-fast);border:none;cursor:pointer;
}
.btn-solid-gold:hover{transform:translateY(-3px);box-shadow:0 15px 30px rgba(197,160,89,.3)}

.btn-outline-gold{
  display:inline-block;padding:16px 35px;background:transparent;border:1px solid var(--gold);
  color:var(--gold);text-transform:uppercase;font-size:.75rem;font-weight:700;letter-spacing:.15em;
  text-decoration:none;transition:var(--transition-fast);
}
.btn-outline-gold:hover{background:var(--gold);color:var(--royal-blue)}

.btn-glass{
  display:inline-block;padding:18px 40px;background:rgba(255,255,255,.05);color:var(--white);
  border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(10px);
  text-transform:uppercase;font-size:.8rem;font-weight:700;letter-spacing:.15em;
  text-decoration:none;transition:var(--transition-fast);
}
.btn-glass:hover{background:var(--white);color:var(--royal-blue)}

.link-gold{display:inline-flex;align-items:center;color:var(--gold);text-decoration:none;text-transform:uppercase;font-size:.85rem;font-weight:700;letter-spacing:.1em;transition:var(--transition-fast)}
.link-gold i{margin-left:10px;transition:.3s}
.link-gold:hover i{transform:translateX(5px)}

/* 4. NAVIGATION */
.navbar{
  position:fixed;top:0;left:0;width:100%;
  z-index:1000;padding:20px 0;transition:var(--transition-slow);
  background:linear-gradient(180deg,rgba(0,21,48,.8) 0%,transparent 100%);
}
.navbar.scrolled{
  background:rgba(0,21,48,.95);
  padding:15px 0;
  backdrop-filter:blur(15px);
  border-bottom:1px solid rgba(255,255,255,.05);
  box-shadow:0 5px 20px rgba(0,0,0,.2);
}

.nav-wrapper{display:flex;justify-content:space-between;align-items:center}
.brand-logo{display:flex;align-items:center}

/* WP custom logo output wraps image in <a><img>... so target both */
.brand-logo img,
.brand-logo .custom-logo{ 
  height:var(--fhs-logo-h-desktop, 50px); filter:brightness(0) invert(1); transition:.3s; display:block; 
  width:auto !important;
  max-width: min(var(--fhs-logo-maxw, 260px), 48vw);
  object-fit: contain;
  object-position: left center;
}
.navbar.scrolled .brand-logo img,
.navbar.scrolled .brand-logo .custom-logo{height:var(--fhs-logo-h-desktop-scrolled, 45px)}

.nav-links-desktop{display:flex;gap:40px}
.nav-links-desktop a,
.nav-links-desktop li a{
  color:rgba(255,255,255,.8);text-decoration:none;text-transform:uppercase;font-size:.75rem;
  letter-spacing:.15em;font-weight:600;transition:.3s;position:relative;
}
.nav-links-desktop li{list-style:none}
.nav-links-desktop a::after,
.nav-links-desktop li a::after{
  content:'';position:absolute;bottom:-5px;left:0;width:0;height:1px;background:var(--gold);transition:.3s
}
.nav-links-desktop a:hover,
.nav-links-desktop li a:hover{color:var(--gold)}
.nav-links-desktop a:hover::after,
.nav-links-desktop li a:hover::after{width:100%}

.nav-actions{display:flex;align-items:center;gap:30px}
.phone-link{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--white)}
.phone-icon{
  width:35px;height:35px;border-radius:50%;
  border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);transition:.3s;
}
.phone-number{font-weight:600;font-size:.9rem;letter-spacing:1px}
.phone-link:hover .phone-icon{background:var(--gold);color:var(--royal-blue)}

.menu-toggle{display:none;cursor:pointer;flex-direction:column;gap:6px;z-index:2001}
.menu-toggle .line{width:30px;height:2px;background:var(--white);transition:.3s}

/* 5. FLOATING BUTTONS */
.floating-call-btn{
  position:fixed;bottom:30px;left:30px;width:60px;height:60px;background:var(--gold-gradient);
  border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--royal-blue);
  font-size:1.5rem;box-shadow:0 10px 20px rgba(0,0,0,.3);z-index:990;text-decoration:none;
  transition:var(--transition-fast);opacity:0;visibility:hidden;transform:translateY(20px)
}
.floating-call-btn.visible{opacity:1;visibility:visible;transform:translateY(0)}
.floating-call-btn:hover{transform:scale(1.1);color:var(--white)}
.call-pulse{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid var(--gold);animation:pulse 2s infinite;opacity:0}
@keyframes pulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.8);opacity:0}}

.back-to-top{
  position:fixed;bottom:30px;right:30px;width:50px;height:50px;background:var(--royal-blue);
  border:1px solid rgba(255,255,255,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--gold);
  font-size:1.2rem;cursor:pointer;z-index:990;transition:var(--transition-fast);text-decoration:none;
  opacity:0;visibility:hidden;transform:translateY(20px)
}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--gold);color:var(--royal-blue)}

/* 6. HERO SECTION */
.hero-section{
  position:relative;height:100vh;width:100%;overflow:hidden;
  display:flex;align-items:center;background:var(--royal-dark);
}
.hero-slider,.hero-slide{position:absolute;top:0;left:0;width:100%;height:100%}
.hero-overlay{
  position:absolute;top:0;left:0;width:100%;height:100%;
  z-index:2;
  background:radial-gradient(circle at 70% 50%,rgba(0,21,48,.2) 0%,rgba(0,21,48,.85) 100%);
}
.hero-slide{
  background-size:cover;background-position:center;opacity:0;transform:scale(1.05);
  transition:opacity 1.5s ease-in-out, transform 8s linear;z-index:1;
}
.hero-slide.active{opacity:1;transform:scale(1)}

/* IMPORTANT FIX: ensure hero content sits above overlay */
.hero-container{position:relative;z-index:3;width:100%}
.hero-content{max-width:820px}
.social-proof-badge{
  display:inline-flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  padding:12px 16px;border-radius:999px;
  backdrop-filter:blur(12px);
  margin-bottom:22px;
}
.social-proof-badge span{color:rgba(255,255,255,.88);font-size:.95rem}
.social-proof-badge strong{color:var(--white)}
.stars{color:#FFD700;font-size:.8rem;margin-bottom:2px}

.hero-sub{font-size:1.25rem;color:rgba(255,255,255,.85);margin-bottom:45px;max-width:600px;font-weight:300}
.hero-btns{display:flex;gap:20px}

/* Scroll indicator right */
.scroll-indicator-right{
  position:absolute;bottom:50px;right:50px;z-index:10;
  display:flex;flex-direction:column;align-items:center;gap:15px;text-decoration:none;
}
.scroll-text{
  color:white;font-size:.65rem;text-transform:uppercase;letter-spacing:.2em;
  writing-mode:vertical-rl;transform:rotate(180deg);
}
.scroll-line{width:1px;height:60px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold);animation:drop 2s infinite}
@keyframes drop{100%{top:100%}}

/* 7. TRUST STRIP */
.trust-strip{background:var(--white);padding:30px 0;border-bottom:1px solid #eee}
.trust-wrapper{display:flex;justify-content:center;gap:60px;flex-wrap:wrap}
.trust-item{
  font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--royal-blue);
  display:flex;align-items:center;gap:10px;
}
.trust-item i{color:var(--gold);font-size:1.2rem}

/* 8. PHILOSOPHY */
.section-padding{padding:120px 0}
.split-layout{display:flex;align-items:center;gap:80px}
.reverse-layout{flex-direction:row-reverse}
.split-text{flex:1}
.split-image{flex:1;position:relative}

.lead-text{font-size:1.35rem;font-weight:300;margin-bottom:30px;color:var(--text-dark)}
.body-text{font-size:1rem;color:inherit}
.highlight-quote{border-left:4px solid var(--gold);padding-left:25px;margin:30px 0;font-style:italic;color:var(--text-gray);font-size:1.1rem}

.img-wrapper{position:relative;padding:20px;border:1px solid rgba(0,0,0,.1)}
.img-wrapper img{width:100%;display:block;box-shadow:var(--shadow-luxury)}
.floating-badge{
  position:absolute;bottom:-20px;left:-20px;background:var(--white);padding:20px 30px;
  box-shadow:var(--shadow-luxury);display:flex;align-items:center;gap:15px;font-weight:700;
  text-transform:uppercase;font-size:.8rem;letter-spacing:2px;color:var(--royal-blue);
}

/* 10. PORTFOLIO */
.portfolio-section{background-color:var(--royal-blue);color:var(--white)}
.section-header{margin-bottom:80px}

.lux-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:60px}
.gallery-item{position:relative;height:450px;overflow:hidden;display:block;text-decoration:none}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item::after{
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  background:linear-gradient(0deg,rgba(0,21,48,.9) 0%,transparent 80%);transition:.4s
}
.gallery-content{position:absolute;bottom:0;left:0;padding:40px;z-index:2;transform:translateY(20px);transition:.4s;opacity:.9}
.gallery-cat{display:block;color:var(--gold);text-transform:uppercase;font-size:.75rem;letter-spacing:.2em;font-weight:700;margin-bottom:10px}
.gallery-item h3{color:var(--white);font-size:2rem;margin:0}

.gallery-item:hover img{transform:scale(1.05)}
.gallery-item:hover .gallery-content{transform:translateY(0);opacity:1}
.gallery-item:hover::after{background:linear-gradient(0deg,rgba(0,21,48,1) 0%,transparent 60%)}

/* 11. INVENTORY counters */
.number-grid{display:flex;gap:40px;margin-top:40px;flex-wrap:wrap}
.num-box{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.1);padding:24px 24px;min-width:220px}
.big-num{font-family:var(--font-heading);font-size:3rem;color:var(--white);line-height:1}
.num-label{display:block;margin-top:8px;text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:rgba(255,255,255,.65)}

/* 12. PROCESS GRID */
.step-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:60px}
.step-card{
  padding:40px 30px;background:var(--white);box-shadow:var(--shadow-luxury);
  transition:var(--transition-fast);text-align:center;border-bottom:3px solid transparent
}
.step-card:hover{transform:translateY(-10px);border-color:var(--gold)}
.step-num{font-family:var(--font-heading);font-size:3rem;color:var(--offwhite);font-weight:700;line-height:1;margin-bottom:20px;transition:.4s}
.step-card:hover .step-num{color:var(--gold)}
.step-card h4{font-size:1.3rem;margin-bottom:15px}
.step-card p{font-size:.9rem;color:var(--text-light)}

/* 13. CONTACT & MAP */
.contact-section{width:100%;background:var(--offwhite);display:block;position:relative;overflow:hidden}
.contact-grid{display:flex;flex-direction:row;width:100%;min-height:600px;margin:0;align-items:stretch}
.contact-info{flex:0 0 50%;width:50%;background:var(--royal-blue);padding:100px 5vw;display:flex;flex-direction:column;justify-content:center}
.contact-inner{max-width:500px;margin-left:auto;margin-right:20px;width:100%}

.contact-list{margin-top:40px}
.c-item{display:flex;gap:20px;margin-bottom:30px}
.c-item i{font-size:1.5rem;margin-top:5px}
.c-item h6{
  font-family:var(--font-body);text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;
  color:rgba(255,255,255,.5);margin-bottom:5px
}
.c-item p,.link-white{font-size:1.1rem;color:var(--white);text-decoration:none;transition:.3s}
.link-white:hover{color:var(--gold)}

.contact-map{flex:0 0 50%;width:50%;position:relative;min-height:100%}
.contact-map iframe{
  position:absolute;top:0;left:0;width:100%;height:100%;
  border:none;filter:grayscale(100%) invert(90%) contrast(85%);transition:filter .5s ease
}
.contact-map:hover iframe{filter:grayscale(0%)}

/* 14. FOOTER */
.footer{
  background:#080808;padding:80px 0 40px;text-align:center;
  border-top:1px solid rgba(255,255,255,.05)
}
.footer-content{display:flex;flex-direction:column;align-items:center}
.footer-logos{display:flex;gap:40px;align-items:center;justify-content:center;margin-bottom:40px;flex-wrap:wrap}
.footer-logos img{max-height:50px;filter:grayscale(100%) brightness(.6);transition:var(--transition-fast)}
.footer-logos img:hover{filter:grayscale(0%) brightness(1)}
.footer-divider{width:100%;max-width:300px;height:1px;background:rgba(255,255,255,.1);margin:0 auto 30px}
.footer-socials{margin-bottom:30px}
.footer-socials a{font-size:1.5rem;margin:0 15px;color:var(--white);opacity:.5;transition:.3s}
.footer-socials a:hover{opacity:1;color:var(--gold);transform:translateY(-3px)}
.footer-legal p{margin-bottom:15px;font-size:.85rem;color:rgba(255,255,255,.6)}

/* 15. OFFCANVAS */
.offcanvas-menu{
  position:fixed;top:0;right:-100%;
  width:85%;max-width:350px;height:100vh;background:var(--royal-blue);z-index:2000;
  transition:right .4s cubic-bezier(.77,0,.175,1);
  box-shadow:-10px 0 30px rgba(0,0,0,.3);
  padding:30px;display:flex;flex-direction:column;justify-content:space-between
}
.offcanvas-menu.active{right:0}
.offcanvas-backdrop{
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:1999;
  opacity:0;visibility:hidden;transition:all .3s ease
}
.offcanvas-backdrop.active{opacity:1;visibility:visible}
.offcanvas-close{align-self:flex-end;font-size:1.5rem;color:var(--gold);cursor:pointer;margin-bottom:40px;padding:10px}
.offcanvas-links{display:flex;flex-direction:column;gap:25px}
.offcanvas-links a{
  font-family:var(--font-heading);font-size:1.8rem;color:var(--white);text-decoration:none;transition:.3s;
  border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:10px
}
.offcanvas-links a:hover{color:var(--gold);padding-left:10px}

/* RESPONSIVE */
@media (max-width:1280px){
  .brand-logo img,
  .brand-logo .custom-logo{height:var(--fhs-logo-h-laptop, 48px)}
  .navbar.scrolled .brand-logo img,
  .navbar.scrolled .brand-logo .custom-logo{height:var(--fhs-logo-h-laptop-scrolled, 43px)}
}

@media (max-width:1024px){
  .brand-logo img,
  .brand-logo .custom-logo{height:var(--fhs-logo-h-tablet, 42px)}
  .navbar.scrolled .brand-logo img,
  .navbar.scrolled .brand-logo .custom-logo{height:var(--fhs-logo-h-tablet-scrolled, 38px)}

  .split-layout{flex-direction:column;gap:50px}
  .reverse-layout{flex-direction:column}
  .split-image{width:100%}
  .lux-gallery{grid-template-columns:1fr}
  .step-grid{grid-template-columns:repeat(2,1fr)}

  .contact-grid{flex-direction:column;min-height:auto}
  .contact-info,.contact-map{flex:0 0 100%;width:100%}
  .contact-info{padding:80px 30px}
  .contact-inner{margin:0 auto;text-align:left}
  .contact-map{height:500px;min-height:500px}
}
@media (max-width:768px){
  .nav-wrapper{display:flex!important;justify-content:space-between!important;align-items:center!important;width:100%;padding:0 15px}
  .nav-links-desktop,.nav-actions .phone-link,.nav-actions .btn-outline-gold{display:none!important}
  .nav-actions{gap:0!important;margin:0!important;padding:0!important}
  .menu-toggle{display:flex!important;flex-direction:column;gap:6px;cursor:pointer;z-index:1001}
  .menu-toggle .line{width:30px;height:2px;background:var(--white);transition:.3s}

  .brand-logo img,.brand-logo .custom-logo{height:var(--fhs-logo-h-mobile, 38px)!important}
  .navbar.scrolled .brand-logo img,.navbar.scrolled .brand-logo .custom-logo{height:var(--fhs-logo-h-mobile-scrolled, 34px)!important}

  .hero-content{padding:0 20px;text-align:left;margin-top:60px}
  h1{font-size:2.8rem}
  .hero-btns{flex-direction:column;width:100%}
  .btn-solid-gold,.btn-glass{width:100%;text-align:center;padding:16px 0;margin-left:0}

  .scroll-indicator-right{display:none}
  .trust-wrapper{flex-direction:column;gap:15px;text-align:center}

  .section-padding{padding:80px 0}
  .step-grid{grid-template-columns:1fr}
  .contact-info{padding:60px 20px}

  .footer-logos{flex-direction:column;gap:30px}
  .footer-logos img{max-height:45px}
}


/* ===== MOBILE FIXES 1.0.5 ===== */
@media (max-width:768px){

  /* Inventory stat boxes full width */
  .number-grid{
    display:flex;
    flex-direction:column;
    gap:20px;
  }

  .num-box{
    width:100%;
  }

  /* All primary buttons full width on mobile */
  .btn-solid-gold,
  .btn-outline-gold,
  .btn-glass{
    width:100%;
    display:block;
    text-align:center;
  }

  /* Portfolio lookbook button full width */
  .portfolio-section .btn-solid-gold{
    width:100%;
  }

}


}


/* ===== CTA FULL WIDTH MOBILE (1.0.6) ===== */
@media (max-width:768px){
  .offcanvas-menu .btn-solid-gold,
  .offcanvas-menu .btn-outline-gold{
    width:100%;
    display:block;
    text-align:center;
  }
}


/* ===== SOCIAL PROOF STARS (1.0.7) ===== */
/* Desktop/tablet: keep original inline look */
.social-proof-badge{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:12px;
}

.social-proof-badge .stars{
  display:flex;
  gap:6px;
  line-height:1;
  flex:0 0 auto;
}

.social-proof-badge .stars i{
  font-size:0.95rem;
  background: var(--gold-gradient);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  background-size: 220% auto;
  animation: fhsStarShine 2.8s linear infinite;
  filter: drop-shadow(0 2px 10px rgba(197,160,89,0.25));
}

@keyframes fhsStarShine{
  to{ background-position: 220% center; }
}

/* Mobile: stars ABOVE text + centered + full width */
@media (max-width:768px){
  .social-proof-badge{
    width:100%;
    max-width:100%;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
    gap:10px;
  }
  .social-proof-badge span{
    text-align:center;
  }
}


/* ===== DESKTOP FIX 1.0.8 ===== */
@media (min-width:769px){
  .social-proof-badge{
    width:auto !important;
    max-width:max-content;
    display:inline-flex;
  }
}
