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

*{
margin:0;
padding:0;
box-sizing:border-box;
scroll-behavior:smooth;
}

body{
font-family:'Montserrat',sans-serif;
background:#050505;
color:white;
overflow-x:hidden;
}

.bg-animation{
position:fixed;
inset:0;
background:
radial-gradient(circle at 20% 20%, rgba(0,102,255,.15), transparent 25%),
radial-gradient(circle at 80% 30%, rgba(0,102,255,.12), transparent 30%),
radial-gradient(circle at 50% 80%, rgba(0,102,255,.10), transparent 25%),
linear-gradient(to bottom,#000,#050505);
animation:bgmove 15s infinite alternate ease-in-out;
z-index:-5;
}

@keyframes bgmove{
0%{transform:scale(1) translateY(0px)}
100%{transform:scale(1.1) translateY(-20px)}
}

nav{
position:fixed;
top:0;
width:100%;
padding:20px 7%;
display:flex;
justify-content:space-between;
align-items:center;
background:rgba(0,0,0,.72);
backdrop-filter:blur(12px);
border-bottom:1px solid rgba(255,255,255,.08);
z-index:1000;
}

nav img{
height:72px;
filter:drop-shadow(0 0 18px #0066ff);
}

nav ul{
display:flex;
gap:28px;
list-style:none;
}

nav a{
text-decoration:none;
color:white;
font-weight:600;
font-size:.95rem;
letter-spacing:1px;
transition:.3s;
}

nav a:hover{
color:#1f7cff;
}

.hero{
min-height:100vh;
display:flex;
align-items:center;
padding:0 7%;
position:relative;
overflow:hidden;
}

.hero::before{
content:'';
position:absolute;
right:-200px;
top:50%;
transform:translateY(-50%);
width:700px;
height:700px;
background:url('logo.jpeg') center/contain no-repeat;
opacity:.08;
animation:rotateLogo 35s linear infinite;
}

@keyframes rotateLogo{
from{transform:translateY(-50%) rotate(0deg)}
to{transform:translateY(-50%) rotate(360deg)}
}

.hero-content{
position:relative;
z-index:2;
max-width:760px;
}

.hero-sub{
color:#1f7cff;
font-size:1rem;
letter-spacing:3px;
margin-bottom:18px;
font-weight:700;
}

.hero h1{
font-size:5.8rem;
line-height:.95;
font-weight:900;
margin-bottom:28px;
text-transform:uppercase;
background:linear-gradient(to bottom,#fff,#1f7cff);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

.hero p{
font-size:1.15rem;
line-height:1.9;
color:#bdbdbd;
max-width:650px;
margin-bottom:40px;
}

.buttons{
display:flex;
gap:18px;
flex-wrap:wrap;
}

.btn{
padding:16px 34px;
border-radius:60px;
text-decoration:none;
font-weight:700;
letter-spacing:1px;
transition:.35s;
display:inline-flex;
align-items:center;
gap:10px;
}

.primary{
background:linear-gradient(135deg,#0066ff,#0040a5);
color:white;
box-shadow:0 0 30px rgba(0,102,255,.45);
}

.secondary{
border:1px solid rgba(255,255,255,.15);
background:rgba(255,255,255,.05);
color:white;
backdrop-filter:blur(10px);
}

.btn:hover{
transform:translateY(-5px);
}

section{
padding:120px 7%;
position:relative;
}

.section-title{
font-size:3rem;
font-weight:800;
margin-bottom:18px;
text-transform:uppercase;
}

.section-text{
color:#a9a9a9;
margin-bottom:60px;
max-width:760px;
line-height:1.8;
}

.grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
gap:28px;
}

.card{
padding:38px;
border-radius:28px;
background:linear-gradient(145deg,#0c0c0c,#141414);
border:1px solid rgba(255,255,255,.05);
transition:.35s;
position:relative;
overflow:hidden;
}

.card::before{
content:'';
position:absolute;
inset:0;
background:linear-gradient(135deg,rgba(0,102,255,.15),transparent);
opacity:0;
transition:.35s;
}

.card:hover::before{
opacity:1;
}

.card:hover{
transform:translateY(-8px);
border-color:rgba(0,102,255,.4);
}

.card h3{
font-size:1.6rem;
margin-bottom:16px;
color:#1f7cff;
}

.card p{
color:#c0c0c0;
line-height:1.7;
}

.gallery{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
gap:24px;
}

.gallery img{
width:100%;
height:400px;
object-fit:cover;
border-radius:24px;
border:1px solid rgba(255,255,255,.08);
transition:.35s;
}

.gallery img:hover{
transform:scale(1.03);
box-shadow:0 0 30px rgba(0,102,255,.25);
}

form{
display:grid;
gap:22px;
max-width:750px;
}

input,textarea{
padding:18px;
border-radius:18px;
background:#0c0c0c;
border:1px solid rgba(255,255,255,.08);
color:white;
font-size:1rem;
}

footer{
padding:70px 7%;
border-top:1px solid rgba(255,255,255,.08);
text-align:center;
background:#030303;
}

.socials{
display:flex;
justify-content:center;
gap:20px;
margin:30px 0;
flex-wrap:wrap;
}

.socials a{
padding:16px 28px;
border-radius:60px;
text-decoration:none;
background:#0d0d0d;
color:white;
border:1px solid rgba(255,255,255,.08);
transition:.3s;
}

.socials a:hover{
background:#0066ff;
box-shadow:0 0 25px rgba(0,102,255,.5);
}

footer p{
color:#8f8f8f;
line-height:2;
}

@media(max-width:900px){
.hero h1{
font-size:3.7rem;
}
nav{
flex-direction:column;
gap:20px;
}
nav ul{
flex-wrap:wrap;
justify-content:center;
}
.hero{
padding-top:120px;
}
}


/* HERO CINEMATIC */
.hero-video-overlay{
position:absolute;
inset:0;
background:
linear-gradient(rgba(0,0,0,.7),rgba(0,0,0,.82)),
radial-gradient(circle at center, rgba(0,102,255,.18), transparent 45%);
z-index:1;
}

.hero-particles{
position:absolute;
inset:0;
overflow:hidden;
z-index:1;
}

.hero-particles span{
position:absolute;
width:4px;
height:4px;
background:#1f7cff;
border-radius:50%;
opacity:.5;
animation:float 10s infinite linear;
}

@keyframes float{
0%{transform:translateY(100vh) scale(0)}
100%{transform:translateY(-100vh) scale(1)}
}

.stats{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
gap:25px;
margin-top:60px;
}

.stat{
padding:35px;
background:rgba(255,255,255,.03);
border:1px solid rgba(255,255,255,.06);
border-radius:24px;
text-align:center;
backdrop-filter:blur(12px);
}

.stat h2{
font-size:2.8rem;
color:#1f7cff;
margin-bottom:10px;
}

.service-link{
text-decoration:none;
color:white;
}

.why-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
gap:28px;
margin-top:50px;
}

.review{
padding:25px;
border-radius:20px;
background:#0d0d0d;
border:1px solid rgba(255,255,255,.06);
}

.review p{
color:#c9c9c9;
line-height:1.8;
}

.gallery-grid{
column-count:2;
column-gap:24px;
}

.gallery-card{
break-inside:avoid;
margin-bottom:24px;
}

.before-after-slider{
position:relative;
overflow:hidden;
border-radius:20px;
}

.before-after-slider img{
width:100%;
display:block;
}

.sticky-estimate{
position:fixed;
bottom:25px;
right:25px;
z-index:9999;
padding:16px 28px;
border-radius:50px;
background:linear-gradient(135deg,#0066ff,#003ea8);
color:white;
text-decoration:none;
font-weight:700;
box-shadow:0 0 30px rgba(0,102,255,.45);
}



/* LUXURY INDUSTRIAL METALLIC TEXTURE */

body::after{
content:'';
position:fixed;
inset:0;
pointer-events:none;
z-index:-1;
opacity:.22;
background:
linear-gradient(
135deg,
rgba(255,255,255,.015) 0%,
rgba(255,255,255,.008) 25%,
transparent 50%,
rgba(255,255,255,.012) 75%,
transparent 100%
),
repeating-linear-gradient(
90deg,
rgba(255,255,255,.015) 0px,
rgba(255,255,255,.015) 1px,
transparent 1px,
transparent 4px
),
repeating-linear-gradient(
0deg,
rgba(255,255,255,.01) 0px,
rgba(255,255,255,.01) 1px,
transparent 1px,
transparent 5px
);

mix-blend-mode:soft-light;
}

/* Matte black steel effect */

section{
position:relative;
background:
linear-gradient(
to bottom,
rgba(255,255,255,.01),
rgba(0,0,0,.08)
);
backdrop-filter:blur(1px);
}

/* subtle brushed metal sheen */

.card,
.gallery-card{
background:
linear-gradient(
145deg,
#0d0d0d 0%,
#141414 35%,
#111111 60%,
#1a1a1a 100%
);
position:relative;
overflow:hidden;
}

.card::after,
.gallery-card::after{
content:'';
position:absolute;
top:0;
left:-120%;
width:60%;
height:100%;
background:linear-gradient(
90deg,
transparent,
rgba(255,255,255,.035),
transparent
);
transform:skewX(-18deg);
transition:1s;
}

.card:hover::after,
.gallery-card:hover::after{
left:140%;
}

/* subtle concrete grain */

.hero::before{
filter:blur(0px) contrast(1.05);
opacity:.07;
}



/* FLOATING PARTICLE FOG */

.fog-container{
position:fixed;
inset:0;
pointer-events:none;
overflow:hidden;
z-index:-2;
}

.fog{
position:absolute;
width:700px;
height:700px;
border-radius:50%;
background:radial-gradient(circle, rgba(31,124,255,.06), transparent 70%);
filter:blur(60px);
animation:fogMove 28s infinite alternate ease-in-out;
mix-blend-mode:screen;
}

.fog:nth-child(2){
top:20%;
left:60%;
animation-duration:35s;
background:radial-gradient(circle, rgba(255,255,255,.025), transparent 70%);
}

.fog:nth-child(3){
top:60%;
left:15%;
animation-duration:42s;
background:radial-gradient(circle, rgba(31,124,255,.05), transparent 70%);
}

@keyframes fogMove{
0%{
transform:translate(0,0) scale(1);
}
100%{
transform:translate(80px,-40px) scale(1.15);
}
}

/* WEATHERED STEEL UI ACCENTS */

.card,
.gallery-card,
.stat{
position:relative;
overflow:hidden;
border:1px solid rgba(255,255,255,.05);
background:
linear-gradient(
145deg,
#0b0b0b 0%,
#151515 30%,
#111111 65%,
#1b1b1b 100%
);
box-shadow:
inset 0 1px 0 rgba(255,255,255,.03),
0 0 35px rgba(0,0,0,.4);
}

/* brushed steel sweep */

.card::before,
.gallery-card::before,
.stat::before{
content:'';
position:absolute;
top:0;
left:-140%;
width:60%;
height:100%;
background:
linear-gradient(
90deg,
transparent,
rgba(255,255,255,.04),
transparent
);
transform:skewX(-18deg);
transition:1.2s;
}

.card:hover::before,
.gallery-card:hover::before,
.stat:hover::before{
left:160%;
}

/* steel edge glow */

.card::after,
.gallery-card::after,
.stat::after{
content:'';
position:absolute;
inset:0;
border-radius:inherit;
padding:1px;
background:linear-gradient(
135deg,
rgba(31,124,255,.25),
transparent,
rgba(255,255,255,.03)
);
-webkit-mask:
linear-gradient(#fff 0 0) content-box,
linear-gradient(#fff 0 0);
-webkit-mask-composite:xor;
mask-composite:exclude;
pointer-events:none;
}

/* subtle concrete texture */

body::after{
content:'';
position:fixed;
inset:0;
pointer-events:none;
opacity:.08;
background-image:
radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
radial-gradient(rgba(255,255,255,.03) 1px, transparent 1px);
background-size:6px 6px, 12px 12px;
background-position:0 0, 3px 3px;
mix-blend-mode:overlay;
z-index:-1;
}



/* FIXED VISIBLE FOG LAYER */

.fog-container{
position:fixed !important;
inset:0 !important;
pointer-events:none !important;
overflow:hidden !important;
z-index:1 !important;
mix-blend-mode:screen;
}

.fog{
opacity:.9 !important;
filter:blur(90px) !important;
}

nav,
.hero,
section,
footer,
.sticky-estimate{
position:relative;
z-index:5;
}
