
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#D4A017;--gold2:#E8B84B;--gold3:#F5E6B8;--gold4:rgba(212,160,23,0.12);
  --dark:#0d0d0d;--dark2:#111;--dark3:#1a1a1a;
  --white:#fff;--offwhite:#fafaf8;--gray:#f2f1ee;
  --text:#2a2a2a;--muted:#777;--border:#e5e3de;
}
html{scroll-behavior:smooth}
body{font-family:'Open Sans',sans-serif;color:var(--text);overflow-x:hidden;background:var(--offwhite)}
a{text-decoration:none;color:inherit}

/* === CUSTOM CURSOR === */
.cursor{width:12px;height:12px;background:var(--gold);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transition:transform 0.15s ease,opacity 0.2s;mix-blend-mode:multiply}
.cursor-ring{width:36px;height:36px;border:1.5px solid var(--gold);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transition:all 0.12s ease;opacity:0.5}

/* === SCROLL ANIMATIONS === */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-60px);transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1),transform 0.9s cubic-bezier(0.16,1,0.3,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(60px);transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1),transform 0.9s cubic-bezier(0.16,1,0.3,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(0.88);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.delay-1{transition-delay:0.1s}
.delay-2{transition-delay:0.2s}
.delay-3{transition-delay:0.3s}
.delay-4{transition-delay:0.4s}
.delay-5{transition-delay:0.5s}

/* === NAVBAR === */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,0.96);backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:74px;
  border-bottom:1px solid transparent;
  transition:all 0.4s ease;
}
.navbar.scrolled{border-bottom-color:var(--border);box-shadow:0 4px 40px rgba(0,0,0,0.08)}
.nav-left{display:flex;align-items:center;gap:36px}
.nav-link{font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px;color:var(--dark);letter-spacing:0.3px;position:relative;padding-bottom:3px}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--gold);transition:width 0.3s ease}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link:hover{color:var(--gold)}
.nav-logo{position:absolute;left:50%;transform:translateX(-50%)}
.logo-wrap{display:flex;flex-direction:column;align-items:center;gap:2px}
.logo-wrap span{font-family:'Montserrat',sans-serif;font-size:9px;font-weight:700;letter-spacing:3px;color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:12px}
.btn-outline{border:1.5px solid var(--gold);color:var(--dark);background:transparent;padding:10px 22px;border-radius:40px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;cursor:pointer;transition:all 0.3s ease;letter-spacing:0.3px}
.btn-outline:hover{background:var(--dark);color:#fff;border-color:var(--dark)}
.btn-gold{background:var(--gold);color:#fff;border:none;padding:10px 22px;border-radius:40px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;cursor:pointer;transition:all 0.3s ease;letter-spacing:0.3px;position:relative;overflow:hidden}
.btn-gold::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s ease}
.btn-gold:hover::before{left:100%}
.btn-gold:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 8px 20px rgba(212,160,23,0.35)}

/* Dropdown */
.dropdown{position:relative}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 8px);left:0;background:#fff;box-shadow:0 20px 60px rgba(0,0,0,0.12);min-width:280px;border-radius:8px;padding:8px;z-index:2000;border:1px solid var(--border)}
.dropdown:hover .dropdown-menu{display:block;animation:dropIn 0.2s ease}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.dropdown-menu a{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;color:var(--text);border-radius:6px;transition:all 0.2s}
.dropdown-menu a:hover{background:var(--gray);color:var(--gold);padding-left:18px}
.dropdown-menu a::before{content:'→';color:var(--gold);opacity:0;transition:opacity 0.2s}
.dropdown-menu a:hover::before{opacity:1}

/* === HERO === */
.hero{
  margin-top:74px;height:calc(100vh - 74px);min-height:600px;
  position:relative;overflow:hidden;
  display:flex;align-items:center;
  background:#060a0f;
}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;}
.hero-gradient{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg,rgba(4,6,10,0.92) 0%,rgba(4,6,10,0.75) 45%,rgba(4,6,10,0.1) 75%,transparent 100%);
  pointer-events:none;
}
.hero-particles{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.particle{
  position:absolute;background:var(--gold);border-radius:50%;opacity:0;
  animation:float var(--dur,8s) var(--del,0s) infinite ease-in-out;
}
@keyframes float{
  0%{opacity:0;transform:translateY(100vh) scale(0)}
  10%{opacity:0.5}90%{opacity:0.15}
  100%{opacity:0;transform:translateY(-20vh) scale(1.5)}
}
.hero-scanlines{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.03) 2px,rgba(0,0,0,0.03) 4px);
}
.hero-content{
  position:relative;z-index:3;padding:0 80px;max-width:58%;
  animation:heroIn 1.2s cubic-bezier(0.16,1,0.3,1) 0.3s both;
}
@keyframes heroIn{
  from{opacity:0;transform:translateY(60px)}
  to{opacity:1;transform:translateY(0)}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--gold);font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;margin-bottom:24px;
}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--gold)}
.hero-content h1{
  font-family:'Montserrat',sans-serif;font-size:clamp(40px,5.5vw,72px);
  font-weight:900;line-height:1.05;color:#fff;margin-bottom:32px;
}
.hero-content h1 .gold{color:var(--gold2)}
.hero-stats{display:flex;gap:40px;margin-top:44px}
.hero-stat{color:#fff;position:relative}
.hero-stat::after{content:'';position:absolute;right:-20px;top:10%;height:80%;width:1px;background:rgba(255,255,255,0.15)}
.hero-stat:last-child::after{display:none}
.hero-stat .num{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:700;color:var(--gold2);line-height:1}
.hero-stat .label{font-size:11px;color:rgba(255,255,255,0.55);margin-top:5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}
.hero-phase-bar{
  position:absolute;bottom:32px;left:80px;z-index:3;
  display:flex;align-items:center;gap:12px;
  animation:heroIn 1.2s cubic-bezier(0.16,1,0.3,1) 1.5s both;
}
.phase-label{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;color:rgba(255,255,255,0.4);letter-spacing:2px;text-transform:uppercase;width:100px}
.phase-dots{display:flex;gap:6px}
.phase-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.15);transition:all 0.5s ease}
.phase-dot.active{background:var(--gold);box-shadow:0 0 8px rgba(212,160,23,0.6);transform:scale(1.3)}

/* Hero Card */
.hero-card{
  position:absolute;right:60px;top:50%;transform:translateY(-50%);
  background:rgba(20,20,20,0.88);backdrop-filter:blur(24px);
  border-radius:16px;padding:40px 36px;width:360px;color:#fff;
  z-index:3;border:1px solid rgba(255,255,255,0.08);
  animation:cardIn 1.2s cubic-bezier(0.16,1,0.3,1) 0.5s both;
  box-shadow:0 40px 80px rgba(0,0,0,0.4);
}
@keyframes cardIn{
  from{opacity:0;transform:translateY(calc(-50% + 40px))}
  to{opacity:1;transform:translateY(-50%)}
}
.hero-card .start-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(212,160,23,0.15);border:1px solid rgba(212,160,23,0.3);
  border-radius:40px;padding:7px 18px;font-size:12px;margin-bottom:24px;
  font-family:'Montserrat',sans-serif;font-weight:600;letter-spacing:1px;
}
.pulse{width:8px;height:8px;background:var(--gold);border-radius:50%;position:relative}
.pulse::after{content:'';position:absolute;inset:-3px;border:1.5px solid var(--gold);border-radius:50%;animation:pulsate 2s infinite}
@keyframes pulsate{0%{transform:scale(1);opacity:1}100%{transform:scale(2);opacity:0}}
.hero-card h2{font-family:'Montserrat',sans-serif;font-size:30px;font-weight:900;line-height:1.2;margin-bottom:8px}
.hero-card h2 span{color:var(--gold2)}
.hero-card .sub{font-size:14px;color:rgba(255,255,255,0.6);margin-bottom:28px}
.btn-gold-xl{
  display:block;width:100%;text-align:center;background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#fff;padding:16px;border-radius:10px;font-family:'Montserrat',sans-serif;
  font-weight:800;font-size:16px;margin-bottom:16px;cursor:pointer;border:none;
  transition:all 0.3s ease;letter-spacing:0.5px;position:relative;overflow:hidden;
}
.btn-gold-xl::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.1);opacity:0;transition:opacity 0.3s}
.btn-gold-xl:hover::before{opacity:1}
.btn-gold-xl:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(212,160,23,0.4)}
.intro-cta{
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);
  border-radius:10px;padding:14px 16px;cursor:pointer;transition:background 0.2s;
}
.intro-cta:hover{background:rgba(255,255,255,0.1)}
.intro-icon{width:38px;height:38px;background:rgba(212,160,23,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.intro-text h4{font-size:13px;font-weight:700}
.intro-text p{font-size:11px;color:rgba(255,255,255,0.5);margin-top:2px}
.intro-arrow{background:var(--gold);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform 0.2s}
.intro-cta:hover .intro-arrow{transform:translateX(3px)}

/* === MARQUEE STRIP === */
.marquee-strip{
  background:var(--dark);padding:16px 0;overflow:hidden;position:relative;
  border-top:1px solid rgba(255,255,255,0.05);border-bottom:1px solid rgba(255,255,255,0.05);
}
.marquee-track{display:flex;gap:48px;animation:marquee 30s linear infinite;width:max-content}
.marquee-item{
  display:flex;align-items:center;gap:12px;
  font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;
  color:rgba(255,255,255,0.5);letter-spacing:2px;text-transform:uppercase;white-space:nowrap;
}
.marquee-item .dot{width:5px;height:5px;background:var(--gold);border-radius:50%;flex-shrink:0}
@keyframes marquee{to{transform:translateX(-50%)}}

/* === SERVICES === */
.services-section{padding:100px 80px;background:var(--offwhite)}
.section-eyebrow{
  font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:4px;color:var(--gold);text-transform:uppercase;
  display:flex;align-items:center;gap:12px;margin-bottom:16px;
}
.section-eyebrow::before{content:'';width:32px;height:1.5px;background:var(--gold)}
.section-title{
  font-family:'Montserrat',sans-serif;font-size:clamp(32px,4vw,52px);
  font-weight:900;color:var(--dark);line-height:1.1;margin-bottom:20px;
}
.section-title .gold{color:var(--gold)}
.section-sub{font-size:15px;color:var(--muted);max-width:640px;line-height:1.8;margin-bottom:60px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service-card{
  border:1.5px solid var(--border);border-radius:12px;
  padding:48px 32px 40px;cursor:pointer;position:relative;
  background:#fff;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);
  overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(212,160,23,0.06),transparent);
  opacity:0;transition:opacity 0.4s;
}
.service-card:hover::before,.service-card.active::before{opacity:1}
.service-card:hover,.service-card.active{
  border-color:var(--gold);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(212,160,23,0.15);
}
.service-icon{width:60px;height:60px;margin-bottom:24px;transition:transform 0.3s}
.service-card:hover .service-icon,.service-card.active .service-icon{transform:scale(1.1) rotate(-3deg)}
.service-card h3{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;color:var(--dark);margin-bottom:14px}
.service-divider{width:36px;height:2.5px;background:var(--border);border-radius:2px;margin-bottom:16px;transition:width 0.3s,background 0.3s}
.service-card:hover .service-divider,.service-card.active .service-divider{width:60px;background:var(--gold)}
.service-card p{font-size:13.5px;color:var(--muted);line-height:1.7;opacity:0;max-height:0;overflow:hidden;transition:all 0.4s ease}
.service-card.active p{opacity:1;max-height:200px}
.service-arrow{
  display:none;width:40px;height:40px;background:var(--gold);border-radius:50%;
  align-items:center;justify-content:center;margin-top:20px;
  transition:transform 0.2s;
}
.service-card.active .service-arrow{display:flex}
.service-card:hover .service-arrow{transform:translateX(4px)}

/* === DARK BG SECTION === */
.dark-bg{background:var(--dark2);color:#fff}

/* === PRICING === */
.pricing-section{background:var(--dark2);padding:100px 80px}
.pricing-section .section-title{color:#fff}
.pricing-box{
  background:#fff;color:var(--dark);border-radius:20px;
  max-width:860px;margin:0 auto 80px;padding:64px 56px;text-align:center;
  position:relative;overflow:hidden;
}
.pricing-box::before{
  content:'';position:absolute;top:-60px;right:-60px;width:220px;height:220px;
  background:radial-gradient(circle,rgba(212,160,23,0.15),transparent 70%);
  border-radius:50%;
}
.pricing-box .from{font-size:14px;color:var(--muted);margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:2px}
.pricing-box .price{font-family:'Montserrat',sans-serif;font-size:80px;font-weight:900;line-height:1;color:var(--dark);position:relative}
.pricing-box .price sub{font-size:24px;vertical-align:middle;font-weight:700;color:var(--gold)}
.pricing-box .limited{font-size:13px;font-style:italic;color:var(--muted);margin:10px 0 24px}
.pricing-box .desc{font-size:14px;line-height:1.8;color:var(--muted);max-width:680px;margin:0 auto 32px}
.trial-cta{font-family:'Montserrat',sans-serif;font-size:24px;font-weight:800}
.trial-cta span{color:var(--gold)}
.packages-label{text-align:center;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:4px;color:var(--gold);text-transform:uppercase;margin-bottom:12px}
.packages-title{text-align:center;font-family:'Montserrat',sans-serif;font-size:52px;font-weight:900;color:#fff;margin-bottom:56px}
.packages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1080px;margin:0 auto}
.pkg-card{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);
  border-radius:16px;padding:40px 32px;color:#fff;
  transition:all 0.4s cubic-bezier(0.16,1,0.3,1);position:relative;overflow:hidden;
}
.pkg-card::after{
  content:'';position:absolute;inset:0;border-radius:16px;
  background:linear-gradient(135deg,rgba(212,160,23,0.08),transparent);
  opacity:0;transition:opacity 0.4s;
}
.pkg-card:hover{transform:translateY(-8px);border-color:var(--gold);box-shadow:0 30px 60px rgba(0,0,0,0.3)}
.pkg-card:hover::after{opacity:1}
.pkg-card.featured{border-color:var(--gold);background:rgba(212,160,23,0.08)}
.pkg-badge{
  display:inline-block;background:var(--gold);color:#fff;
  font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:20px;
  margin-bottom:20px;
}
.pkg-label{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}
.pkg-price{font-family:'Montserrat',sans-serif;font-size:46px;font-weight:900;line-height:1;margin-bottom:4px}
.pkg-period{font-size:12px;color:rgba(255,255,255,0.45);margin-bottom:4px}
.pkg-rate{font-size:13px;color:rgba(255,255,255,0.65);margin-bottom:28px}
.btn-sub{
  display:block;width:100%;text-align:center;
  background:rgba(255,255,255,0.9);color:var(--dark);
  padding:13px;border-radius:40px;font-family:'Montserrat',sans-serif;
  font-weight:700;font-size:13px;margin-bottom:12px;cursor:pointer;border:none;
  transition:all 0.3s;
}
.btn-sub:hover{background:#fff;transform:scale(1.02)}
.pkg-card.featured .btn-sub{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff}
.btn-how{
  display:block;width:100%;text-align:center;
  border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.7);
  padding:12px;border-radius:40px;font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:12px;margin-bottom:28px;cursor:pointer;background:transparent;
  transition:all 0.3s;
}
.btn-how:hover{border-color:var(--gold);color:var(--gold)}
.feat-title{font-size:15px;font-weight:700;margin-bottom:16px}
.feat-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:11px;font-size:13px;color:rgba(255,255,255,0.8);line-height:1.4}
.feat-check{width:17px;height:17px;background:var(--gold);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px}
.feat-check::after{content:'✓';font-size:9px;color:#fff;font-weight:700}

/* === PORTFOLIO === */
.portfolio-section{padding:100px 80px;background:var(--offwhite)}
.portfolio-label{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:4px;color:var(--gold);text-transform:uppercase;text-align:center;margin-bottom:12px}
.portfolio-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-template-rows:repeat(2,230px);gap:10px;margin:48px 0 24px;
}
.pf-item{
  position:relative;overflow:hidden;cursor:pointer;border-radius:8px;
}
.pf-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.7s cubic-bezier(0.16,1,0.3,1)}
.pf-item:hover img{transform:scale(1.1)}
.pf-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(212,160,23,0.9) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:24px;
  opacity:0;transition:opacity 0.4s ease;
}
.pf-item:hover .pf-overlay{opacity:1}
.pf-overlay h3{color:#fff;font-family:'Montserrat',sans-serif;font-size:16px;font-weight:700;transform:translateY(10px);transition:transform 0.3s}
.pf-item:hover .pf-overlay h3{transform:translateY(0)}
.pf-divider{width:28px;height:2px;background:rgba(255,255,255,0.6);margin:8px 0;transform:scaleX(0);transform-origin:left;transition:transform 0.3s 0.1s}
.pf-item:hover .pf-divider{transform:scaleX(1)}
.pf-overlay p{color:rgba(255,255,255,0.85);font-size:12px;transform:translateY(10px);opacity:0;transition:all 0.3s 0.15s}
.pf-item:hover .pf-overlay p{transform:translateY(0);opacity:1}

/* === QUOTE CTA === */
.quote-cta{
  background:linear-gradient(135deg,#fdf4dc,#fef9ec);
  padding:80px;text-align:center;
  position:relative;overflow:hidden;
}
.quote-cta::before{
  content:'';position:absolute;width:400px;height:400px;
  background:radial-gradient(circle,rgba(212,160,23,0.15),transparent 70%);
  border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);
  animation:breathe 6s ease-in-out infinite;
}
@keyframes breathe{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.2)}}
.quote-cta h2{font-family:'Montserrat',sans-serif;font-size:34px;font-weight:800;color:var(--dark);position:relative;z-index:1}
.btn-quote{
  display:inline-block;margin-top:28px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;
  padding:18px 56px;border-radius:50px;font-family:'Montserrat',sans-serif;
  font-weight:800;font-size:16px;cursor:pointer;border:none;position:relative;z-index:1;
  transition:all 0.3s ease;letter-spacing:0.5px;
}
.btn-quote:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(212,160,23,0.4)}

/* === ABOUT === */
.about-section{background:var(--dark2);padding:100px 80px}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.about-img-wrap{position:relative}
.about-corner{position:absolute;width:80px;height:80px;border:2.5px solid var(--gold)}
.about-corner.tl{top:-16px;left:-16px;border-right:none;border-bottom:none}
.about-corner.br{bottom:-16px;right:-16px;border-left:none;border-top:none}
.about-img-wrap img{width:100%;height:520px;object-fit:cover;border-radius:4px;filter:grayscale(20%)}
.years-badge{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  background:#fff;padding:18px 36px;border-radius:4px;white-space:nowrap;
  box-shadow:0 20px 60px rgba(0,0,0,0.3);
}
.years-badge .num{font-family:'Montserrat',sans-serif;font-size:36px;font-weight:900;line-height:1}
.years-badge .num .y{color:var(--gold)}
.years-badge .lbl{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text)}
.about-content{color:#fff}
.about-content .eyebrow{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:4px;color:var(--gold);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.about-content .eyebrow::before{content:'';width:28px;height:1.5px;background:var(--gold)}
.about-content h2{font-family:'Montserrat',sans-serif;font-size:38px;font-weight:800;line-height:1.2;margin-bottom:24px}
.about-content p{color:rgba(255,255,255,0.7);line-height:1.9;font-size:15px;margin-bottom:28px}
.client-logos-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px}
.clogo{
  border:1px solid rgba(255,255,255,0.12);border-radius:6px;
  padding:8px 14px;font-size:11px;font-weight:700;
  color:rgba(255,255,255,0.55);font-family:'Montserrat',sans-serif;
  letter-spacing:0.5px;transition:all 0.3s;
}
.clogo:hover{border-color:var(--gold);color:var(--gold)}

/* === TESTIMONIALS === */
.testimonials-section{padding:100px 80px;background:var(--offwhite)}
.testimonials-title{font-family:'Montserrat',sans-serif;font-size:clamp(32px,4vw,48px);font-weight:900;color:var(--dark);margin-bottom:56px}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi-card{
  background:#fff;border:1.5px solid var(--border);border-radius:16px;
  padding:36px 32px;position:relative;
  transition:all 0.4s cubic-bezier(0.16,1,0.3,1);
}
.testi-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,0.1);border-color:var(--gold)}
.quote-bubble{
  position:absolute;top:-20px;left:36px;
  width:42px;height:42px;background:linear-gradient(135deg,var(--gold),var(--gold2));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:18px;color:#fff;font-weight:900;font-family:serif;
  box-shadow:0 8px 20px rgba(212,160,23,0.3);
}
.testi-card h4{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:800;margin-bottom:3px}
.testi-card .src{font-size:12px;color:var(--muted);margin-bottom:18px}
.testi-card p{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:14px}
.read-more{font-size:12px;font-weight:700;color:var(--dark);cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.read-more::after{content:'→';transition:transform 0.2s}
.read-more:hover::after{transform:translateX(4px)}
.testi-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.stars{letter-spacing:2px;font-size:16px}

/* === FAQs === */
.faq-section{background:var(--dark2);padding:100px 80px}
.faq-title{text-align:center;font-family:'Montserrat',sans-serif;font-size:clamp(40px,6vw,64px);font-weight:900;color:var(--gold);margin-bottom:56px}
.faq-list{max-width:860px;margin:0 auto}
.faq-item{
  border:1px solid rgba(255,255,255,0.1);border-radius:10px;
  margin-bottom:14px;overflow:hidden;transition:border-color 0.3s;
}
.faq-item.active{border-color:var(--gold)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 28px;cursor:pointer;color:#fff;font-size:15px;
  font-family:'Open Sans',sans-serif;transition:color 0.3s;
}
.faq-item.active .faq-q{color:var(--gold)}
.faq-icon{
  width:32px;height:32px;border:1.5px solid rgba(255,255,255,0.2);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:18px;color:#fff;transition:all 0.3s;flex-shrink:0;
}
.faq-item.active .faq-icon{background:var(--gold);border-color:var(--gold);transform:rotate(45deg)}
.faq-a{
  padding:0 28px;max-height:0;overflow:hidden;
  color:rgba(255,255,255,0.6);font-size:14px;line-height:1.8;
  transition:max-height 0.4s ease,padding 0.3s;
}
.faq-item.active .faq-a{max-height:200px;padding-bottom:24px}

/* === CLIENTS === */
.clients-section{padding:100px 80px;background:#fff}
.clients-title{text-align:center;font-family:'Montserrat',sans-serif;font-size:clamp(32px,4vw,48px);font-weight:900;color:var(--dark);margin-bottom:56px}
.clients-title .gold{color:var(--gold)}
.clients-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto}
.client-card{
  border:1.5px solid var(--border);border-radius:12px;padding:32px;
  transition:all 0.4s;background:#fff;
}
.client-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,0.08);border-color:var(--gold)}
.client-card p{font-style:italic;font-size:15px;color:var(--text);line-height:1.8;margin-bottom:20px}
.reviewer{display:flex;align-items:center;gap:14px}
.rev-img{width:48px;height:48px;border-radius:50%;overflow:hidden;border:2px solid var(--gold3)}
.rev-img img{width:100%;height:100%;object-fit:cover}
.rev-name{font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;margin-bottom:2px}
.rev-company{font-size:12px;color:var(--gold)}
.slider-nav{display:flex;justify-content:center;gap:8px;margin-top:32px}
.s-dot{width:9px;height:9px;border-radius:50%;background:var(--border);cursor:pointer;transition:all 0.3s}
.s-dot.active{background:var(--gold);transform:scale(1.3)}

/* === CONTACT === */
.contact-section{padding:100px 80px;background:var(--offwhite);position:relative;overflow:hidden}
.contact-deco{
  position:absolute;right:-100px;top:50%;transform:translateY(-50%);
  width:500px;height:500px;border:60px solid rgba(212,160,23,0.07);border-radius:50%;pointer-events:none;
  animation:spin-slow 20s linear infinite;
}
.contact-deco2{
  position:absolute;right:-50px;top:50%;transform:translateY(-50%);
  width:300px;height:300px;border:30px solid rgba(212,160,23,0.05);border-radius:50%;pointer-events:none;
  animation:spin-slow 15s linear infinite reverse;
}
@keyframes spin-slow{to{transform:translateY(-50%) rotate(360deg)}}
.contact-title{font-family:'Montserrat',sans-serif;font-size:clamp(44px,6vw,64px);font-weight:900;color:var(--dark);margin-bottom:48px}
.contact-title .dot{color:var(--gold)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px}
.contact-info .tagline{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:800;color:var(--gold);margin-bottom:20px}
.contact-info p{font-size:15px;color:var(--text);line-height:1.8;margin-bottom:12px}
.contact-info .clabel{font-weight:700;font-size:14px;color:var(--dark);margin-top:20px;margin-bottom:4px}
.contact-info a{color:var(--gold);font-size:14px;transition:opacity 0.2s}
.contact-info a:hover{opacity:0.7}
.contact-video{
  background:var(--dark);height:260px;border-radius:12px;margin-top:24px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.2);font-size:13px;overflow:hidden;position:relative;
}
.play-btn{
  width:64px;height:64px;border:2px solid rgba(255,255,255,0.3);border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:all 0.3s;position:absolute;
}
.play-btn:hover{background:var(--gold);border-color:var(--gold);transform:scale(1.1)}
.contact-form{display:flex;flex-direction:column;gap:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:0}
.form-field{
  border-bottom:1.5px solid var(--border);padding:20px 0;
  position:relative;transition:border-color 0.3s;
}
.form-field:focus-within{border-bottom-color:var(--gold)}
.form-field label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;display:block;margin-bottom:6px}
.form-field input,.form-field textarea,.form-field select{
  width:100%;border:none;font-size:14px;font-family:'Open Sans',sans-serif;
  outline:none;background:transparent;color:var(--text);
}
.form-field textarea{min-height:80px;resize:none}
.form-field::after{content:'';position:absolute;bottom:-1.5px;left:0;width:0;height:2px;background:var(--gold);transition:width 0.4s ease}
.form-field:focus-within::after{width:100%}
.nda-row{padding:20px 0;display:flex;align-items:center;gap:12px;cursor:pointer}
.nda-row input{width:18px;height:18px;cursor:pointer;accent-color:var(--gold)}
.nda-row span{font-size:14px;color:var(--text)}
.btn-send{
  margin-top:12px;background:transparent;border:2px solid var(--gold);
  color:var(--dark);padding:16px 48px;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;
  cursor:pointer;transition:all 0.3s;letter-spacing:1px;align-self:flex-start;
  position:relative;overflow:hidden;
}
.btn-send::before{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease;z-index:-1}
.btn-send:hover::before{transform:scaleX(1)}
.btn-send:hover{color:#fff}

/* === MAP === */
.map-section{padding:100px 80px 60px;background:#fff}
.map-title{text-align:center;font-family:'Montserrat',sans-serif;font-size:clamp(32px,4vw,48px);font-weight:900;color:var(--dark);margin-bottom:48px}
.map-title .gold{color:var(--gold)}
#formrise-map{width:100%;height:500px;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.1);border:1px solid var(--border)}
.btn-lets-talk{
  display:block;margin:36px auto 0;
  border:2px solid var(--gold);background:transparent;color:var(--dark);
  padding:16px 80px;border-radius:50px;font-family:'Montserrat',sans-serif;
  font-weight:800;font-size:14px;cursor:pointer;transition:all 0.3s;letter-spacing:3px;
  position:relative;overflow:hidden;
}
.btn-lets-talk::before{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:center;transition:transform 0.3s;z-index:-1}
.btn-lets-talk:hover::before{transform:scaleX(1)}
.btn-lets-talk:hover{color:#fff}

/* === FOOTER === */
footer{
  background:var(--dark);
  background-image:linear-gradient(rgba(6,4,2,0.88),rgba(10,7,3,0.82)),url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?w=1600&q=80');
  background-size:cover;background-position:center;
  color:#fff;padding:72px 80px 28px;
}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:40px}
.footer-logo-area{display:flex;flex-direction:column;align-items:flex-start;gap:12px}
.footer-brand{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:4px;color:rgba(255,255,255,0.4);text-transform:uppercase}
.footer-nav-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px 32px}
.footer-nav-grid a{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:600;color:rgba(255,255,255,0.55);letter-spacing:0.5px;transition:color 0.2s;padding:4px 0}
.footer-nav-grid a:hover{color:var(--gold)}
.footer-offices{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.08)}
.footer-office h3{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:700;margin-bottom:14px;color:#fff}
.footer-office address{font-style:normal;font-size:13px;color:rgba(255,255,255,0.5);line-height:1.9}
.footer-bottom{display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.3)}
.footer-socials{display:flex;gap:24px}
.footer-socials a{font-size:12px;color:rgba(255,255,255,0.4);font-weight:600;letter-spacing:1px;transition:color 0.2s}
.footer-socials a:hover{color:var(--gold)}

/* === COUNTER ANIMATION === */
.count-num{display:inline-block}

/* === LEAFLET CUSTOM === */
.leaflet-popup-content-wrapper{border-radius:10px!important;box-shadow:0 10px 40px rgba(0,0,0,0.2)!important;border:1px solid var(--border)!important}
.custom-popup h4{font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;color:var(--dark);margin-bottom:4px}
.custom-popup p{font-size:12px;color:var(--muted)}
.gold-pin{background:var(--gold);border:3px solid #fff;width:16px;height:16px;border-radius:50%;box-shadow:0 4px 12px rgba(212,160,23,0.4)}

/* === MISC === */
.text-center{text-align:center}
.flex-center{display:flex;justify-content:center}

/* === HAMBURGER / MOBILE NAV === */
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:40px;height:40px;cursor:pointer;background:none;border:none;padding:4px;z-index:1100;
}
.hamburger span{
  display:block;height:2px;background:var(--dark);border-radius:2px;
  transition:all 0.3s ease;width:100%;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{
  display:none;position:fixed;top:74px;left:0;right:0;bottom:0;
  background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);
  z-index:999;overflow-y:auto;padding:24px 28px 40px;
  flex-direction:column;gap:0;
}
.mobile-menu.open{display:flex}
.mobile-menu a,.mobile-menu .mob-link{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:18px;
  color:var(--dark);padding:16px 0;border-bottom:1px solid var(--border);
  display:block;transition:color 0.2s;
}
.mobile-menu a:hover,.mobile-menu .mob-link:hover{color:var(--gold)}
.mobile-menu .mob-submenu{
  padding-left:16px;display:none;
}
.mobile-menu .mob-submenu.open{display:block}
.mobile-menu .mob-submenu a{font-size:14px;font-weight:500;padding:10px 0;border-bottom:none;color:var(--muted)}
.mobile-menu .mob-submenu a:hover{color:var(--gold)}
.mob-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:none;cursor:pointer;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:18px;color:var(--dark);padding:16px 0;border-bottom:1px solid var(--border);}
.mob-toggle .arr{transition:transform 0.3s;font-size:14px;color:var(--gold)}
.mob-toggle.open .arr{transform:rotate(180deg)}
.mobile-menu .mob-btns{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.mobile-menu .mob-btns .btn-outline,
.mobile-menu .mob-btns .btn-gold{width:100%;text-align:center;padding:14px 22px;font-size:14px}

/* === RESPONSIVE === */
@media(max-width:900px){
  /* Navbar */
  .navbar{padding:0 20px}
  .nav-left,.nav-right{display:none}
  .hamburger{display:flex}
  .nav-logo{position:static;transform:none}

  /* Hero - hide card on mobile, keep content clean */
  .hero{height:auto;min-height:100svh;flex-direction:column;align-items:flex-start;padding-bottom:0}
  .hero-content{
    padding:36px 24px 0;max-width:100%;
    animation:heroIn 1.2s cubic-bezier(0.16,1,0.3,1) 0.3s both;
  }
  .hero-content h1{font-size:clamp(30px,8vw,48px);margin-bottom:24px}
  .hero-stats{gap:20px;flex-wrap:wrap;margin-top:28px}
  .hero-stat .num{font-size:32px}
  .hero-stat::after{display:none}
  /* Hide the "Join Formrise Architects" card on mobile — hero animation is enough */
  .hero-card{display:none}
  .hero-phase-bar{
    position:static;left:auto;bottom:auto;
    margin:28px 24px 36px;
    animation:none;opacity:1;
  }

  /* Sections */
  .services-section,
  .pricing-section,
  .about-section,
  .testimonials-section,
  .faq-section,
  .clients-section,
  .contact-section,
  .map-section{padding:64px 24px}
  .portfolio-section{padding:64px 24px}

  /* Services grid */
  .services-grid{grid-template-columns:1fr}
  .service-card p{opacity:1;max-height:none}
  .service-arrow{display:flex}

  /* Portfolio — 2-col, equal square-ish cells */
  .portfolio-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
    gap:8px;
    margin:32px 0 20px;
  }
  .pf-item{height:160px}
  /* Always show overlay text on mobile (no hover) */
  .pf-overlay{opacity:1;background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,0.65) 100%)}
  .pf-overlay h3{transform:translateY(0);font-size:13px}
  .pf-divider{transform:scaleX(1)}
  .pf-overlay p{transform:translateY(0);opacity:1;font-size:11px}

  /* Pricing */
  .pricing-box{padding:36px 24px;margin-bottom:48px}
  .pricing-box .price{font-size:56px}
  .packages-grid{grid-template-columns:1fr}
  .packages-title{font-size:36px}

  /* About */
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-img-wrap img{height:280px}
  .about-content h2{font-size:28px}

  /* Testimonials */
  .testi-grid{grid-template-columns:1fr}

  /* Clients */
  .clients-grid{grid-template-columns:1fr}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .form-row{grid-template-columns:1fr}
  .contact-title{font-size:clamp(32px,9vw,52px)}
  .contact-deco,.contact-deco2{display:none}

  /* Footer — clean stacked layout */
  footer{padding:48px 24px 28px}
  .footer-top{
    flex-direction:column;align-items:center;gap:28px;text-align:center;
    padding-bottom:28px;margin-bottom:28px;
  }
  .footer-logo-area{align-items:center}
  .footer-nav-grid{
    grid-template-columns:repeat(2,1fr);gap:6px 24px;
    text-align:left;max-width:280px;
  }
  .footer-offices{
    grid-template-columns:1fr;gap:24px;
    margin-bottom:28px;padding-bottom:28px;
  }
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .footer-socials{justify-content:center;gap:20px}
  .footer-copy{font-size:11px}

  /* Map */
  #formrise-map{height:300px}

  /* Cursor - hide on touch */
  .cursor,.cursor-ring{display:none}
}

@media(max-width:480px){
  .hero-stats{gap:16px}
  .hero-stat .num{font-size:26px}
  .hero-phase-bar{margin:20px 16px 28px}
  .services-section,
  .pricing-section,
  .about-section,
  .testimonials-section,
  .faq-section,
  .clients-section,
  .contact-section,
  .map-section,
  .portfolio-section{padding:48px 16px}
  .section-title{font-size:clamp(26px,8vw,38px)}
  .faq-title{font-size:clamp(28px,9vw,44px)}
  .packages-title{font-size:28px}
  footer{padding:40px 16px 24px}
  .portfolio-grid{gap:6px}
  .pf-item{height:130px}
  .footer-nav-grid{max-width:240px}
}


/* ── WordPress & scroll fixes ────────────────── */
html { scroll-behavior: smooth; scroll-padding-top: 74px; }
section[id] { scroll-margin-top: 74px; }
body.admin-bar .navbar { top: 32px; }
body.admin-bar { padding-top: 0 !important; }
img { max-width: 100%; height: auto; }
#formrise-map { width:100%; height:480px; border-radius:12px; z-index:1; }
.custom-popup h4 { font-family:'Montserrat',sans-serif; font-weight:700; font-size:14px; color:#0d0d0d; margin-bottom:4px; }
.custom-popup p  { font-size:12px; color:#777; }
