@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800;900&family=Poppins:wght@300;400;500;600;700;800;900&display=swap');

:root{
--navy:#06162c;
--navy-2:#0d2b53;
--red:#d12b2b;
--red-2:#ff5a5a;
--green:#25d366;
--text:#162132;
--muted:#5f6870;
--bg:#f6f9fd;
--panel:rgba(255,255,255,.78);
--panel-strong:rgba(255,255,255,.94);
--soft:#f2f6fb;
--border:rgba(18,30,52,.10);
--border-strong:rgba(255,255,255,.42);
--shadow:0 14px 36px rgba(0,0,0,.06), 0 2px 8px rgba(7,22,45,.04);
--shadow-2:0 26px 64px rgba(7,22,45,.12), 0 4px 16px rgba(209,43,43,.06);
--shadow-3:0 40px 110px rgba(7,22,45,.20), 0 12px 32px rgba(0,0,0,.05);
--radius:22px;
--radius-lg:32px;
--container:1400px;
--ease-premium:cubic-bezier(0.16, 1, 0.3, 1);
--glow-red:0 0 30px rgba(209, 43, 43, 0.35);
--glow-navy:0 0 30px rgba(6, 22, 44, 0.25);
--glow-green:0 0 30px rgba(37, 211, 102, 0.40);
}

*,
*::before,
*::after{
margin:0;
padding:0;
box-sizing:border-box;
}

html{
width:100%;
max-width:100%;
scroll-behavior:smooth;
overflow-x:hidden;
overscroll-behavior-x:none;
}

body{
width:100%;
max-width:100%;
font-family:'Manrope','Poppins',sans-serif;
color:var(--text);
line-height:1.75;
overflow-x:hidden;
position:relative;
isolation:isolate;
word-wrap:break-word;
overflow-wrap:break-word;
background:
radial-gradient(circle at 15% 15%, rgba(209,43,43,.14), transparent 25%),
radial-gradient(circle at 85% 20%, rgba(13,43,83,.12), transparent 25%),
radial-gradient(circle at 50% 50%, rgba(37,211,102,.05), transparent 30%),
radial-gradient(circle at 80% 85%, rgba(209,43,43,.06), transparent 20%),
linear-gradient(180deg, #ffffff 0%, #f5f8fe 35%, #edf3fa 70%, #e4ecf6 100%);
background-attachment:fixed;
}

body::before,
body::after{
content:"";
position:fixed;
width:560px;
height:560px;
border-radius:50%;
z-index:-3;
pointer-events:none;
filter:blur(90px);
opacity:.20;
animation:floatAura 28s cubic-bezier(0.4, 0, 0.2, 1) infinite alternate;
}

body::before{
top:-220px;
left:-220px;
background:radial-gradient(circle, rgba(209,43,43,.85) 0%, rgba(209,43,43,.28) 45%, transparent 70%);
}

body::after{
right:-220px;
bottom:-220px;
background:radial-gradient(circle, rgba(13,43,83,.90) 0%, rgba(7,22,45,.34) 45%, transparent 70%);
animation-delay:9s;
}

@keyframes floatAura{
from{
transform:translate3d(0,0,0) scale(1) rotate(0deg);
}
to{
transform:translate3d(90px,60px,0) scale(1.15) rotate(10deg);
}
}

#header,
#footer,
main,
section{
width:100%;
display:block;
}

img{
max-width:100%;
display:block;
}

a{
color:inherit;
text-decoration:none;
}

ul{
list-style:none;
}

button,
input,
textarea,
select{
font:inherit;
}

.container{
width:min(92%, var(--container));
max-width:100%;
margin-inline:auto;
}

::selection{
background:rgba(209,43,43,.25);
color:var(--navy);
}

::-webkit-scrollbar{
width:12px;
}

::-webkit-scrollbar-track{
background:#f0f4f9;
}

::-webkit-scrollbar-thumb{
background:linear-gradient(180deg, var(--navy), var(--red), var(--navy-2));
border-radius:999px;
border:3px solid #f0f4f9;
}

/* ========== ORIGINAL HEADER STYLES (PRESERVED) ========== */
.main-header{
position:sticky;
top:0;
z-index:9999;
width:100%;
background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.82));
backdrop-filter:blur(18px) saturate(170%);
-webkit-backdrop-filter:blur(18px) saturate(170%);
border-bottom:1px solid rgba(15,23,42,.07);
box-shadow:0 12px 40px rgba(7,22,45,.05), 0 1px 0 rgba(255,255,255,.90) inset;
}

.header-bar{
min-height:96px;
display:flex;
align-items:center;
justify-content:space-between;
gap:20px;
}

.logo{
display:inline-flex;
align-items:center;
flex-shrink:0;
}

.logo img{
height:68px;
width:auto;
max-width:240px;
object-fit:contain;
filter:
drop-shadow(0 8px 16px rgba(7,22,45,.12))
drop-shadow(0 0 25px rgba(209,43,43,.06));
}

.desktop-nav{
flex:1;
display:flex;
justify-content:center;
}

.desktop-nav > ul{
display:flex;
align-items:center;
gap:32px;
background:rgba(15,23,42,.03);
padding:8px 24px;
border-radius:999px;
border:1px solid rgba(15,23,42,.04);
}

.desktop-nav > ul > li{
position:relative;
}

.desktop-nav > ul > li > a{
font-size:14px;
font-weight:800;
color:var(--navy);
position:relative;
padding:8px 4px;
letter-spacing:.4px;
text-transform:uppercase;
transition:color .25s var(--ease-premium), text-shadow .25s var(--ease-premium);
}

.desktop-nav > ul > li > a:hover{
color:var(--red);
text-shadow:var(--glow-red);
}

.desktop-nav > ul > li > a::after{
content:"";
position:absolute;
left:50%;
transform:translateX(-50%);
bottom:-2px;
width:0%;
height:3px;
border-radius:999px;
background:linear-gradient(90deg, var(--red), var(--red-2));
box-shadow:0 2px 10px rgba(209,43,43,.4);
transition:width .3s var(--ease-premium);
}

.desktop-nav > ul > li > a:hover::after{
width:100%;
}

.dropdown-menu{
position:absolute;
top:calc(100% + 18px);
left:50%;
transform:translateX(-50%) translateY(-8px) scale(.98);
min-width:350px;
max-height:75vh;
overflow:auto;
padding:20px;
background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(251,253,255,.96));
backdrop-filter:blur(18px) saturate(170%);
-webkit-backdrop-filter:blur(18px) saturate(170%);
border-radius:24px;
box-shadow:var(--shadow-3);
border:1px solid rgba(15,23,42,.08);
display:none;
transform-origin:top center;
opacity:0;
animation:dropdownFade .25s var(--ease-premium) forwards;
}

@keyframes dropdownFade{
from{
opacity:0;
transform:translateX(-50%) translateY(-12px) scale(.95);
}
to{
opacity:1;
transform:translateX(-50%) translateY(0) scale(1);
}
}

.dropdown:hover .dropdown-menu{
display:block;
}

.dropdown-menu::-webkit-scrollbar{
width:6px;
}

.dropdown-menu::-webkit-scrollbar-thumb{
background:rgba(7,22,45,.2);
border-radius:999px;
}

.dropdown-title{
font-size:12px;
font-weight:900;
color:var(--muted);
padding:12px 12px 6px;
margin-top:10px;
text-transform:uppercase;
letter-spacing:.8px;
border-top:1px solid rgba(15,23,42,.06);
}

.dropdown-title:first-child{
border-top:none;
margin-top:0;
padding-top:0;
}

.dropdown-menu li a{
display:block;
padding:11px 14px;
margin:3px 0;
border-radius:14px;
font-size:14.5px;
font-weight:600;
color:#283447;
transition:background .25s var(--ease-premium), color .25s var(--ease-premium), transform .25s var(--ease-premium), box-shadow .25s var(--ease-premium);
}

.dropdown-menu li a:hover{
background:linear-gradient(90deg, rgba(209,43,43,.08), rgba(7,22,45,.04));
color:var(--red);
transform:translateX(5px);
box-shadow:0 8px 20px rgba(209,43,43,.06);
}

.header-actions{
display:flex;
align-items:center;
gap:12px;
flex-shrink:0;
}

.call-btn,
.whatsapp-btn,
.secondary-btn,
.hero-call-btn,
.hero-whatsapp-btn{
display:inline-flex;
align-items:center;
justify-content:center;
padding:13px 22px;
border-radius:16px;
font-size:14px;
font-weight:800;
white-space:nowrap;
position:relative;
overflow:hidden;
letter-spacing:.3px;
z-index:1;
transition:transform .3s var(--ease-premium), box-shadow .3s var(--ease-premium), filter .3s var(--ease-premium), background .3s var(--ease-premium);
}

.call-btn::before,
.whatsapp-btn::before,
.secondary-btn::before,
.hero-call-btn::before,
.hero-whatsapp-btn::before{
content:"";
position:absolute;
top:0;
left:-130%;
width:80px;
height:100%;
background:linear-gradient(90deg, transparent, rgba(255,255,255,.65), transparent);
transform:skewX(-30deg);
z-index:-1;
}

.call-btn:hover::before,
.whatsapp-btn:hover::before,
.secondary-btn:hover::before,
.hero-call-btn:hover::before,
.hero-whatsapp-btn:hover::before{
animation:btnShine .9s var(--ease-premium);
}

@keyframes btnShine{
100%{
left:160%;
}
}

.call-btn,
.hero-call-btn{
background:linear-gradient(135deg, #06162c, #112d54 60%, #1a4279);
color:#fff;
box-shadow:0 12px 30px rgba(7,22,45,.2), 0 1px 0 rgba(255,255,255,.15) inset;
}

.call-btn:hover,
.hero-call-btn:hover{
box-shadow:0 16px 36px rgba(7,22,45,.3), var(--glow-navy);
}

.whatsapp-btn,
.hero-whatsapp-btn{
background:linear-gradient(135deg, #25d366, #16b353 65%, #32e875);
color:#fff;
box-shadow:0 12px 30px rgba(37,211,102,.25), 0 1px 0 rgba(255,255,255,.2) inset;
}

.whatsapp-btn:hover,
.hero-whatsapp-btn:hover{
box-shadow:0 16px 36px rgba(37,211,102,.35), var(--glow-green);
}

.secondary-btn{
background:linear-gradient(135deg, #ffffff, #f3f7fc);
color:var(--navy);
border:1px solid rgba(7,22,45,.08);
box-shadow:0 10px 24px rgba(7,22,45,.06);
}

.secondary-btn:hover{
background:linear-gradient(135deg, #f3f7fc, #ffffff);
box-shadow:0 14px 32px rgba(7,22,45,.1);
}

.call-btn:hover,
.whatsapp-btn:hover,
.secondary-btn:hover,
.hero-call-btn:hover,
.hero-whatsapp-btn:hover{
transform:translateY(-3px);
filter:saturate(1.08);
}

.call-btn:active,
.whatsapp-btn:active,
.secondary-btn:active,
.hero-call-btn:active,
.hero-whatsapp-btn:active{
transform:translateY(-1px);
}

.mobile-menu-btn{
display:none;
border:none;
background:transparent;
color:var(--navy);
font-size:34px;
line-height:1;
cursor:pointer;
}

.mobile-nav{
display:none;
}

/* ========== REST OF ORIGINAL STYLES (UNCHANGED) ========== */
.hero{
position:relative;
min-height:85vh;
display:flex;
align-items:center;
justify-content:center;
text-align:center;
padding:160px 20px 120px;
color:#fff;
overflow:hidden;
background:
linear-gradient(135deg, rgba(4,14,28,.92), rgba(13,43,83,.76)),
url('/assets/Images/image.01.jpg');
background-size:cover;
background-position:center;
background-repeat:no-repeat;
box-shadow:inset 0 -1px 0 rgba(255,255,255,.1);
}

.hero::before{
content:"";
position:absolute;
inset:0;
background-image:
linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
background-size:54px 54px;
opacity:.32;
pointer-events:none;
z-index:1;
animation:gridShift 32s linear infinite;
}

@keyframes gridShift{
from{ background-position:0 0; }
to{ background-position:54px 54px; }
}

.hero::after{
content:"";
position:absolute;
inset:0;
background:
radial-gradient(circle at 50% 25%, rgba(209,43,43,.32) 0%, transparent 35%),
radial-gradient(circle at 85% 20%, rgba(37,211,102,.15) 0%, transparent 25%),
radial-gradient(circle at 15% 75%, rgba(255,255,255,.10) 0%, transparent 28%);
pointer-events:none;
z-index:2;
}

.hero-content{
position:relative;
z-index:3;
width:min(100%, 1050px);
margin:auto;
}

.hero-content::before{
content:"";
position:absolute;
top:-140px;
left:-200px;
width:420px;
height:420px;
background:radial-gradient(circle, rgba(255,255,255,.18) 0%, rgba(255,255,255,.06) 40%, transparent 75%);
border-radius:50%;
filter:blur(70px);
animation:heroGlow 12s infinite alternate ease-in-out;
pointer-events:none;
}

@keyframes heroGlow{
from{ transform:translateX(0) scale(1); }
to{ transform:translateX(110px) scale(1.12); }
}

@keyframes pulseGlow{
0%{
box-shadow:0 0 0 0 rgba(209,43,43,.65), 0 12px 24px rgba(209,43,43,.3);
transform:translateY(0);
}
50%{
transform:translateY(-2px);
}
70%{
box-shadow:0 0 0 16px rgba(209,43,43,0), 0 12px 24px rgba(209,43,43,0);
}
100%{
box-shadow:0 0 0 0 rgba(209,43,43,0), 0 12px 24px rgba(209,43,43,0);
transform:translateY(0);
}
}

.hero-tag{
display:inline-flex;
align-items:center;
justify-content:center;
padding:10px 22px;
border-radius:999px;
background:linear-gradient(135deg, rgba(209,43,43,1), rgba(255,90,90,.95));
color:#fff;
font-size:13px;
font-weight:800;
letter-spacing:.6px;
text-transform:uppercase;
margin-bottom:24px;
border:1px solid rgba(255,255,255,.2);
animation:pulseGlow 2.8s infinite;
}

.hero h1{
font-size:clamp(2.4rem, 5.5vw, 5.2rem);
line-height:1.08;
font-weight:900;
letter-spacing:-1.5px;
margin-bottom:22px;
text-wrap:balance;
background:linear-gradient(135deg, #ffffff 30%, #ffdada 75%, #ffffff 100%);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
filter:drop-shadow(0 12px 32px rgba(0,0,0,.5));
}

.hero p{
max-width:880px;
margin:0 auto 38px;
font-size:clamp(1.05rem, 2.2vw, 1.25rem);
color:rgba(255,255,255,.94);
font-weight:500;
text-shadow:0 2px 12px rgba(0,0,0,.3);
}

.hero-buttons{
display:flex;
gap:16px;
justify-content:center;
align-items:center;
flex-wrap:wrap;
}

.services-preview,
.about-preview,
.locations-preview,
.gallery-preview,
.faq-preview,
.contact-cta{
padding:104px 0;
position:relative;
overflow:hidden;
}

.services-preview::before,
.about-preview::before,
.locations-preview::before,
.gallery-preview::before,
.faq-preview::before{
content:"";
position:absolute;
top:0;
left:50%;
transform:translateX(-50%);
width:min(90%, 1240px);
height:1px;
background:linear-gradient(90deg, transparent, rgba(209,43,43,.35), rgba(13,43,83,.25), transparent);
}

.services-preview::after,
.about-preview::after,
.locations-preview::after,
.gallery-preview::after,
.faq-preview::after{
content:"";
position:absolute;
inset:auto -10% -20% -10%;
height:400px;
background:
radial-gradient(circle at 25% 40%, rgba(209,43,43,.06), transparent 35%),
radial-gradient(circle at 75% 60%, rgba(13,43,83,.07), transparent 35%);
pointer-events:none;
z-index:0;
filter:blur(8px);
}

.section-heading{
text-align:center;
margin-bottom:52px;
position:relative;
z-index:1;
}

.section-tag{
display:inline-flex;
align-items:center;
justify-content:center;
padding:8px 18px;
border-radius:999px;
background:linear-gradient(135deg, rgba(255,255,255,.98), rgba(242,246,252,.98));
color:var(--red);
font-size:12.5px;
font-weight:900;
letter-spacing:.6px;
text-transform:uppercase;
margin-bottom:16px;
box-shadow:0 8px 24px rgba(15,23,42,.04);
border:1px solid rgba(15,23,42,.07);
}

.section-heading h2{
font-size:clamp(2rem, 3.5vw, 3rem);
line-height:1.12;
color:var(--navy);
font-weight:900;
text-wrap:balance;
background:linear-gradient(135deg, var(--navy) 40%, var(--navy-2) 75%, var(--red) 100%);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

.section-heading p{
margin-top:14px;
color:var(--muted);
font-size:16.5px;
max-width:840px;
margin-left:auto;
margin-right:auto;
}

.service-grid{
display:grid;
grid-template-columns:repeat(4, minmax(0, 1fr));
gap:26px;
position:relative;
z-index:1;
}

.service-card,
.location-card,
.info-card,
.text-block{
position:relative;
}

.service-card{
display:block;
background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(249,251,254,.98));
backdrop-filter:blur(14px) saturate(150%);
-webkit-backdrop-filter:blur(14px) saturate(150%);
border:1px solid rgba(15,23,42,.08);
border-radius:var(--radius-lg);
padding:36px 30px;
box-shadow:var(--shadow);
transition:transform .4s var(--ease-premium), box-shadow .4s var(--ease-premium), border-color .4s var(--ease-premium), filter .4s var(--ease-premium);
min-height:220px;
overflow:hidden;
}

.service-card:hover,
.location-card:hover,
.info-card:hover,
.text-block:hover{
will-change:transform;
}

.service-card::before,
.location-card::before,
.info-card::before,
.text-block::before{
content:"";
position:absolute;
inset:0;
background:
radial-gradient(circle at 0% 0%, rgba(209,43,43,.08), transparent 35%),
radial-gradient(circle at 100% 100%, rgba(13,43,83,.06), transparent 35%);
opacity:0;
transition:opacity .4s var(--ease-premium);
pointer-events:none;
z-index:0;
}

.service-card::after,
.location-card::after,
.info-card::after,
.text-block::after{
content:"";
position:absolute;
inset:0;
border-radius:inherit;
padding:1.5px;
background:linear-gradient(135deg, rgba(209,43,43,.22), rgba(13,43,83,.10), rgba(255,255,255,.3));
-webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
-webkit-mask-composite:xor;
mask-composite:exclude;
pointer-events:none;
opacity:.8;
transition:background .4s var(--ease-premium), opacity .4s var(--ease-premium);
z-index:1;
}

.service-card > *,
.location-card > *,
.info-card > *,
.text-block > *{
position:relative;
z-index:2;
}

.service-card:hover,
.location-card:hover,
.info-card:hover,
.text-block:hover{
transform:translateY(-10px) scale(1.012);
box-shadow:var(--shadow-2), 0 12px 40px rgba(7,22,45,.06);
border-color:rgba(209,43,43,.25);
filter:saturate(1.04);
}

.service-card:hover::after,
.location-card:hover::after,
.info-card:hover::after,
.text-block:hover::after{
background:linear-gradient(135deg, var(--red-2), rgba(13,43,83,.30), var(--red));
opacity:1;
}

.service-card:hover::before,
.location-card:hover::before,
.info-card:hover::before,
.text-block:hover::before{
opacity:1;
}

.service-card h3{
color:var(--navy);
font-size:1.2rem;
line-height:1.35;
margin-bottom:14px;
font-weight:900;
letter-spacing:-.3px;
}

.service-card p{
color:var(--muted);
font-size:15px;
}

.service-card:nth-child(1){
background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,254,.98)), radial-gradient(circle at 15% 15%, rgba(209,43,43,.06), transparent 30%);
}
.service-card:nth-child(2){
background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,254,.98)), radial-gradient(circle at 15% 15%, rgba(13,43,83,.06), transparent 30%);
}
.service-card:nth-child(3){
background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,254,.98)), radial-gradient(circle at 15% 15%, rgba(37,211,102,.05), transparent 30%);
}
.service-card:nth-child(4){
background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,254,.98)), radial-gradient(circle at 15% 15%, rgba(209,43,43,.06), transparent 30%);
}

.two-column{
display:grid;
grid-template-columns:1.2fr .8fr;
gap:28px;
align-items:start;
position:relative;
z-index:1;
}

.text-block,
.info-card{
background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.99));
backdrop-filter:blur(14px) saturate(150%);
-webkit-backdrop-filter:blur(14px) saturate(150%);
border:1px solid rgba(15,23,42,.08);
border-radius:var(--radius-lg);
padding:36px;
box-shadow:var(--shadow);
overflow:hidden;
}

.text-block p{
color:var(--muted);
margin-bottom:16px;
font-size:16px;
}

.info-card h3{
color:var(--navy);
font-size:1.2rem;
margin-bottom:18px;
font-weight:900;
}

.check-list{
display:grid;
gap:12px;
}

.check-list li{
position:relative;
padding-left:32px;
color:var(--text);
font-size:15.5px;
font-weight:500;
}

.check-list li::before{
content:"✓";
position:absolute;
left:4px;
top:-1px;
color:var(--red);
font-weight:900;
font-size:16px;
text-shadow:0 2px 8px rgba(209,43,43,.3);
}

.location-grid{
display:grid;
grid-template-columns:repeat(4, minmax(0, 1fr));
gap:26px;
position:relative;
z-index:1;
}

.location-card{
display:block;
background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(249,251,254,.98));
backdrop-filter:blur(14px) saturate(150%);
-webkit-backdrop-filter:blur(14px) saturate(150%);
border:1px solid rgba(15,23,42,.08);
border-radius:var(--radius-lg);
padding:32px 26px;
box-shadow:var(--shadow);
transition:transform .4s var(--ease-premium), box-shadow .4s var(--ease-premium), border-color .4s var(--ease-premium);
overflow:hidden;
}

.location-card:hover{
transform:translateY(-10px) scale(1.012);
box-shadow:var(--shadow-2), 0 12px 40px rgba(209,43,43,.06);
border-color:rgba(13,43,83,.22);
}

.location-card h3{
color:var(--navy);
margin-bottom:10px;
font-size:1.12rem;
font-weight:900;
letter-spacing:-.2px;
}

.location-card p{
color:var(--muted);
font-size:14.5px;
}

.gallery-grid{
display:grid;
grid-template-columns:repeat(12, minmax(0, 1fr));
gap:22px;
position:relative;
z-index:1;
}

.gallery-grid img{
width:100%;
height:100%;
object-fit:cover;
border-radius:var(--radius-lg);
box-shadow:var(--shadow);
border:1px solid rgba(15,23,42,.08);
transition:transform .45s var(--ease-premium), box-shadow .45s var(--ease-premium), filter .45s var(--ease-premium);
min-height:230px;
}

.gallery-grid img:hover{
transform:scale(1.03) rotate(-.35deg);
box-shadow:var(--shadow-2), 0 15px 45px rgba(7,22,45,.12);
filter:saturate(1.08) contrast(1.04);
will-change:transform;
}

.gallery-grid img:nth-child(1){ grid-column:span 7; min-height:340px; }
.gallery-grid img:nth-child(2){ grid-column:span 5; min-height:340px; }
.gallery-grid img:nth-child(3){ grid-column:span 5; min-height:270px; }
.gallery-grid img:nth-child(4){ grid-column:span 7; min-height:270px; }

/* FAQ FIXES */
.faq-list{
max-width:960px;
margin:0 auto;
display:grid;
gap:16px;
position:relative;
z-index:1;
}

.faq-list details{
background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.99));
backdrop-filter:blur(14px) saturate(150%);
-webkit-backdrop-filter:blur(14px) saturate(150%);
border:1px solid rgba(15,23,42,.08);
border-radius:var(--radius-lg);
box-shadow:var(--shadow);
overflow:visible;
transition:box-shadow .35s var(--ease-premium), border-color .35s var(--ease-premium);
}

.faq-list details:hover{
box-shadow:var(--shadow-2);
border-color:rgba(209,43,43,.22);
}

.faq-list summary{
cursor:pointer;
list-style:none;
padding:22px 28px;
font-weight:900;
font-size:16px;
color:var(--navy);
position:relative;
padding-right:64px;
border-radius:var(--radius-lg);
user-select:none;
-webkit-user-select:none;
}

.faq-list summary::-webkit-details-marker{
display:none;
}

.faq-list summary::after{
content:"+";
position:absolute;
right:26px;
top:50%;
transform:translateY(-50%);
width:34px;
height:34px;
display:grid;
place-items:center;
border-radius:999px;
background:linear-gradient(135deg, rgba(209,43,43,.12), rgba(255,255,255,.95));
color:var(--red);
font-size:20px;
font-weight:900;
box-shadow:0 6px 16px rgba(209,43,43,.08);
transition:background .3s var(--ease-premium), box-shadow .3s var(--ease-premium), color .3s var(--ease-premium);
line-height:1;
}

.faq-list details[open] summary::after{
content:"×";
transform:translateY(-50%);
background:linear-gradient(135deg, var(--red), var(--red-2));
color:#fff;
box-shadow:var(--glow-red);
font-size:22px;
}

.faq-list p{
padding:0 28px 24px;
color:var(--muted);
font-size:15.5px;
line-height:1.8;
word-break:break-word;
overflow-wrap:break-word;
}

.contact-cta{
background:
radial-gradient(circle at 10% 15%, rgba(209,43,43,.12), transparent 25%),
radial-gradient(circle at 90% 85%, rgba(13,43,83,.14), transparent 25%),
linear-gradient(180deg, #f5f8fc 0%, #e3edf8 100%);
text-align:center;
border-top:1px solid rgba(15,23,42,.06);
border-bottom:1px solid rgba(15,23,42,.06);
}

.contact-cta h2{
color:var(--navy);
font-size:clamp(1.8rem, 3.2vw, 2.7rem);
margin-bottom:12px;
font-weight:900;
line-height:1.15;
letter-spacing:-.6px;
}

.contact-cta p{
color:var(--muted);
max-width:800px;
margin:0 auto 32px;
font-size:16.5px;
}

.main-footer{
background:
radial-gradient(circle at 0% 0%, rgba(209,43,43,.18), transparent 22%),
radial-gradient(circle at 100% 0%, rgba(37,211,102,.12), transparent 22%),
linear-gradient(180deg, #051222, #02070f);
color:#fff;
position:relative;
overflow:hidden;
}

.main-footer::before{
content:"";
position:absolute;
inset:0;
background-image:
linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
background-size:40px 40px;
opacity:.32;
pointer-events:none;
}

.footer-top{
display:grid;
grid-template-columns:1.4fr 1fr 1fr 1fr 1.1fr;
gap:38px;
padding:80px 0;
width:min(92%, var(--container));
margin:0 auto;
position:relative;
z-index:1;
}

.footer-column h3{
font-size:1.1rem;
margin-bottom:22px;
font-weight:900;
color:#fff;
position:relative;
padding-bottom:12px;
letter-spacing:.3px;
}

.footer-column h3::after{
content:"";
position:absolute;
left:0;
bottom:0;
width:50px;
height:2.5px;
border-radius:999px;
background:linear-gradient(90deg, var(--red), rgba(255,255,255,.25));
box-shadow:0 0 15px rgba(209,43,43,.4);
}

.footer-column p,
.footer-column li,
.footer-column a{
color:rgba(255,255,255,.82);
font-size:14.5px;
}

.footer-column p{
margin-bottom:16px;
line-height:1.7;
}

.footer-column ul{
display:grid;
gap:12px;
}

.footer-column a{
transition:color .25s var(--ease-premium), padding-left .25s var(--ease-premium);
display:inline-block;
}

.footer-column a:hover{
color:#fff;
padding-left:4px;
text-shadow:0 0 10px rgba(255,255,255,.3);
}

.footer-bottom{
border-top:1px solid rgba(255,255,255,.08);
padding:24px 0;
width:min(92%, var(--container));
margin:0 auto;
display:flex;
align-items:center;
justify-content:space-between;
gap:20px;
flex-wrap:wrap;
position:relative;
z-index:1;
}

.footer-links{
display:flex;
gap:22px;
flex-wrap:wrap;
}

.footer-links a{
color:rgba(255,255,255,.75);
font-size:14px;
transition:color .2s ease;
}

.footer-links a:hover{
color:#fff;
}

.glow-line{
position:relative;
}

.glow-line::after{
content:"";
position:absolute;
left:50%;
bottom:-14px;
transform:translateX(-50%);
width:min(260px, 62%);
height:3.5px;
border-radius:999px;
background:linear-gradient(90deg, transparent, rgba(209,43,43,1), rgba(37,211,102,.7), transparent);
box-shadow:0 0 20px rgba(209,43,43,.35);
}

.premium-card{
position:relative;
overflow:hidden;
}

.premium-card::before{
content:"";
position:absolute;
top:0;
left:0;
width:16px;
height:16px;
border-top:2px solid var(--red);
border-left:2px solid var(--red);
z-index:2;
pointer-events:none;
}

.premium-card::after{
content:"";
position:absolute;
inset:0;
border-radius:inherit;
padding:1.5px;
background:linear-gradient(135deg, rgba(209,43,43,.25), rgba(7,22,45,.08), rgba(255,255,255,.25));
-webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
-webkit-mask-composite:xor;
mask-composite:exclude;
pointer-events:none;
opacity:.9;
}

.trust-badge{
display:inline-flex;
align-items:center;
gap:10px;
padding:9px 16px;
border-radius:999px;
background:rgba(7,22,45,.05);
color:var(--navy);
font-size:13px;
font-weight:900;
box-shadow:0 8px 20px rgba(15,23,42,.03);
border:1px solid rgba(7,22,45,.07);
letter-spacing:.3px;
}

.trust-badge::before{
content:"";
width:11px;
height:11px;
border-radius:50%;
background:var(--green);
box-shadow:0 0 0 0 rgba(37,211,102,.6);
animation:trustPing 2.2s cubic-bezier(0.25, 0, 0, 1) infinite;
}

@keyframes trustPing{
0%{ box-shadow:0 0 0 0 rgba(37,211,102,.6); }
70%{ box-shadow:0 0 0 14px rgba(37,211,102,0); }
100%{ box-shadow:0 0 0 0 rgba(37,211,102,0); }
}

.floating-whatsapp{
position:fixed;
right:24px;
bottom:24px;
width:68px;
height:68px;
border-radius:50%;
background:linear-gradient(135deg, #25d366, #14b856 65%, #38ef7d);
display:flex;
align-items:center;
justify-content:center;
z-index:9999;
color:#fff;
box-shadow:0 18px 40px rgba(37,211,102,.45), 0 1px 0 rgba(255,255,255,.25) inset;
animation:whatsappPulse 2.4s cubic-bezier(0.25, 0, 0, 1) infinite;
will-change:transform, box-shadow;
}

@keyframes whatsappPulse{
0%{
box-shadow:0 0 0 0 rgba(37,211,102,.55), 0 18px 40px rgba(37,211,102,.35);
transform:translateY(0) scale(1);
}
50%{
transform:translateY(-4px) scale(1.03);
}
70%{
box-shadow:0 0 0 24px rgba(37,211,102,0), 0 18px 40px rgba(37,211,102,.25);
}
100%{
box-shadow:0 0 0 0 rgba(37,211,102,0), 0 18px 40px rgba(37,211,102,.35);
transform:translateY(0) scale(1);
}
}

@media (max-width: 1280px){
.service-grid{ grid-template-columns:repeat(3, minmax(0, 1fr)); gap:24px; }
.location-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
.gallery-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
.gallery-grid img:nth-child(1),
.gallery-grid img:nth-child(2),
.gallery-grid img:nth-child(3),
.gallery-grid img:nth-child(4){ grid-column:span 1; min-height:250px; }
.footer-top{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 1024px){
.header-bar{ min-height:84px; }
.desktop-nav, .header-actions{ display:none; }
.mobile-menu-btn{ display:inline-flex; align-items:center; justify-content:center; }
.mobile-nav{
display:block;
position:fixed;
left:0;
right:0;
top:84px;
max-height:calc(100vh - 84px);
overflow-y:auto;
overflow-x:hidden;
background:rgba(255,255,255,.97);
backdrop-filter:blur(18px) saturate(170%);
-webkit-backdrop-filter:blur(18px) saturate(170%);
border-top:1px solid rgba(15,23,42,.08);
box-shadow:0 24px 50px rgba(7,22,45,.15);
padding:22px;
transform:translateY(-15px);
opacity:0;
visibility:hidden;
pointer-events:none;
transition:transform .3s var(--ease-premium), opacity .3s var(--ease-premium), visibility .3s var(--ease-premium);
z-index:10000;
}
.mobile-nav.is-open{
transform:translateY(0);
opacity:1;
visibility:visible;
pointer-events:auto;
}
.mobile-nav > a,
.mobile-nav > details > summary{
display:block;
width:100%;
padding:15px;
margin-bottom:10px;
border-radius:14px;
background:var(--soft);
color:var(--navy);
font-weight:800;
}
.mobile-nav > details{ margin-bottom:10px; }
.mobile-nav > details > summary{
cursor:pointer;
list-style:none;
position:relative;
user-select:none;
-webkit-user-select:none;
}
.mobile-nav > details > summary::-webkit-details-marker{ display:none; }
.mobile-nav > details > summary::after{
content:"+";
position:absolute;
right:16px;
top:50%;
transform:translateY(-50%);
font-size:20px;
font-weight:900;
color:var(--red);
line-height:1;
}
.mobile-nav > details[open] > summary::after{ content:"×"; transform:translateY(-50%); }
.mobile-submenu{ padding:10px 8px 14px 14px; display:grid; gap:8px; }
.mobile-group-title{ margin-top:12px; margin-bottom:6px; color:var(--muted); font-size:12px; font-weight:900; text-transform:uppercase; letter-spacing:.6px; }
.mobile-submenu a{ display:block; padding:12px 14px; border-radius:12px; background:#f3f6fa; color:#243244; font-size:14.5px; font-weight:600; }
.mobile-cta{ display:grid; gap:12px; margin-top:18px; }
.mobile-cta .call-btn,
.mobile-cta .whatsapp-btn{ width:100%; justify-content:center; }
.service-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
.two-column{ grid-template-columns:1fr; }
.footer-top{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 768px){
.logo img{ height:56px; }
.hero{ min-height:auto; padding:130px 16px 90px; }
.hero-content::before{ width:250px; height:250px; top:-90px; left:-100px; }
.hero-tag{ font-size:12px; padding:8px 16px; }
.hero-buttons{ gap:12px; }
.hero-call-btn, .hero-whatsapp-btn, .secondary-btn{ width:100%; max-width:360px; padding:14px 22px; }
.services-preview, .about-preview, .locations-preview, .gallery-preview, .faq-preview, .contact-cta{ padding:72px 0; }
.service-grid, .location-grid, .gallery-grid, .footer-top{ grid-template-columns:1fr; gap:22px; }
.text-block, .info-card{ padding:28px; }
.service-card, .location-card{ padding:28px 24px; }
.faq-list summary{ padding:18px 20px; padding-right:56px; }
.faq-list p{ padding:0 20px 20px; }
.footer-bottom{ flex-direction:column; text-align:center; justify-content:center; gap:14px; }
.floating-whatsapp{ right:20px; bottom:20px; width:60px; height:60px; }
body{ background-attachment:scroll; }
}

@media (max-width: 480px){
.header-bar{ min-height:76px; }
.logo img{ height:48px; }
.hero{ padding:115px 14px 80px; }
.hero h1{ line-height:1.1; }
.hero p, .text-block p, .service-card p, .location-card p, .faq-list p, .footer-column p{ font-size:14.5px; }
.section-heading{ margin-bottom:34px; }
.section-heading h2{ font-size:1.65rem; }
.footer-column h3{ margin-bottom:16px; }
.mobile-nav{ top:76px; max-height:calc(100vh - 76px); }
}

@media (hover: none) and (pointer: coarse){
.service-card:hover,
.location-card:hover,
.info-card:hover,
.text-block:hover,
.gallery-grid img:hover,
.faq-list details:hover,
.call-btn:hover,
.whatsapp-btn:hover,
.secondary-btn:hover,
.hero-call-btn:hover,
.hero-whatsapp-btn:hover,
.dropdown-menu li a:hover,
.footer-column a:hover{
transform:none;
box-shadow:inherit;
filter:none;
text-shadow:none;
padding-left:inherit;
will-change:auto;
}
.dropdown:hover .dropdown-menu{ display:none; }
}

@media (prefers-reduced-motion: reduce){
*,
*::before,
*::after{
animation:none !important;
transition:none !important;
scroll-behavior:auto !important;
}
}

/* ========== FLOATING PILL HEADER (FORCE OVERRIDE – ADDED AT THE VERY END) ========== */
@media screen and (min-width: 992px) {
    .main-header {
        position: sticky !important;
        top: 20px !important;
        width: calc(100% - 40px) !important;
        max-width: 1400px !important;
        margin: 0 auto !important;
        background: rgba(255, 255, 255, 0.85) !important;
        backdrop-filter: blur(16px) !important;
        -webkit-backdrop-filter: blur(16px) !important;
        border-radius: 60px !important;
        border-bottom: none !important;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05), 0 1px 0 rgba(255, 255, 255, 0.9) inset !important;
        transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
        left: auto !important;
        right: auto !important;
    }
    .main-header.scrolled {
        background: rgba(255, 255, 255, 0.98) !important;
        box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12) !important;
        backdrop-filter: blur(20px) !important;
    }
    .header-bar {
        min-height: 70px !important;
        padding: 0 20px !important;
    }
    .dropdown-menu {
        margin-top: 8px !important;
    }
}

/* On mobile, ensure no gap and full‑width */
@media screen and (max-width: 991px) {
    .main-header {
        top: 0 !important;
        width: 100% !important;
        border-radius: 0 !important;
        margin: 0 !important;
        background: rgba(255, 255, 255, 0.95) !important;
        backdrop-filter: blur(10px) !important;
        border-bottom: 1px solid rgba(15,23,42,.07) !important;
    }
    .header-bar {
        min-height: 84px !important;
        padding: 0 16px !important;
    }
}
/* ===== FOOTER IMPROVEMENTS: TWO‑COLUMN SERVICE LIST & GOLDEN BREATHING GLOW ===== */

/* Make the "All Services" column compact on desktop */
.all-services-column {
    max-width: 360px;
    min-width: 260px;
}

.services-two-column {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 6px 20px !important;
    list-style: none;
    padding: 0;
    margin: 0;
}

.services-two-column li {
    margin: 0;
    padding: 0;
}

.services-two-column a {
    font-size: 0.85rem;
    white-space: nowrap;
    display: inline-block;
    padding: 2px 0;
}

/* Tablet & smaller desktop: allow text wrapping */
@media (max-width: 1200px) {
    .services-two-column a {
        white-space: normal;
    }
}

/* Mobile: single column (your responsive already handles footer columns) */
@media (max-width: 768px) {
    .services-two-column {
        grid-template-columns: 1fr !important;
        gap: 6px !important;
    }
}

/* Golden breathing glow for NexGen Solutions link */
.nexgen-glow-link {
    color: #FFD700 !important;          /* golden colour */
    text-decoration: none !important;
    font-weight: 800 !important;
    display: inline-block;
    padding: 0 4px;
    transition: text-shadow 0.2s ease, color 0.2s ease;
    animation: goldenBreathing 1.8s ease-in-out infinite;
}

@keyframes goldenBreathing {
    0% {
        text-shadow: 0 0 1px rgba(255,215,0,0.3), 0 0 2px rgba(255,215,0,0);
    }
    50% {
        text-shadow: 0 0 6px rgba(255,215,0,0.9), 0 0 12px rgba(255,215,0,0.6);
    }
    100% {
        text-shadow: 0 0 1px rgba(255,215,0,0.3), 0 0 2px rgba(255,215,0,0);
    }
}

.nexgen-glow-link:hover {
    animation: none;
    text-shadow: 0 0 12px #FFD700, 0 0 24px #FFA500;
    color: #FFF8DC !important;
}