html, body {
  overflow: hidden;
}
body{overflow-x:hidden}
.services-main{position:relative;min-height:100vh;font-family:'Inter',sans-serif;color:#f0f0f0}

/* Overlays & Decorations */
.geometric-overlay,.service-dots{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}
.triangle{position:absolute;width:0;height:0;border-style:solid}
.triangle:nth-child(1){border-left:15px solid transparent;border-right:15px solid transparent;border-bottom:26px solid rgba(228,168,83,0.1);top:10%;left:5%;animation:triangleSpin 8s linear infinite}
.triangle:nth-child(2){border-left:12px solid transparent;border-right:12px solid transparent;border-bottom:21px solid rgba(228,168,83,0.15);top:25%;right:8%;animation:triangleSpin 12s linear infinite reverse}
.triangle:nth-child(3){border-left:18px solid transparent;border-right:18px solid transparent;border-bottom:31px solid rgba(228,168,83,0.08);top:60%;left:10%;animation:triangleSpin 10s linear infinite}
.triangle:nth-child(4){border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:17px solid rgba(228,168,83,0.12);top:80%;right:15%;animation:triangleSpin 15s linear infinite reverse}
.triangle:nth-child(5){border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:24px solid rgba(228,168,83,0.09);top:40%;left:85%;animation:triangleSpin 9s linear infinite}
.triangle:nth-child(6){border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid rgba(228,168,83,0.11);top:5%;left:60%;animation:triangleSpin 11s linear infinite reverse}
.triangle:nth-child(7){border-left:11px solid transparent;border-right:11px solid transparent;border-bottom:19px solid rgba(228,168,83,0.13);top:70%;right:60%;animation:triangleSpin 13s linear infinite}
.triangle:nth-child(8){border-left:13px solid transparent;border-right:13px solid transparent;border-bottom:23px solid rgba(228,168,83,0.10);top:35%;left:30%;animation:triangleSpin 7s linear infinite reverse}
.dot{position:absolute;width:4px;height:4px;background:linear-gradient(45deg,#e4a853,#f4c463);border-radius:50%;animation:dotPulse 3s ease-in-out infinite}
.dot:nth-child(1){top:15%;left:12%;animation-delay:0s}
.dot:nth-child(2){top:25%;left:88%;animation-delay:.5s}
.dot:nth-child(3){top:45%;left:5%;animation-delay:1s}
.dot:nth-child(4){top:55%;left:92%;animation-delay:1.5s}
.dot:nth-child(5){top:75%;left:15%;animation-delay:2s}
.dot:nth-child(6){top:85%;left:85%;animation-delay:2.5s}
.dot:nth-child(7){top:35%;left:45%;animation-delay:.3s}
.dot:nth-child(8){top:65%;left:55%;animation-delay:.8s}
.dot:nth-child(9){top:20%;left:70%;animation-delay:1.3s}
.dot:nth-child(10){top:80%;left:30%;animation-delay:1.8s}
.dot:nth-child(11){top:50%;left:75%;animation-delay:2.3s}
.dot:nth-child(12){top:90%;left:50%;animation-delay:.2s}

/* Layout & Sections */
.service-container{max-width:1200px;margin:0 auto;padding:0 2rem}
.service-intro-section,.services-showcase,.contact-section,.location-section{position:relative;z-index:2}
.service-intro-section{padding:100px 0 80px}
.services-showcase,.contact-section{padding:80px 0}
.location-section{padding:60px 0;text-align:center}
.intro-layout,.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}

/* Typography */
.service-main-title,.location-title,.contact-title{font-family:'Dancing Script',cursive;color:#e4a853;font-weight:700}
.service-main-title{font-size:4rem;line-height:1.2;margin-bottom:2rem}
.location-title{font-size:3.5rem;margin-bottom:2rem}
.contact-title{font-size:3.8rem;margin-bottom:2rem}
.service-description,.contact-description,.location-description{font-size:1.2rem;line-height:1.7}
.location-description{margin:0 auto 1.5rem;max-width:800px}
.contact-description{margin-bottom:3rem}

/* Images & Wrappers */
.service-image-wrapper,.contact-image-wrapper{position:relative;margin:0 auto}
.service-image-wrapper{width:400px;height:400px}
.contact-image-wrapper{width:380px;height:380px}
.service-featured-image,.contact-image{width:100%;height:100%;object-fit:cover;border-radius:50%;position:relative;z-index:2;transition:transform .4s ease}
.service-featured-image:hover{transform:scale(1.05)}
.contact-image:hover{transform:scale(1.03)}
.rotating-border{position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;border:2px solid transparent;border-radius:50%;background:linear-gradient(45deg,#e4a853,transparent,#f4c463,transparent) border-box;background-clip:border-box;animation:borderRotate 20s linear infinite}
.image-shine{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.3),transparent 40%);pointer-events:none;z-index:3}
.image-frame{position:absolute;top:-15px;left:-15px;right:-15px;bottom:-15px;background:conic-gradient(#e4a853,#f4c463,#e4a853);border-radius:50%;animation:frameRotate 25s linear infinite}
.contact-glow{position:absolute;top:50%;left:50%;width:120%;height:120%;background:radial-gradient(circle,rgba(228,168,83,.2),transparent 70%);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:1;animation:glowPulse 4s ease-in-out infinite}

/* Service Grid */
.services-grid{display:grid;gap:40px;max-width:800px;margin:0 auto}
.service-item{background:rgba(26,26,46,.6);border:1px solid rgba(228,168,83,.2);border-radius:15px;padding:2.5rem;position:relative;transition:all .4s ease;backdrop-filter:blur(10px)}
.service-item:hover{transform:translateY(-8px);border-color:rgba(228,168,83,.5);box-shadow:0 20px 40px rgba(228,168,83,.2)}
.service-number{position:absolute;top:20px;right:25px;font-family:'Dancing Script',cursive;font-size:3rem;color:rgba(228,168,83,.3);font-weight:600}
.service-name{font-family:'Dancing Script',cursive;font-size:2rem;color:#e4a853;margin-bottom:1rem;font-weight:600}
.service-text{font-size:1.1rem;line-height:1.6;margin:0}
.service-accent{position:absolute;bottom:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#e4a853,transparent);border-radius:0 0 15px 15px}

/* CTA Button */
.service-cta-btn{background:linear-gradient(135deg,#e4a853,#f4c463);color:#0a0a0f;border:none;padding:18px 45px;font-family:'Inter',sans-serif;font-size:1.1rem;font-weight:600;border-radius:50px;cursor:pointer;position:relative;overflow:hidden;transition:all .3s ease;box-shadow:0 8px 25px rgba(228,168,83,.3)}
.service-cta-btn:hover{transform:translateY(-3px);box-shadow:0 15px 35px rgba(228,168,83,.5)}
.btn-text{position:relative;z-index:2}
.btn-ripple{position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.3);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s}
.service-cta-btn:active .btn-ripple{width:300px;height:300px}

/* Animation Helpers */
.slide-in,.slide-in-right{opacity:0;transition:all 1s ease}
.fade-up{opacity:0;transform:translateY(40px);transition:all .8s ease}
.slide-in{transform:translateX(-50px)}
.slide-in-right{transform:translateX(50px)}
.fade-up.delay-1{transition-delay:.2s}
.fade-up.delay-2{transition-delay:.4s}
.slide-in.visible,.slide-in-right.visible,.fade-up.visible{opacity:1;transform:translate(0)}

/* Keyframes */
@keyframes triangleSpin{to{transform:rotate(360deg)}}
@keyframes dotPulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}
@keyframes borderRotate{to{transform:rotate(360deg)}}
@keyframes frameRotate{to{transform:rotate(-360deg)}}
@keyframes glowPulse{0%,100%{opacity:.2}50%{opacity:.4}}

/* Media Queries */
@media(max-width:1024px){
.intro-layout,.contact-layout{grid-template-columns:1fr;gap:50px;text-align:center}
.service-main-title{font-size:3.5rem}
.contact-title{font-size:3.2rem}
.location-title{font-size:3rem}
.service-image-wrapper,.contact-image-wrapper{width:320px;height:320px}
}
@media(max-width:768px){
.service-intro-section{padding:80px 0 60px}
.services-showcase,.contact-section{padding:60px 0}
.service-container{padding:0 1.5rem}
.intro-layout,.contact-layout{gap:40px}
.service-main-title{font-size:3rem}
.contact-title{font-size:2.8rem}
.location-title{font-size:2.5rem}
.service-description,.contact-description,.location-description{font-size:1.1rem}
.service-image-wrapper,.contact-image-wrapper{width:280px;height:280px}
.service-item{padding:2rem}
.service-name{font-size:1.8rem}
.service-text{font-size:1rem}
}
@media(max-width:480px){
.service-container{padding:0 1rem}
.service-main-title{font-size:2.5rem}
.contact-title{font-size:2.3rem}
.location-title{font-size:2.2rem}
.service-image-wrapper,.contact-image-wrapper{width:240px;height:240px}
.service-item{padding:1.5rem}
.service-cta-btn{padding:15px 35px;font-size:1rem}
}