body{
margin:0;
font-family:Arial;
background:#0b0b0b;
color:white;
scroll-behavior:smooth;
}
/* NAVBAR */

nav{
position:fixed;
overflow:hidden;
top:0;
width:100%;
display:flex;
align-items:center;
justify-content:flex-start;
gap:40px;
padding:10px 40px;
z-index:1000;
transition:0.3s;

background:
linear-gradient(90deg,#000000 0%,#000000 55%,#7a0000 100%);
border-bottom:1px solid #2a2a2a;
}

nav::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;

background:linear-gradient(
90deg,
transparent 40%,
rgba(255,0,0,0.15) 70%,
rgba(255,0,0,0.25) 100%
);

opacity:0;
transition:0.4s;
pointer-events:none;
}  

nav.scrolled{
background:linear-gradient(
90deg,
rgba(0,0,0,0.75) 0%,
rgba(0,0,0,0.75) 55%,
rgba(122,0,0,0.75) 100%
);
backdrop-filter:blur(14px);
-webkit-backdrop-filter:blur(14px);

padding:6px 40px;

border-bottom:1px solid rgba(255,255,255,0.08);
}

nav.scrolled::before{
opacity:1;
}
  nav.scrolled .logo img{
height:55px;
}
  
.logo img{
height:70px;
transition:0.3s;
}

/* MENU */

.menu{
display:flex;
align-items:center;
gap:25px;
}

.menu a{
color:white;
text-decoration:none;
font-size:18px;
}

.menu a:hover{
color:#ff1c1c;
}

/* HAMBURGER */

.menu-toggle{
display:none;
font-size:32px;
color:white;
cursor:pointer;
margin-left:auto;
}

/* HERO */

.hero{
height:100vh;
display:flex;
align-items:center;
justify-content:center;
text-align:center;

background:
linear-gradient(rgba(0,0,0,0.85),rgba(0,0,0,0.95)),
url("webpic/pozadina.webp") center/cover;
}

.hero-content{
max-width:700px;
padding:20px;
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
text-align:center;
margin:0 auto;
}
.hero-title{
display:flex;
align-items:center;
justify-content:center;
gap:20px;
margin-bottom:10px;
}

.hero-logo{
display:block;
width:clamp(120px, 18vw, 320px);
height:auto;
margin:0 auto 10px auto;

filter:
drop-shadow(0 0 10px rgba(255,255,255,0.3))
drop-shadow(0 0 20px rgba(255,0,0,0.4))
drop-shadow(0 0 40px rgba(255,0,0,0.2));
}

.hero h1{
font-size:90px;
margin:0 0 5px 0;
letter-spacing:3px;
font-weight:700;
color:white;
position:relative;
display:inline-block;
text-align:center;

text-shadow:
0 0 10px rgba(255,255,255,0.3),
0 0 20px rgba(255,0,0,0.4),
0 0 40px rgba(255,0,0,0.2);
}

.hero h1::after{
content:"";
position:absolute;
left:0;
bottom:-5px;
width:100%;
height:2px;

background:linear-gradient(
90deg,
transparent,
#ff1c1c,
transparent
);

box-shadow:
0 0 6px #ff1c1c,
0 0 12px rgba(255,0,0,0.8),
0 0 20px rgba(255,0,0,0.5);

animation:ledLine 3s linear infinite;
}

@keyframes ledLine{

0%{
background-position:-300px;
}

100%{
background-position:300px;
}

}

.hero h2{
font-size:32px;
font-weight:400;
color:#ff1c1c;
margin-top:35px;
position:relative;
display:inline-block;
overflow:hidden;
}

.hero-text{
font-size:18px;
opacity:0.85;
margin-top:15px;
line-height:1.6;
}

.hero h1,
.hero h2,
.hero-text{
text-align:center;
width:100%;
margin-left:auto;
margin-right:auto;
}

.hero-brand{
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
width:100%;
margin:0 auto;
}

/* BUTTON */

.btn{
display:inline-block;
margin-top:60px;
padding:15px 35px;
background:#ff1c1c;
color:white;
text-decoration:none;
font-size:16px;
transition:0.3s;
border-radius:6px;
}
  
.btn-secondary{
background:transparent;
border:2px solid #ff1c1c;
color:#ff1c1c;
margin-top:15px;
display:inline-block;
}

.btn-secondary:hover{
background:#ff1c1c;
color:white;
box-shadow:0 0 15px rgba(255,0,0,0.6);
transform:scale(1.05);
}
  
.btn:not(.btn-secondary):hover{
background:white;
color:black;
box-shadow:0 0 15px rgba(255,0,0,0.6);
transform:scale(1.05);
}
/* WHATSAPP FLOAT BUTTON */

.whatsapp-float{
position:fixed;
bottom:25px;
right:25px;
width:60px;
height:60px;
border-radius:50%;
background:#25D366;
display:flex;
align-items:center;
justify-content:center;
font-size:28px;
color:white;
text-decoration:none;
z-index:999;
box-shadow:0 0 15px rgba(0,0,0,0.5);
transition:0.3s;
animation:whatsapp-pulse 2s infinite;
}

.whatsapp-float:hover{
transform:scale(1.1);
}

/* tooltip */

.whatsapp-float::after{
content:"Pišite nam na WhatsApp";
position:absolute;
bottom:70px;
right:0;
background:#111;
color:white;
padding:6px 12px;
border-radius:6px;
font-size:14px;
opacity:0;
transform:translateY(10px);
transition:0.3s;
white-space:nowrap;
}

.whatsapp-float:hover::after{
opacity:1;
transform:translateY(0);
}

/* pulse efekt */

@keyframes whatsapp-pulse{
0%{box-shadow:0 0 0 0 rgba(37,211,102,0.7);}
70%{box-shadow:0 0 0 15px rgba(37,211,102,0);}
100%{box-shadow:0 0 0 0 rgba(37,211,102,0);}
}

body{
margin:0;
font-family:Arial;
background:#0b0b0b;
color:white;
scroll-behavior:smooth;
overflow-x:hidden;
}

/* SECTION */

#services{
position:relative;
overflow:visible;
background:#000;

/* VISINA SEKCIJE */
min-height:90vh;

padding:120px 0;
}

/* POZADINSKA SLIKA */
#services::before{
content:"";
position:absolute;

top:0;
left:50%;
transform:translateX(-50%);

width:100vw;
height:100%;

background:
linear-gradient(
to bottom,
rgba(0,0,0,0.85),
rgba(0,0,0,0.65),
rgba(0,0,0,0.85)
),
url("https://images.pexels.com/photos/15336274/pexels-photo-15336274.jpeg");

background-size:cover;
background-position:center;
background-repeat:no-repeat;

z-index:0;
pointer-events:none;
}

/* GORNJA LINIJA */
#services::after{
content:"";
position:absolute;
top:0;
left:50%;
transform:translateX(-50%);
width:100vw;
height:2px;

background:#ff1c1c;

box-shadow:
0 0 10px #ff1c1c,
0 0 25px rgba(255,28,28,0.9),
0 0 60px rgba(255,28,28,0.6);

z-index:3;
}

/* DONJA LINIJA */
#services .bottom-glow{
position:absolute;
bottom:0;
left:50%;
transform:translateX(-50%);
width:100vw;
height:2px;

background:#ff1c1c;

box-shadow:
0 0 10px #ff1c1c,
0 0 25px rgba(255,28,28,0.9),
0 0 60px rgba(255,28,28,0.6);

z-index:3;
}

/* SADRZAJ IZNAD SLIKE */
#services{
position:relative;
min-height:1050px;
padding-top:120px;
padding-bottom:120px;
}

#services::before{
top:-20px;
}

#services::after{
bottom:-20px;
}

#services{
scroll-margin-top:80px;
}

.services-header{
text-align:center;
max-width:700px;
margin:0 auto 70px auto;
}

.services-header h2{
font-size:48px;
font-weight:700;
margin-bottom:16px;
letter-spacing:1px;
}

.services-header p{
font-size:18px;
opacity:0.85;
line-height:1.6;
}

/* SERVICES GRID */

.services{
display:flex;
justify-content:center;
gap:34px;
flex-wrap:nowrap;
margin-top:120px;
}
/* SERVICE CARD */

.service-card{
width:300px;
height:420px;
position:relative;
border-radius:14px;
overflow:hidden;
display:flex;
align-items:flex-end;

background-size:110%;
background-position:center;

transition:transform .35s ease, box-shadow .35s ease, background-size .35s ease;
cursor:pointer;
}

.service-card:hover{
transform:scale(1.05);
background-size:120%;

box-shadow:
0 0 15px rgba(255,0,0,0.6),
0 0 40px rgba(255,0,0,0.4);
}

/* TAMNI OVERLAY */

.service-overlay{
background:linear-gradient(
to top,
rgba(0,0,0,0.95) 0%,
rgba(0,0,0,0.8) 40%,
rgba(0,0,0,0.3) 70%,
rgba(0,0,0,0.1) 100%
);

padding:28px;
width:100%;
pointer-events:none;
}

.service-overlay h3{
margin:0 0 10px 0;
font-size:24px;
font-weight:600;

text-shadow:
0 0 8px rgba(255,255,255,0.3);
}

.service-overlay p{
margin:0;
font-size:16px;
opacity:0.9;
line-height:1.5;
}


/* SLIKE ZA USLUGE */

.service-card:nth-child(1){
background-image:url("https://images.pexels.com/photos/20703571/pexels-photo-20703571.jpeg");
background-size:110%;
background-position:center;
background-repeat:no-repeat;
}

.service-card:nth-child(2){
background-image:url("https://images.pexels.com/photos/29504457/pexels-photo-29504457.jpeg?auto=compress&cs=tinysrgb&w=1200");
background-size:110%;
background-position:center;
background-repeat:no-repeat;
}

.service-card:nth-child(3){
background-image:url("Kemijskoslika.jpg");
background-size:110%;
background-position:center;
background-repeat:no-repeat;
}

.service-card:nth-child(4){
background-image:url("https://images.pexels.com/photos/6074540/pexels-photo-6074540.jpeg");

background-size:100%;
background-position:50% 0%;
background-repeat:no-repeat;
}

.service-card:nth-child(5){
background-image:url("https://images.pexels.com/photos/9381011/pexels-photo-9381011.jpeg");
background-size:110%;
background-position:center;
background-repeat:no-repeat;
}

.service-card:nth-child(6){
background-image:url("https://images.pexels.com/photos/2539244/pexels-photo-2539244.jpeg");
background-size:110%;
background-position:left;
}

.service-card:nth-child(7){
background-image:url("https://images.pexels.com/photos/32164493/pexels-photo-32164493.jpeg");
background-size:110%;
background-position:center;
}

/* SCROLL ANIMATION */

.fade-in{
opacity:0;
transform:translateY(40px);
transition:all 0.8s ease;
}

.fade-in.visible{
opacity:1;
transform:translateY(0);
}

.service-hover{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%) scale(0.8);

background:#ff1c1c;
color:#fff;

padding:10px 22px;
border-radius:30px;

font-size:14px;
font-weight:600;
letter-spacing:1px;

opacity:0;
transition:0.35s ease;

z-index:5;
pointer-events:none;
}

.service-card:hover .service-hover{
opacity:1;
transform:translate(-50%,-50%) scale(1);
}

.service-card:hover{
transform:scale(1.05);
background-size:120%;

box-shadow:
0 0 15px rgba(255,0,0,0.6),
0 0 40px rgba(255,0,0,0.4);
}

/* PACKAGES */

.packages{

max-width:1200px;
margin:80px auto;

display:flex;
justify-content:center;
align-items:flex-end;

gap:60px;

position:relative;
z-index:2;

}

.package{
background:#121212;
padding:30px;
border:2px solid #ff1c1c;
border-radius:10px;
}

/* WORK HOURS */

.hours{
text-align:center;
font-size:18px;
}

/* FOOTER */

footer{
background:black;
padding:60px 20px;
text-align:center;
}

.socials a{
color:white;
margin:10px;
text-decoration:none;
}

.socials a:hover{
color:#ff1c1c;
}

/* SCROLL ARROW */

.scroll-arrow{
position:absolute;
left:50%;
transform:translateX(-50%);

bottom:5vh;   /* uvijek 5% od dna ekrana */

color:#ff1c1c;
font-size:34px;
text-decoration:none;

animation:arrowFloat 2.4s ease-in-out infinite;
transition:0.3s;
}

.scroll-arrow:hover{
color:white;
transform:translateX(-50%) scale(1.2);
}

section{
position:relative;
}
  
@keyframes arrowFloat{

0%{
transform:translateX(-50%) translateY(0);
opacity:0.6;
}

50%{
transform:translateX(-50%) translateY(10px);
opacity:1;
}

100%{
transform:translateX(-50%) translateY(0);
opacity:0.6;
}

}





/* POPUP NASLOV */

.popup h2{
margin-top:0;
}

.popup-content h2{

font-size:26px;
font-weight:700;
margin-bottom:15px;

background:linear-gradient(45deg,#cd7f32,#ffb36b);
background-clip:text;
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;

text-shadow:
0 0 10px rgba(205,127,50,0.35);
}

/* OPIS */

.popup-desc{
margin-bottom:25px;
opacity:0.8;
font-size:14px;
}

/* SEKCIJE */

.package-item{
margin-top:20px;
}

.package-item strong{
display:block;
margin-bottom:8px;
font-size:15px;
color:#ddd;
}

/* OPCIJE UNUTARNJE / VANJSKO */

.package-item p{

display:inline-block;

padding:10px 16px;
margin-top:8px;

border-radius:8px;

background:#262626;        /* svjetlije od popup pozadine */
border:1px solid #333;

color:#e5e5e5;

font-weight:600;

cursor:pointer;

transition:all 0.25s ease;
}

.package-item p.active{

background:rgba(205,127,50,0.12);

border:1px solid #cd7f32;

color:#ffb36b;

box-shadow:
0 0 12px rgba(205,127,50,0.35);
}

/* HOVER */

.package-item p:hover{

background:#2f2f2f;

border-color:#cd7f32;

color:#ffb36b;

transform:translateY(-2px);

box-shadow:
0 0 10px rgba(205,127,50,0.25);
}

/* OPCIJE (RADIO POPUP) */

.popup-option{

display:block;
padding:15px;
margin-bottom:12px;

border-radius:8px;
cursor:pointer;

position:relative;

transition:all 0.25s ease;

border:1px solid transparent;
line-height:1.5;
}

/* HOVER OPCIJA */

.popup-option:hover{
background:rgba(255,255,255,0.05);
}

/* RADIO */

.popup-option input{
margin-right:8px;
}

/* ODABRANA OPCIJA */

.popup-option:has(input:checked){

background:rgba(255,28,28,0.08);

border:1px solid rgba(255,28,28,0.6);

box-shadow:
0 0 10px rgba(255,28,28,0.25),
0 0 20px rgba(255,28,28,0.1);
}

.popup-option input:checked + strong{
color:#ff1c1c;
}

/* BUTTON */

.popup-btn{

width:100%;
margin-top:30px;

padding:15px;

border-radius:10px;

font-weight:600;
font-size:15px;

background:linear-gradient(45deg,#ff1c1c,#ff3c3c);

border:none;

cursor:pointer;

transition:0.3s;
}

.popup-btn:hover{

transform:scale(1.04);

box-shadow:
0 0 15px rgba(255,28,28,0.6);
}

/* CLOSE X */

.close-popup{

position:absolute;
top:15px;
right:20px;

font-size:22px;

cursor:pointer;

transition:0.25s;
}

.close-popup:hover{

color:#ff1c1c;

transform:rotate(90deg);
}

/* ANIMACIJE */


/* NAJPOPULARNIJE */

.popular-badge{
position:absolute;
top:-8px;
right:10px;
background:#ff1c1c;
color:white;
font-size:12px;
padding:4px 8px;
border-radius:6px;
font-weight:600;
}

/* KERAMIKA NAPOMENA */

.ceramic-note{
margin-top:8px;
font-size:13px;
color:#ff1c1c;
}

/* REZERVIRAJ GUMB */

.popup-btn{
display:block;
margin-top:20px;
background:#ff1c1c;
color:white;
text-align:center;
padding:12px;
border-radius:6px;
text-decoration:none;
transition:0.3s;
}

.popup-btn:hover{
background:#ff3b3b;
}

/* X GUMB */

.close-popup{
position:absolute;
top:15px;
right:20px;
font-size:28px;
cursor:pointer;
}

/* POPUP NAVIGATION */

.popup-nav{
position:absolute;
top:50%;
left:-70px;
right:-70px;
transform:translateY(-50%);
display:flex;
justify-content:space-between;
pointer-events:none;
}

.popup-arrow{
pointer-events:auto;
font-size:32px;
cursor:pointer;
padding:12px 16px;
background:#111;
border-radius:8px;
transition:0.25s;
user-select:none;

box-shadow:
0 0 10px rgba(255,0,0,0.4),
0 0 25px rgba(255,0,0,0.2);
}

.popup-arrow:hover{
background:#ff1c1c;
transform:scale(1.15);
}

.popup-nav.single-next{
justify-content:flex-end;
}

*{
box-sizing:border-box;
}

html,body{
overflow-x:hidden;
max-width:100%;
}

/* ! PACKAGES */
#packages{
position:relative;
overflow:hidden;
background:#050505;

padding-top:60px;
padding-bottom:450px;

scroll-margin-top:120px;
}

.packages{

max-width:1600px;
margin:80px auto;

display:flex;
justify-content:center;
align-items:flex-end;

gap:60px;

position:relative;
z-index:2;

}

.packages,
.packages-header{
position:relative;
z-index:2;
}

#packages h2{
text-align:center;
font-size:42px;
margin-bottom:25px;
}

#packages p{
text-align:center;
opacity:0.8;
margin-bottom:150px;
}

#packages::before{

content:"";
position:absolute;
top:0;
left:0;

width:100%;
height:100%;

/* UKOSO HIGHLIGHT LINIJE */

background:

linear-gradient(120deg, transparent 10%, rgba(255,255,255,0.28) 12%, transparent 14%),
linear-gradient(120deg, transparent 25%, rgba(255,255,255,0.18) 26%, transparent 27%),
linear-gradient(120deg, transparent 40%, rgba(255,255,255,0.32) 43%, transparent 46%),
linear-gradient(120deg, transparent 55%, rgba(255,255,255,0.20) 57%, transparent 59%),
linear-gradient(120deg, transparent 70%, rgba(255,255,255,0.35) 74%, transparent 78%),
linear-gradient(120deg, transparent 85%, rgba(255,255,255,0.16) 87%, transparent 88%);

animation:shinePulse 7s ease-in-out infinite;

filter:blur(8px);
opacity:0.5;

pointer-events:none;
z-index:0;

}

@keyframes shinePulse{

0%{
opacity:0.45;
}

50%{
opacity:1;
}

100%{
opacity:0.45;
}

}

/* GRID */

#packages{
position:relative;
overflow:hidden;
background:#050505;
padding-bottom:140px;
}

/* CARD */

.package-card{

width:400px;
min-height:560px;

padding:45px 40px;

border-radius:18px;

background:#111;

position:relative;

display:flex;
flex-direction:column;
align-items:center;

text-align:center;

transition:0.4s;
}

.package-price-box{
margin-top:auto;
}

.package-card ul{

flex-grow:1;

display:flex;
flex-direction:column;
justify-content:flex-start;

margin-top:10px;
margin-bottom:30px;

}

.package-btn{
margin-top:auto;
}

.package-card button{
margin-top:auto;
}

.package-card:hover{

transform:scale(1.08) translateY(-12px);

box-shadow:
0 20px 60px rgba(0,0,0,0.8),
0 0 25px rgba(255,28,28,0.4);

z-index:10;

}


/* DIAMOND */

.package-card.diamond{

width:380px;

transform:scale(1.15);
z-index:3;

border:2px solid #7df9ff;

box-shadow:
0 0 20px rgba(0,255,255,0.5),
0 0 60px rgba(0,255,255,0.3);

}

.package-card.diamond:hover{
box-shadow:
0 0 35px rgba(110,231,255,0.9),
0 0 120px rgba(110,231,255,0.5);
}


/* GOLD */

.package-card.gold{

position:relative;

border:2px solid transparent;
border-radius:18px;

background:
linear-gradient(#0b0b0b,#0b0b0b) padding-box,
linear-gradient(90deg,#ff3c00,#ff7a00,#ffd000,#ff7a00,#ff3c00) border-box;

background-size:100% 100%,250% 250%;

box-shadow:
0 0 15px rgba(255,170,0,0.4),
0 0 35px rgba(255,120,0,0.3);

animation:
goldBorder 6s linear infinite,
cardPulse 5s ease-in-out infinite;

transition:0.3s;

will-change:transform,background-position;

}
.package-card.gold:hover{
box-shadow:
0 0 35px rgba(255,200,0,0.9),
0 0 100px rgba(255,200,0,0.5);
}

/* GOLD BORDER */

@keyframes goldBorder{

0%{
background-position:0% 50%;
}

100%{
background-position:200% 50%;
}

}

/* BRONZE */

.package-card.bronze{

border:2px solid transparent;
border-radius:18px;

background:
linear-gradient(#0b0b0b,#0b0b0b) padding-box,
linear-gradient(90deg,#cd7f32,#b87333,#a05a2c,#b87333,#cd7f32) border-box;

background-size:100% 100%,250% 250%;

box-shadow:
0 0 8px rgba(205,127,50,0.25);

animation:
bronzeBorder 10s linear infinite,
cardPulse 5s ease-in-out infinite;

transition:0.3s;

will-change:transform,background-position;

}

.package-card.bronze:hover{
box-shadow:
0 0 30px rgba(205,127,50,0.7),
0 0 80px rgba(205,127,50,0.4);
}

/* BRONZE BORDER */

@keyframes bronzeBorder{

0%{
background-position:0% 50%;
}

100%{
background-position:200% 50%;
}

}

/* PULSE ZA BRONZE I GOLD */

@keyframes cardPulse{

0%{
transform:scale(1);
}

50%{
transform:scale(1.025);
}

100%{
transform:scale(1);
}

}

/* HOVER */

.package-card.gold:hover{
transform:scale(1.06);
}

.package-card.bronze:hover{
transform:scale(1.05);
}

/* ICON */

.package-icon{
font-size:34px;
margin-bottom:8px;
}

/* TITLE */

.package-card h3{
font-size:38px;
margin-top:5px;
margin-bottom:15px;
font-weight:700;
}

/* LIST */
.package-card ul{
list-style:none;
padding:0;
margin-bottom:30px;
}

.package-card li{
position:relative;
padding-left:22px;
margin-bottom:10px;
opacity:0.9;
}

.package-card li::before{
content:"";
position:absolute;
left:0;
top:7px;

width:8px;
height:8px;

background:#ff1c1c;

border-radius:2px;
}

/* BUTTON */

.package-btn{
background:#ff1c1c;
color:white;

border:none;
padding:12px 18px;

border-radius:8px;
cursor:pointer;

font-weight:600;
}

/* BEST OFFER */

.best-offer{

position:absolute;

top:-18px;
left:50%;

transform:translateX(-50%);

background:#ff1c1c;

padding:6px 14px;

border-radius:20px;

font-size:12px;
font-weight:600;

color:white;

box-shadow:
0 0 10px #ff1c1c,
0 0 25px rgba(255,28,28,0.5);
}

.package-card.bronze h3{
color:#cd7f32;
text-align:center;
}

.package-card.bronze{

border:2px solid #cd7f32;

box-shadow:
0 0 10px rgba(205,127,50,0.6),
0 0 25px rgba(205,127,50,0.4),
0 0 40px rgba(205,127,50,0.25);

}

.package-card.gold h3{
color:#ffcc33;
text-align:center;
}

.package-card.diamond h3{
color:#6ee7ff;
text-align:center;
}

/* RANDOM LIGHT LINES */

.light-lines{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
pointer-events:none;
z-index:1;
overflow:hidden;
}

@keyframes lineGlow{

0%{
opacity:0.1;
filter:blur(0.5px);
}

50%{
opacity:0.6;
filter:blur(1px);
}

100%{
opacity:0.1;
filter:blur(0.5px);
}

}

.reservation-link{

margin-left:auto;

padding:10px 20px;

background:black;

color:white;

border:2px solid black;

border-radius:6px;

font-weight:600;

text-decoration:none;

transition:0.3s;

}

.reservation-link:hover{

background:white;

color:black;

transform:scale(1.08);

}

/* MOJ IZBOR PANEL */

#selection-panel{
position:fixed;
top:0;
right:-420px;

width:420px;
height:100%;

background:linear-gradient(180deg,#0f0f0f,#070707);

border-left:2px solid #ff1c1c;

padding:30px;

transition:0.4s;

z-index:2000;

box-shadow:-10px 0 40px rgba(0,0,0,0.7);

display:flex;
flex-direction:column;
}

#selection-panel.active{
right:0;
}

.selection-header h3{
font-size:24px;
font-weight:700;
letter-spacing:1px;
text-transform:uppercase;
}

.selection-header{
display:flex;
justify-content:space-between;
align-items:center;
padding-bottom:15px;
border-bottom:1px solid #222;
margin-bottom:25px;
}

#close-selection{
cursor:pointer;
font-size:22px;
opacity:0.7;
transition:0.2s;
}

#close-selection:hover{
opacity:1;
transform:scale(1.1);
}

.selection-content{
display:flex;
flex-direction:column;
height:100%;
}

.selection-note textarea{
width:100%;
height:80px;
margin-top:10px;
background:#111;
border:1px solid #333;
color:white;
padding:10px;
border-radius:6px;
}

.selection-btn{
margin-top:20px;
width:100%;
padding:14px;

background:linear-gradient(90deg,#ff1c1c,#ff3a3a);

border:none;

color:white;
font-weight:700;

border-radius:8px;

cursor:pointer;

letter-spacing:0.5px;

transition:0.25s;
}

.selection-btn:hover{
transform:translateY(-2px);
box-shadow:0 8px 20px rgba(255,28,28,0.4);
}

.selection-note{
margin-top:auto;
padding-top:20px;
border-top:1px solid #222;
}

.selection-note strong{
display:block;
margin-bottom:8px;
font-size:14px;
letter-spacing:1px;
text-transform:uppercase;
opacity:0.8;
}

.selection-note textarea{
width:100%;
height:90px;

margin-top:5px;

background:#111;
border:1px solid #333;

color:white;
padding:12px;

border-radius:8px;

resize:none;

font-size:14px;

transition:0.25s;
}

.selection-note textarea:focus{
outline:none;
border-color:#ff1c1c;
box-shadow:0 0 8px rgba(255,28,28,0.3);
}

#selection-list{
list-style:none;
padding:0;
margin:0;

flex:1;
overflow-y:auto;
}

#selection-list li{
background:#111;

padding:12px 14px;

border-radius:8px;

margin-bottom:10px;

border:1px solid #222;

display:flex;
justify-content:space-between;
align-items:center;

font-size:14px;
}

#selection-list li:hover{
border-color:#ff1c1c;
}

.clickable{
cursor:pointer;
padding:6px 10px;
border-radius:6px;
transition:0.3s;
}

.clickable:hover{
background:#1a1a1a;
transform:scale(1.03);
}

.package-note{
font-size:14px;
opacity:0.7;
margin-top:10px;
}

.option-changed{
animation:flash 0.4s;
}

@keyframes flash{
0%{background:#333;}
100%{background:transparent;}
}

.package-item p{
color:#ff1c1c;
font-weight:600;
cursor:pointer;
transition:0.25s;
}

.package-item p:hover{
color:white;
transform:translateX(5px);
}



/* =========================
   ANIMACIJE
========================= */



/* =========================
   CLOSE BUTTON
========================= */

.close-popup{
position:absolute;
top:18px;
right:22px;

font-size:24px;
cursor:pointer;

transition:0.25s;
}

.close-popup:hover{
color:#ff1c1c;
transform:rotate(90deg);
}

/* =========================
   PACKAGE BADGE
========================= */

.package-badge{

display:inline-block;

padding:10px 22px;

border-radius:30px;

font-size:18px;
font-weight:700;

margin-bottom:25px;

letter-spacing:0.6px;
}

/* BRONZE */

.package-badge.bronze{

background:linear-gradient(45deg,#cd7f32,#ffb36b);

color:#1a1a1a;

box-shadow:
0 0 12px rgba(205,127,50,0.5),
0 0 30px rgba(205,127,50,0.15);
}

/* =========================
   PODNASLOV
========================= */

.popup-desc{

margin-bottom:35px;

font-size:18px;

color:#ffffff;

font-weight:600;

letter-spacing:0.3px;
}

/* =========================
   SEKCIJE
========================= */

.package-item{
margin-bottom:28px;
}

.package-item strong{

display:block;

margin-bottom:10px;

font-size:16px;

color:#ffffff;

font-weight:700;
}

/* =========================
   OPCIJE (kartice)
========================= */

.package-item p{

display:block;

padding:14px 20px;

margin-top:10px;

border-radius:10px;

background:#262626;

border:1px solid #333;

color:#ffffff;

font-weight:600;

cursor:pointer;

transition:all 0.25s ease;

max-width:360px;
}

/* HOVER */

.package-item p:hover{

background:#2f2f2f;

border-color:#cd7f32;

color:#ffb36b;

transform:translateY(-2px);

box-shadow:
0 0 12px rgba(205,127,50,0.3);
}

/* =========================
   DONJA NAPOMENA
========================= */

.popup-note{

margin-top:25px;

font-size:15px;

color:#ffffff;

font-weight:600;

opacity:0.95;
}

.popup-note::before{
content:"💡 ";
}

/* =========================
   BUTTON
========================= */

.popup-btn{

margin-top:28px;

padding:12px 26px;

border-radius:10px;

font-weight:600;

font-size:14px;

background:linear-gradient(45deg,#ff1c1c,#ff3c3c);

border:none;

cursor:pointer;

transition:0.25s;

width:auto;
}

.popup-btn:hover{

transform:scale(1.05);

box-shadow:
0 0 10px #ff1c1c,
0 0 25px rgba(255,28,28,0.7);
}

/* =========================
   PACKAGE PRICE
========================= */


.package-price-box{

margin-top:10px;
margin-bottom:25px;

display:flex;
flex-direction:column;
align-items:center;

}
.price-label{
display:block;
font-size:12px;
letter-spacing:2px;
color:#aaa;
margin-bottom:6px;
text-transform:uppercase;
}

.package-price{
font-size:36px;
font-weight:700;
color:#ffffff;
line-height:1.2;
}

.package-more{

font-size:13px;
opacity:0.75;

margin-top:auto;
margin-bottom:35px;

text-align:center;

line-height:1.4;

cursor:pointer;

transition:0.3s;

max-width:220px;

}

.package-more:hover{
opacity:1;
color:#ffffff;
}

.packages-container{
display:flex;
justify-content:center;
gap:40px;
flex-wrap:wrap;
}

.package-price-box{
margin-top:50px;
margin-bottom:35px;
}

.popup-services{

margin:25px 0;

display:flex;
flex-direction:column;
gap:12px;

}

.popup-service{

background:#1a1a1a;

padding:12px 16px;

border-radius:8px;

border:1px solid #333;

font-size:14px;

}

.bronze-title{

color:#cd7f32;

font-size:28px;

margin-bottom:25px;

}

.bronze-services{

display:flex;

justify-content:space-between;

gap:40px;

text-align:left;

}

.bronze-column h4{

color:#fff;

margin-bottom:10px;

}

.bronze-column ul{

list-style:none;

padding:0;

}

.bronze-column li{

padding:6px 0;

color:#ccc;

font-size:14px;

}

.bronze-grid{

display:flex;

justify-content:space-between;

gap:80px;

margin-top:25px;

}


.bronze-col h3{

font-size:20px;

color:#ffffff;

margin-bottom:15px;

letter-spacing:1px;

}


.service-list{

list-style:none;

padding:0;

margin:0;

}


.service-list li{

position:relative;

padding-left:28px;

margin-bottom:10px;

color:#d6d6d6;

font-size:15px;

}


.service-list li::before{

content:"✓";

position:absolute;

left:0;

color:#cd7f32;

font-weight:bold;

font-size:16px;

}

.popup-btn{
display:block;
margin:30px auto 0 auto;
}


.package-header{
font-size:28px;
font-weight:700;
text-align:center;
padding:14px;
border-radius:10px;
margin-bottom:15px;
letter-spacing:1px;
}

/* GOLD */

.package-header.gold{
background:linear-gradient(135deg,#FFD700,#C9A227);
color:#111;
box-shadow:0 0 15px rgba(255,215,0,0.4);
}

/* DIAMOND */

.package-header.diamond{
background:linear-gradient(135deg,#e6f0ff,#9fb4d9);
color:#111;
box-shadow:0 0 15px rgba(170,190,255,0.5);
}

/* GOLD */

.gold-title{
color:#FFD700;
text-align:center;
font-size:28px;
margin-bottom:20px;
text-shadow:0 0 8px rgba(255,215,0,0.6);
}

/* DIAMOND */

.diamond-title{
color:#9fb4ff;
text-align:center;
font-size:28px;
margin-bottom:20px;
text-shadow:0 0 10px rgba(160,190,255,0.7);
}

/* GOLD NASLOV U POPUPU */

.popup-content h2.gold-title{
background:none;
background-clip:unset;
-webkit-text-fill-color:unset;
color:#FFD700;
}

/* DIAMOND NASLOV U POPUPU */

.popup-content h2.diamond-title{
background:none;
background-clip:unset;
-webkit-text-fill-color:unset;
color:#9fb4ff;
}

.package-item .clickable{
cursor:pointer;
padding:8px 10px;
border-radius:8px;
transition:0.2s;
}

.package-item .clickable:hover{
background:#1a1a1a;
}

.package-item .clickable.active{
background:#262626;
border:1px solid #ff1c1c;
color:#fff;
box-shadow:0 0 10px rgba(255,28,28,0.25);
}

#selection-warning{
background:#ff1c1c;
color:white;
padding:10px 14px;
border-radius:6px;
font-size:14px;
margin-bottom:15px;
display:none;
animation:fadeWarning 0.3s;
}

@keyframes fadeWarning{
from{opacity:0;transform:translateY(-5px);}
to{opacity:1;transform:translateY(0);}
}

.selected-package{
display:flex;
justify-content:space-between;
align-items:center;
font-weight:600;
}

.remove-package{
background:none;
border:none;
color:#ff3b3b;
font-size:18px;
cursor:pointer;
}

.package-sub{
margin-left:15px;
opacity:0.8;
font-size:14px;
}

#selection-list li{
display:flex;
justify-content:space-between;
align-items:center;
gap:10px;
}

.remove-service{
background:none;
border:none;
color:#ff3b3b;
font-size:16px;
cursor:pointer;
}

.remove-service:hover{
color:#ff0000;
}

.packages-divider{

position:absolute;
bottom:0;
left:50%;

transform:translateX(-50%);

width:100vw;
height:2px;

background:#ff1c1c;

box-shadow:
0 0 10px #ff1c1c,
0 0 25px rgba(255,28,28,0.9),
0 0 60px rgba(255,28,28,0.6);

z-index:3;

}

.gallery-divider{
    width:70%;
    height:1px;
    margin:100px auto;

    background:linear-gradient(
        to right,
        transparent,
        rgba(255,0,0,0.9),
        transparent
    );

    box-shadow:
        0 0 10px rgba(255,0,0,0.7),
        0 0 30px rgba(255,0,0,0.4);

    opacity:0.9;
}

#packages{
position:relative;
}

.before-after-section{
    text-align: center;
    margin: 120px 0;
    padding-top: 40px;
    border-top: 1px solid rgba(255,255,255,0.1);
}

.before-after-slider{
position:relative;
max-width:600px;
margin:auto;
overflow:hidden;
}

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

/* BEFORE overlay */

.before-wrapper{
position:absolute;
top:0;
left:0;
width:50%;
height:100%;
overflow:hidden;
}

.before-wrapper img{
width:100%;
height:100%;
object-fit:cover;
}

.compare-wrapper{
    position:relative;
    width:95%;
    max-width:1150px;
    height:1000px;
    margin:80px auto;
    overflow:hidden;
    border-radius:22px;
    background:rgba(255,255,255,0.03);
    box-shadow:0 25px 70px rgba(0,0,0,0.55);
}

.compare-base,
.compare-top{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:contain;
    object-position:center;
    z-index:2;
    filter:drop-shadow(0 10px 25px rgba(0,0,0,0.35));
}

.compare-overlay{
    position:absolute;
    inset:0;
    z-index:2;
    overflow:hidden;
    clip-path: inset(0 50% 0 0);
    -webkit-clip-path: inset(0 50% 0 0);
}

.compare-divider{
    position:absolute;
    top:0;
    left:50%;
    transform:translateX(-50%);
    width:2px;
    height:100%;
    background:rgba(255,255,255,0.75);
    z-index:3;
}

.compare-handle{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    width:42px;
    height:42px;
    background:white;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    box-shadow:0 0 10px rgba(0,0,0,0.4);
    z-index:4;
    pointer-events:none;
}

.compare-slider{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    opacity:0;
    cursor:ew-resize;
    z-index:5;
}
/* handle */

.compare-handle{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%);
width:40px;
height:40px;
background:white;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
gap:6px;
box-shadow:0 0 10px rgba(0,0,0,0.4);
pointer-events:none;
}

.compare-bg{
    position:absolute;
    inset:80px 140px; /* smanji blur samo oko slike */
    z-index:0;
    background-size:cover;
    background-position:center;
    filter:blur(30px) brightness(0.35);
    transform:scale(1.08);
    border-radius:18px;
    filter:blur(22px) brightness(0.5);
}

.compare-bg::after{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(0,0,0,0.4); /* dodatno smiri pozadinu */
}
/* strelice */

.arrow-left,
.arrow-right{
width:0;
height:0;
border-top:6px solid transparent;
border-bottom:6px solid transparent;
}

.arrow-left{
border-right:8px solid black;
}

.arrow-right{
border-left:8px solid black;
}

#gallery{
padding:80px 20px;
background:#0b0b0b;
color:white;
text-align:center;
position:relative;
}

#gallery .scroll-arrow{
    position:absolute;
    left:50%;
    bottom:48px;
    transform:translateX(-50%);
    z-index:6;
    color:#ff1c1c;
    font-size:48px;
    text-decoration:none;
    animation:arrowFloat 2.4s ease-in-out infinite;
    transition:0.3s;
    text-shadow:
        0 0 10px #ff1c1c,
        0 0 20px rgba(255,0,0,0.6);
}

#gallery .scroll-arrow:hover{
    color:white;
    transform:translateX(-50%) scale(1.25);
}
.slider-wrapper{
position:relative;
max-width:1200px;
margin:auto;
overflow:hidden;
}

.slider{
display:flex;
gap:20px;
transition:transform 0.5s ease;
}

.slider img{
width:calc(100% / 5 - 16px);
height:220px;
object-fit:cover;
border-radius:12px;
opacity:0.6;
transition:0.3s;
}

/* aktivna srednja */
.slider img:hover{
opacity:1;
transform:scale(1.05);
}

/* glow efekt */
.slider img{
box-shadow:0 0 20px rgba(0,255,255,0.1);
}

/* strelice */
.nav{
position:absolute;
top:50%;
transform:translateY(-50%);
background:rgba(0,0,0,0.6);
border:none;
color:white;
font-size:30px;
padding:10px 15px;
cursor:pointer;
border-radius:50%;
z-index:20; /* malo više za sigurnost */
transition:0.3s;
}

.nav:hover{
background:rgba(255,255,255,0.2);
}

/* POZICIJE (VRATI U VIEW) */
.prev{
left:400px;
}

.next{
right:400px;
}

#gallery{
    position:relative;
    overflow:hidden;
    padding-bottom:140px; /* ostavi prostor za strelicu iznad crte */
}

.gallery-bottom-glow{
    position:absolute;
    left:50%;
    bottom:0;
    transform:translateX(-50%);
    width:100vw;
    height:2px;
    background:#ff1c1c;
    box-shadow:
        0 0 10px #ff1c1c,
        0 0 25px rgba(255,28,28,0.9),
        0 0 60px rgba(255,28,28,0.6);
    z-index:3;
}

#gallery h2{
 text-align: center !important;
color:white;
font-size:32px;
margin-bottom:60px;
letter-spacing:1px;
}

.carousel{
position:relative;
height:650px;
  margin-bottom: 120px;
}

.carousel img{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%, -50%);
width:340px;
aspect-ratio:9/16;
object-fit:cover;
object-position:center 40%;
border-radius:14px;
transition:all 0.5s ease;
opacity:0;

}

.carousel img.active:hover{
transform:translate(-50%, -50%) scale(1.2);
}

/* AKTIVNA */
.carousel img.active{
transform:translate(-50%, -50%) scale(1.15);
opacity:1;
z-index:5;
}

/* PRVA LIJEVO */
.carousel img.left{
transform:translate(-160%, -50%) scale(0.75);
opacity:0.6;
}


/* PRVA DESNO */
.carousel img.right{
transform:translate(60%, -50%) scale(0.75);
opacity:0.6;
}

/* DRUGA LIJEVO */
.carousel img.left2{
transform:translate(-250%, -50%) scale(0.6);
opacity:0.3;
}

/* DRUGA DESNO */
.carousel img.right2{
transform:translate(150%, -50%) scale(0.6);
opacity:0.3;
}

.carousel-controls{
display:flex;
justify-content:center;
gap:20px;
margin-bottom:20px;
}

.carousel-controls button{
background:#111;
color:white;
border:none;
font-size:28px;
padding:10px 20px;
cursor:pointer;
border-radius:8px;
transition:0.3s;
}

.carousel-controls button:hover{
background:#333;
}




/* NORMALNE POZICIJE (unutar okvira) */

@keyframes glowMove{
0%{background-position:0% 50%;}
100%{background-position:200% 50%;}
}


.split-video{
display:flex;
gap:10px;
justify-content:center;
margin:50px auto;
}

.split-video video{
width:250px;
aspect-ratio:9/16;
object-fit:cover;
border-radius:12px;
}

.single-video{
display:flex;
justify-content:center;
margin:80px auto;
}

.single-video video{
width:280px;
aspect-ratio:9/16;
object-fit:cover;
border-radius:12px;
display:block;
}

#lightbox{
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.6);
backdrop-filter:blur(20px);
-webkit-backdrop-filter:blur(20px);
display:flex;
justify-content:center;
align-items:center;
opacity:0;
pointer-events:none;
transition:0.4s ease;
z-index:9999;
transition:opacity 0.3s ease;
}

#lightbox::before{
content:"";
position:absolute;
width:500px;
height:500px;
background:radial-gradient(circle, rgba(255,255,255,0.1), transparent);
filter:blur(100px);
z-index:-1;
}

/* aktivan */
#lightbox.active{
opacity:1;
pointer-events:all;
}

/* slika */
#lightbox img{
max-width:90%;
max-height:90%;
border-radius:16px;
transform:scale(1);
opacity:1;
transition:transform 0.4s ease, opacity 0.4s ease, filter 0.4s ease;
box-shadow:0 20px 60px rgba(0,0,0,0.8);
}

/* izlaz stare slike */
.lb-exit-left{
transform:translateX(-100px) scale(0.95);
opacity:0;
filter:blur(5px);
}

.lb-exit-right{
transform:translateX(100px) scale(0.95);
opacity:0;
filter:blur(5px);
}

/* ulaz nove slike */
.lb-enter{
transform:scale(1.05);
opacity:1;
filter:blur(0);
}

/* gumbi */
.lb-prev, .lb-next, .lb-close{
position:absolute;
display:flex;
align-items:center;
justify-content:center;
width:52px;
height:52px;
padding:0;
background:rgba(255,255,255,0.08);
backdrop-filter:blur(10px);
-webkit-backdrop-filter:blur(10px);
color:white;
border:1px solid rgba(255,255,255,0.2);
font-size:24px;
line-height:1;
cursor:pointer;
border-radius:12px;
transition:0.3s ease;
z-index:10001;
}
.lb-prev:hover, .lb-next:hover, .lb-close:hover{
background:rgba(255,255,255,0.2);
box-shadow:0 0 15px rgba(255,255,255,0.3);
transition:all 0.25s ease;
}


/* pozicije */
.lb-prev{ left:30px; top:50%; transform:translateY(-50%); }
.lb-next{ right:30px; top:50%; transform:translateY(-50%); }
.lb-close{ top:30px; right:30px; font-size:26px; }

#lightbox{
z-index:9999;
}

#lightbox img{
z-index:10000;
}

.lb-prev,
.lb-next,
.lb-close{
z-index:10001;
}

.service-card{
width:300px;
height:420px;
position:relative;
border-radius:14px;
overflow:hidden;
display:flex;
align-items:flex-end;
background-size:110%;
background-position:center;
background-repeat:no-repeat;
cursor:pointer;
opacity:1;
pointer-events:auto;
transform:none;
filter:none;
transition:transform .35s ease, box-shadow .35s ease, background-size .35s ease;
will-change:transform;
}

.service-card:hover{
transform:scale(1.05);
background-size:120%;
box-shadow:
0 0 15px rgba(255,0,0,0.6),
0 0 40px rgba(255,0,0,0.4);
}

.service-card::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:linear-gradient(to top, rgba(0,0,0,0.45), rgba(0,0,0,0.05));
pointer-events:none;
}

#gallery{
    position: relative;
    background-image: url('https://images.pexels.com/photos/1756957/pexels-photo-1756957.jpeg');
    background-size: cover;
    background-position: center;
}

#gallery::before{
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.7); /* tamni sloj */
    z-index: 0;
}

#gallery > *{
    position: relative;
    z-index: 1;
}
#gallery::before{
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(3px);
}

.compare{
    position:relative;
    display:flex;
    justify-content:center;
}

.compare-nav{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    z-index:10;

    background:rgba(0,0,0,0.6);
    border:none;
    color:white;
    font-size:22px;
    padding:10px 14px;
    cursor:pointer;
    border-radius:50%;
    transition:0.3s;
}

.compare-nav:hover{
    background:rgba(255,255,255,0.2);
}

/* lijeva */
.compare-nav.prev{
    left: 650px;
}

/* desna */
.compare-nav.next{
    right: 650px;
}

.compare-base,
.compare-top{
    transition:
        opacity 0.35s ease,
        transform 0.35s ease;
}

.compare-bg{
    transition:
        opacity 0.45s ease,
        transform 0.45s ease,
        background-image 0s;
}

.compare-fade-out{
    opacity:0;
    transform:translateY(8px) scale(0.985);
}

.compare-fade-in{
    opacity:1;
    transform:scale(1);
}

.section-title{
    position:relative;
    display:inline-block;
    z-index:1;
}

.section-title::before{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    
    width:140%;
    height:140%;

    background:radial-gradient(
        ellipse,
        rgba(255, 0, 0, 0.45) 0%,
        rgba(255, 0, 0, 0.25) 30%,
        rgba(255, 0, 0, 0.12) 55%,
        rgba(255, 0, 0, 0.05) 75%,
        transparent 100%
    );

    filter:blur(22px);
    z-index:-1;
    pointer-events:none;
}

.social-grid{
    max-width:1500px;
    margin:80px auto 0;
    display:grid;
    grid-template-columns:repeat(3, minmax(320px, 1fr));
    gap:42px;
    justify-items:center;
    align-items:start;
}

.social-item{
    width:100%;
    max-width:420px;
}

.social-card{
    width:100%;
    min-height:760px;
    border-radius:30px;
    padding:34px 26px 28px;
    position:relative;
    overflow:hidden;
    text-decoration:none;
    color:white;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    transition:0.35s ease;
    background:rgba(10,10,10,0.84);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,0.08);
    box-shadow:
        0 24px 60px rgba(0,0,0,0.45),
        inset 0 1px 0 rgba(255,255,255,0.04);
}

.social-card.facebook .social-media img{
    object-fit:cover;
    object-position:30% center; /* pomak ulijevo */
}

.social-card:hover{
    transform:translateY(-8px) scale(1.015);
    filter:brightness(1.05);
}

.social-card::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(
        180deg,
        rgba(255,255,255,0.08) 0%,
        rgba(255,255,255,0.02) 18%,
        rgba(255,255,255,0) 42%
    );
    pointer-events:none;
}

.social-top{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    margin-top:4px;
    margin-bottom:30px;
    position:relative;
    z-index:2;
}

.social-top img{
    width:30px;
    height:30px;
    object-fit:contain;
    opacity:0.95;
}

.social-top span{
    font-size:38px;
    font-weight:800;
    letter-spacing:0.3px;
    line-height:1;
}

.social-media,
.video-wrapper{
    width:100%;
    max-width:300px;
    aspect-ratio:9 / 16;
    border-radius:24px;
    overflow:hidden;
    background:#000;
    display:flex;
    align-items:center;
    justify-content:center;
    position:relative;
    z-index:2;
    border:1px solid rgba(255,255,255,0.08);
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,0.03),
        0 16px 36px rgba(0,0,0,0.35);
}

.social-media img,
.video-wrapper img{
width:100%;
height:100%;
display:block;
background:#000;
object-fit:cover;
object-position:center;
}

.social-desc{
    width:100%;
    margin-top:28px;
    text-align:center;
    font-size:16px;
    line-height:1.6;
    padding:0 10px;
    position:relative;
    z-index:2;
    opacity:0.96;
}

/* INSTAGRAM */
.social-card.instagram{
    background:
        radial-gradient(circle at 18% 18%, rgba(131,58,180,0.45), transparent 30%),
        radial-gradient(circle at 85% 15%, rgba(253,29,29,0.40), transparent 30%),
        radial-gradient(circle at 80% 85%, rgba(252,176,69,0.35), transparent 34%),
        radial-gradient(circle at 20% 85%, rgba(88,81,219,0.30), transparent 30%),
        linear-gradient(180deg, rgba(22,22,24,0.95), rgba(12,12,14,0.93));
    border:1px solid rgba(255,120,170,0.25);
    box-shadow:
        0 24px 60px rgba(0,0,0,0.45),
        0 0 40px rgba(253,29,29,0.22),
        0 0 70px rgba(131,58,180,0.18);
}

.social-card.instagram::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:30px;
    padding:1.5px;
    background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045,#5851db);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
        mask:
  linear-gradient(#fff 0 0) content-box,
  linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor;
    mask-composite:exclude;
    pointer-events:none;
    opacity:0.9;
}

.social-card.instagram .social-top img{
    filter:brightness(0) invert(1);
}

.social-card.instagram .social-top span{
    background:linear-gradient(90deg,#c56bff,#ff5d7a,#ffca68);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}

.social-card.instagram .social-desc{
    color:#f7dce8;
}

/* TIKTOK */
.social-card.tiktok{
    background:
        radial-gradient(circle at 18% 18%, rgba(0,242,234,0.30), transparent 30%),
        radial-gradient(circle at 82% 18%, rgba(255,0,80,0.30), transparent 30%),
        linear-gradient(180deg, rgba(18,18,18,0.96), rgba(8,8,8,0.94));
    border:1px solid rgba(255,255,255,0.08);
    box-shadow:
        0 24px 60px rgba(0,0,0,0.45),
        -12px 0 32px rgba(0,242,234,0.18),
        12px 0 32px rgba(255,0,80,0.18);
}

.social-card.tiktok::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:30px;
    padding:1.5px;
    background:linear-gradient(135deg, rgba(0,242,234,0.95), rgba(255,0,80,0.95));
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
        mask:
  linear-gradient(#fff 0 0) content-box,
  linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor;
    mask-composite:exclude;
    pointer-events:none;
}

.social-card.tiktok .social-top img{
    filter:brightness(0) invert(1);
}

.social-card.tiktok .social-top span{
    color:#fff;
    text-shadow:
        -1.5px 0 rgba(0,242,234,0.95),
         1.5px 0 rgba(255,0,80,0.95);
}

.social-card.tiktok .social-desc{
    color:#f1f1f1;
}

/* FACEBOOK */
.social-card.facebook{
    background:
        radial-gradient(circle at 18% 18%, rgba(24,119,242,0.35), transparent 30%),
        radial-gradient(circle at 82% 82%, rgba(160,200,255,0.18), transparent 30%),
        linear-gradient(180deg, rgba(18,24,38,0.95), rgba(10,14,22,0.93));
    border:1px solid rgba(120,170,255,0.24);
    box-shadow:
        0 24px 60px rgba(0,0,0,0.45),
        0 0 45px rgba(24,119,242,0.18);
}

.social-card.facebook::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:30px;
    padding:1.5px;
    background:linear-gradient(135deg, rgba(255,255,255,0.85), rgba(24,119,242,0.95), rgba(160,200,255,0.7));
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
        mask:
  linear-gradient(#fff 0 0) content-box,
  linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor;
    mask-composite:exclude;
    pointer-events:none;
}

.social-card.facebook .social-top img{
    filter:
        brightness(0)
        saturate(100%)
        invert(44%)
        sepia(96%)
        saturate(2200%)
        hue-rotate(198deg)
        brightness(100%)
        contrast(100%);
}

.social-card.facebook .social-top span{
    color:#7db0ff;
}

.social-card.facebook .social-desc{
    color:#d9e7ff;
}





@media (max-width:1100px){
    .social-grid{
        grid-template-columns:1fr;
        max-width:420px;
        gap:28px;
    }

    .social-item{
        max-width:420px;
    }

    .social-card{
        min-height:720px;
    }

    .social-top span{
        font-size:34px;
    }

    .social-media,
    .video-wrapper{
        max-width:300px;
    }
}

/* INSTAGRAM – svijetla (bijela) */
.social-card.instagram .social-top img{
    filter:brightness(0) invert(1);
    opacity:0.95;
}

/* TIKTOK – ostaje bijela */
.social-card.tiktok .social-top img{
    filter:brightness(0) invert(1);
    opacity:0.95;
}

/* FACEBOOK – plava */
.social-card.facebook .social-top img{
    filter:
        brightness(0)
        saturate(100%)
        invert(44%)
        sepia(96%)
        saturate(2200%)
        hue-rotate(198deg)
        brightness(100%)
        contrast(100%);
}
/* =========================
   DESKTOP RESTORE FIX
========================= */

@media (min-width: 1101px){

  /* HERO vrati na staro */
  .hero{
    height:100vh !important;
    min-height:100vh !important;
    padding:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
  }

  .hero-content{
    max-width:700px !important;
    padding:20px !important;
  }

  .hero-logo{
    width:300px !important;
    margin-bottom:10px !important;
  }

  .hero h1{
    font-size:90px !important;
    margin:0 0 5px 0 !important;
  }

  .hero h2{
    font-size:32px !important;
    margin-top:35px !important;
    margin-bottom:0 !important;
  }

  .hero-text{
    font-size:18px !important;
    line-height:1.6 !important;
    max-width:700px !important;
    margin-top:15px !important;
  }

  /* NAVBAR vrati desktop */
  nav{
    padding:10px 40px !important;
    gap:40px !important;
  }

  .logo img{
    height:70px !important;
  }

  nav.scrolled{
    padding:6px 40px !important;
  }

  nav.scrolled .logo img{
    height:55px !important;
  }

  .menu{
    position:static !important;
    transform:none !important;
    opacity:1 !important;
    pointer-events:auto !important;
    flex-direction:row !important;
    background:none !important;
    padding:0 !important;
    min-width:auto !important;
    border-radius:0 !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    display:flex !important;
    align-items:center !important;
    gap:25px !important;
  }

  .menu a{
    margin:0 !important;
    font-size:18px !important;
  }

  .menu-toggle{
    display:none !important;
  }

  .reservation-link{
    margin-left:auto !important;
    display:inline-block !important;
  }

  /* USLUGE vrati kako su bile */
 .services{
    display:flex !important;
    justify-content:center !important;
    gap:34px !important;
    flex-wrap:wrap !important;
    margin-top:120px !important;
}
  .service-card{
    width:300px !important;
    height:420px !important;
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    pointer-events:auto !important;
    cursor:pointer !important;
    position:relative !important;
    border-radius:14px !important;
    overflow:hidden !important;
    display:flex !important;
    align-items:flex-end !important;
    background-size:110% !important;
    background-position:center !important;
    background-repeat:no-repeat !important;
  }

  .service-card:hover{
    transform:scale(1.05) !important;
    background-size:120% !important;
    box-shadow:
      0 0 15px rgba(255,0,0,0.6),
      0 0 40px rgba(255,0,0,0.4) !important;
  }

  .service-overlay{
    padding:28px !important;
    width:100% !important;
    pointer-events:none !important;
    background:linear-gradient(
      to top,
      rgba(0,0,0,0.95) 0%,
      rgba(0,0,0,0.8) 40%,
      rgba(0,0,0,0.3) 70%,
      rgba(0,0,0,0.1) 100%
    ) !important;
  }

  .service-overlay h3{
    font-size:24px !important;
    margin:0 0 10px 0 !important;
    color:#fff !important;
    font-weight:600 !important;
  }

  .service-overlay p{
    font-size:16px !important;
    line-height:1.5 !important;
    opacity:0.9 !important;
    color:#fff !important;
    margin:0 !important;
  }

  /* POPUPOVI iznad svega i normalne veličine */

  .popup-content{
    max-width:760px !important;
    width:95% !important;
    padding:55px !important;
    border-radius:20px !important;
    position:relative !important;
    z-index:100000 !important;
  }

  .popup h2{
    font-size:26px !important;
  }

  .popup-desc{
    font-size:18px !important;
    margin-bottom:35px !important;
  }

  .popup-option{
    padding:15px !important;
    margin-bottom:12px !important;
  }

  .popup-btn{
    width:auto !important;
    padding:12px 26px !important;
    font-size:14px !important;
  }

  .close-popup{
    top:18px !important;
    right:22px !important;
    font-size:24px !important;
  }
}

.popup{
  position: fixed;
  inset: 0;
  display: none;
  justify-content: center;
  align-items: center;
  background: rgba(0,0,0,0.78);
  z-index: 999999;
}

.popup.show{
  display: flex;
}



.package-card,
#packages,
#services,
#gallery,
#about,
#booking,
footer{
    z-index:auto !important;
}

.instagram-embed{
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
}

.instagram-embed blockquote{
    max-width:100% !important;
    min-width:100% !important;
    width:100% !important;
    margin:0 !important;
}

.instagram-embed iframe{
    width:100% !important;
    height:100% !important;
    border-radius:20px;
}

/* =========================
   GALLERY END CTA
========================= */

.gallery-end{
    margin-top:120px;
    padding:80px 20px;

    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;

    position:relative;
}


.gallery-end-content{
    position:relative;
    z-index:1;

    max-width:700px;
}

.gallery-end h3{
    font-size:32px;
    margin-bottom:15px;
}

.gallery-end p{
    opacity:0.85;
    margin-bottom:30px;
    line-height:1.6;
}

/* BUTTON */

.gallery-btn{
    display:inline-block;
    padding:14px 28px;

    background:#ff1c1c;
    color:white;

    border-radius:8px;
    text-decoration:none;

    font-weight:600;
    letter-spacing:0.5px;

    transition:0.3s;
}

.gallery-btn:hover{
    background:white;
    color:black;

    transform:scale(1.05);

    box-shadow:
        0 0 15px rgba(255,0,0,0.6);
}


/* =========================
   GALLERY BOTTOM LINE
========================= */

.gallery-bottom-glow{
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:100vw;
    height:2px;

    background:#ff1c1c;

    box-shadow:
        0 0 10px #ff1c1c,
        0 0 25px rgba(255,28,28,0.9),
        0 0 60px rgba(255,28,28,0.6);

    z-index:3;
}


/* ===== GALLERY FINAL ARROW FIX ===== */
#gallery{
    position:relative !important;
    padding-bottom:140px !important;
}

#gallery > .scroll-arrow{
    position:absolute !important;
    left:50% !important;
    bottom:26px !important;
    transform:translateX(-50%) !important;
    z-index:10 !important;

    color:#ff1c1c !important;
    font-size:52px !important;
    line-height:1 !important;
    text-decoration:none !important;

    animation:arrowFloat 2.4s ease-in-out infinite !important;
    text-shadow:
        0 0 10px #ff1c1c,
        0 0 20px rgba(255,0,0,0.6) !important;
}

#gallery > .scroll-arrow:hover{
    color:white !important;
    transform:translateX(-50%) scale(1.2) !important;
}

#gallery > .gallery-bottom-glow{
    position:absolute !important;
    left:50% !important;
    bottom:0 !important;
    transform:translateX(-50%) !important;
    width:100vw !important;
    height:2px !important;
    z-index:3 !important;

    background:#ff1c1c !important;
    box-shadow:
        0 0 10px #ff1c1c,
        0 0 25px rgba(255,28,28,0.9),
        0 0 60px rgba(255,28,28,0.6) !important;
}

#about{
    position:relative;
    padding:90px 20px 110px;
    text-align:center;
        min-height:auto !important;
    height:auto !important;

    background:linear-gradient(
        90deg,
        rgba(255,0,0,0.08) 0%,
        rgba(255,0,0,0.15) 25%,
        rgba(255,0,0,0.2) 50%,
        rgba(255,0,0,0.15) 75%,
        rgba(255,0,0,0.08) 100%
    );

    backdrop-filter:blur(12px);
    border-top:1px solid rgba(255,0,0,0.3);
    border-bottom:1px solid rgba(255,0,0,0.3);
}
.about-container{
    max-width:900px;
    margin:auto;
    padding:35px 40px;
}

#about h2{
    font-size:36px;
    margin-bottom:20px;
}

.about-text{
    color:#ccc;
    font-size:16px;
    line-height:1.6;
    margin-bottom:60px;
}

.about-features{
    display:flex;
    justify-content:center;
    gap:30px;
    flex-wrap:wrap;
}

.about-card{
    width:260px;
    padding:25px;
    border-radius:16px;

    background:rgba(0,0,0,0.6);
    border:1px solid rgba(255,0,0,0.2);

    backdrop-filter:blur(10px);
    transition:0.3s;
}

.about-card:hover{
    transform:translateY(-8px);
    border-color:#ff1c1c;

    box-shadow:
        0 0 20px rgba(255,0,0,0.4),
        0 0 40px rgba(255,0,0,0.2);
}
.about-card span{
    font-size:28px;
    display:block;
    margin-bottom:10px;
}

.about-card h4{
    margin-bottom:10px;
    font-size:18px;
}

.about-card p{
    font-size:14px;
    color:#aaa;
}

.about-card:hover{
    transform:translateY(-6px);
    border-color:#ff1c1c;
    box-shadow:0 0 20px rgba(255,0,0,0.2);
}

.section-bottom-glow{
    position:absolute;
    left:50%;
    bottom:0;
    transform:translateX(-50%);
    width:100vw;
    height:2px;
    background:#ff1c1c;
    box-shadow:
        0 0 10px #ff1c1c,
        0 0 25px rgba(255,28,28,0.9),
        0 0 60px rgba(255,28,28,0.6);
}

#about::before{
    content:"";
    position:absolute;
    top:0;
    left:-50%;
    width:200%;
    height:100%;

    background:linear-gradient(
        120deg,
        transparent 30%,
        rgba(255,255,255,0.15) 50%,
        transparent 70%
    );

    animation:shineMove 6s linear infinite;
    pointer-events:none;
}

@keyframes shineMove{
    0%{
        transform:translateX(-50%);
    }
    100%{
        transform:translateX(50%);
    }
}

#about::after{
    content:"";
    position:absolute;
    inset:0;

    background:radial-gradient(
        circle at center,
        rgba(255,0,0,0.15),
        transparent 70%
    );

    pointer-events:none;
}

/* =========================
   ABOUT SECTION
========================= */

#about{
    position:relative;
    padding:70px 20px 90px;
    min-height:auto;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;

    background:
        linear-gradient(90deg, rgba(255,255,255,0.04), transparent 18%, transparent 82%, rgba(255,0,0,0.08)),
        linear-gradient(180deg, rgba(255,0,0,0.10), rgba(0,0,0,0.55) 30%, rgba(0,0,0,0.72) 100%);
}

#about::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 20% 50%, rgba(255,255,255,0.06), transparent 35%),
        radial-gradient(circle at 80% 40%, rgba(255,0,0,0.12), transparent 35%);
    pointer-events:none;
}

.about-container{
    position:relative;
    z-index:1;
    width:min(760px, 92vw);

    padding:30px 36px;
    border-radius:26px;

    background:linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
    border:1px solid rgba(255,255,255,0.10);

    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);

    box-shadow:
        0 18px 50px rgba(0,0,0,0.45),
        inset 0 1px 0 rgba(255,255,255,0.08),
        0 0 35px rgba(255,0,0,0.08);

    text-align:center;
}

.about-badge{
    display:inline-block;
    padding:8px 14px;
    margin-bottom:12px;
    border-radius:999px;

    background:rgba(255,28,28,0.08);
    border:1px solid rgba(255,28,28,0.25);
    color:#ff4b4b;

    font-size:12px;
    font-weight:700;
    letter-spacing:1.2px;
    text-transform:uppercase;
}

.about-container h2{
    font-size:32px;
    line-height:1.15;
    margin:0 0 16px;
    color:#fff;
}

.about-lead{
    font-size:15px;
    line-height:1.65;
    color:rgba(255,255,255,0.9);
    max-width:620px;
    margin:0 auto 16px;
}

.about-content{
    max-width:660px;
    margin:0 auto;
}

.about-content p{
    font-size:14px;
    line-height:1.7;
    color:rgba(255,255,255,0.82);
    margin:0 0 12px;
}

.about-content strong{
    color:#fff;
}

.about-highlight{
    color:#ff6a6a;
    font-weight:700;
}

.about-stats{
    margin-top:20px;
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:14px;
}

.about-stat{
    padding:14px 12px;
    border-radius:18px;

    background:rgba(255,255,255,0.035);
    border:1px solid rgba(255,255,255,0.08);

    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.04),
        0 8px 24px rgba(0,0,0,0.25);

    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
}

.about-stat strong{
    display:block;
    font-size:15px;
    color:#fff;
    margin-bottom:6px;
}

.about-stat span{
    display:block;
    font-size:12px;
    line-height:1.45;
    color:rgba(255,255,255,0.72);
}

#about .scroll-arrow{
    bottom:22px;
}

@media (max-width: 768px){
    #about{
        padding:55px 16px 80px;
    }

    .about-container{
        padding:24px 18px;
        border-radius:22px;
    }

    .about-container h2{
        font-size:26px;
    }

    .about-lead{
        font-size:14px;
    }

    .about-content p{
        font-size:13px;
        line-height:1.65;
    }

    .about-stats{
        grid-template-columns:1fr;
        gap:10px;
    }
}
.about-stat small{
    display:block;
    font-size:14px;
    letter-spacing:0.3px;
    color:rgba(255,255,255,0.76);
}

.about-bottom-glow{
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:100vw;
    height:2px;
    background:#ff1c1c;
    box-shadow:
        0 0 10px #ff1c1c,
        0 0 25px rgba(255,28,28,0.9),
        0 0 60px rgba(255,28,28,0.6);
    z-index:3;
}

#about{
    scroll-margin-top: 80px;
}

#hours-section{
    position:relative;
    padding:80px 20px 100px;
    text-align:center;
    background:#050505;
}

/* BOX */

.hours-box{
    max-width:600px;
    margin:0 auto 30px;

    border-radius:16px;
    overflow:hidden;

    background:#0b0b0b;

    border:2px solid #ff1c1c;
}

/* ROW */

.hours-row{
    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:18px 22px;

    font-size:17px;

    border-bottom:1px solid rgba(255,255,255,0.06);

    transition:0.25s;
}

.hours-row:last-child{
    border-bottom:none;
}

/* HOVER */

.hours-row:hover{
    background:rgba(255,255,255,0.05);
}

/* TEXT */

.hours-row span{
    color:#dcdcdc;
}

.hours-row strong{
    color:#fff;
    font-weight:600;
}

/* CLOSED */

.hours-row.closed strong{
    color:#ff3b3b;
}

/* NOTE */

.hours-note{
    max-width:700px;
    margin:0 auto;
    font-size:15px;
    line-height:1.7;
    color:rgba(255,255,255,0.75);
}

#hours-section h2{
    display:inline-block;

    padding:10px 22px;
    margin-bottom:30px;

    border:2px solid #ff1c1c;
    border-radius:10px;

    color:#fff;
    font-size:26px;
    letter-spacing:1px;

    box-shadow:
        0 0 10px rgba(255,28,28,0.5),
        0 0 25px rgba(255,28,28,0.2);
}

/* =========================
   BOOKING SECTION
========================= */

#booking{
    position:relative;
      padding: 120px 0 280px;
    background:
        linear-gradient(180deg, rgba(255,0,0,0.06), rgba(0,0,0,0.88) 25%, #050505 100%);
    overflow:hidden;
    scroll-margin-top:80px;
}

#booking::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255,0,0,0.12), transparent 30%),
        radial-gradient(circle at 80% 30%, rgba(255,255,255,0.05), transparent 25%),
        radial-gradient(circle at 50% 100%, rgba(255,0,0,0.08), transparent 35%);
    pointer-events:none;
}

.booking-container{
    position:relative;
    z-index:1;
    width:min(1250px, 94vw);
    margin:0 auto;
}

.booking-header{
    text-align:center;
    max-width:760px;
    margin:0 auto 40px;
}

.booking-header h2{
    font-size:42px;
    margin-bottom:16px;
}

.booking-header p{
    color:rgba(255,255,255,0.82);
    line-height:1.7;
    font-size:16px;
}

.booking-grid{
    display:grid;
    grid-template-columns:0.95fr 1.25fr;
    gap:34px;
    align-items:start;
    margin-top:40px;
}
.booking-info,
.booking-form-wrap{
    border-radius:24px;
    padding:32px;
    background:linear-gradient(135deg, rgba(255,255,255,0.05), rgba(255,255,255,0.025));
    border:1px solid rgba(255,255,255,0.08);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    box-shadow:
        0 18px 50px rgba(0,0,0,0.38),
        inset 0 1px 0 rgba(255,255,255,0.04);
}

.booking-info h3,
.booking-summary h3{
    margin-top:0;
    margin-bottom:20px;
    font-size:24px;
}

.booking-steps{
    display:flex;
    flex-direction:column;
    gap:16px;
    margin-bottom:28px;
}

.booking-step{
    display:flex;
    gap:14px;
    align-items:flex-start;
    padding:16px;
    border-radius:16px;
    background:rgba(255,255,255,0.03);
    border:1px solid rgba(255,255,255,0.06);
}

.booking-step span{
    min-width:42px;
    height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:#ff1c1c;
    color:white;
    font-weight:700;
    box-shadow:0 0 18px rgba(255,28,28,0.35);
}

.booking-step p{
    margin:0;
    color:rgba(255,255,255,0.84);
    line-height:1.6;
    font-size:15px;
}

.booking-contact-box{
    margin-top:10px;
    padding:18px 20px;
    border-radius:18px;
    background:rgba(255,0,0,0.06);
    border:1px solid rgba(255,28,28,0.18);
}

.booking-contact-box h4{
    margin:0 0 12px 0;
    font-size:18px;
}

.booking-contact-box p{
    margin:0 0 10px;
    color:rgba(255,255,255,0.82);
    line-height:1.5;
}

.booking-form{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.form-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
}

.form-group{
    display:flex;
    flex-direction:column;
    gap:8px;
}

.form-group label{
    font-size:14px;
    font-weight:600;
    color:#fff;
}

.form-group input,
.form-group select,
.form-group textarea{
    width:100%;
    background:#111;
    border:1px solid #2b2b2b;
    color:white;
    padding:14px 15px;
    border-radius:12px;
    font-size:15px;
    transition:0.25s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
    outline:none;
    border-color:#ff1c1c;
    box-shadow:0 0 10px rgba(255,28,28,0.22);
}

.form-group textarea{
    min-height:120px;
    resize:vertical;
}

.booking-summary{
    margin-top:4px;
    padding:20px;
    border-radius:18px;
    background:rgba(255,255,255,0.03);
    border:1px solid rgba(255,255,255,0.08);
}

.booking-summary-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin-bottom:14px;
}

.booking-summary-head h3{
    margin:0;
    font-size:20px;
}

#booking-open-selection{
    border:none;
    background:transparent;
    color:#ff4b4b;
    cursor:pointer;
    font-weight:700;
    transition:0.25s;
}

#booking-open-selection:hover{
    color:white;
}

#booking-selected-services{
    list-style:none;
    padding:0;
    margin:0;
    display:flex;
    flex-direction:column;
    gap:10px;
}

#booking-selected-services li{
    padding:12px 14px;
    border-radius:12px;
    background:#111;
    border:1px solid #242424;
    color:rgba(255,255,255,0.9);
    font-size:14px;
}

.booking-submit{
    margin-top:6px;
    width:100%;
    padding:16px 20px;
    border:none;
    border-radius:14px;
    cursor:pointer;
    font-size:15px;
    font-weight:700;
    color:white;
    background:linear-gradient(90deg,#ff1c1c,#ff3b3b);
    box-shadow:0 12px 30px rgba(255,28,28,0.22);
    transition:0.3s;
}

.booking-submit:hover{
    transform:translateY(-2px);
    box-shadow:0 16px 35px rgba(255,28,28,0.35);
}

@media (max-width: 980px){
    .booking-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width: 768px){
    #booking{
        padding:70px 16px 100px;
    }

    .booking-header h2{
        font-size:30px;
    }

    .booking-info,
    .booking-form-wrap{
        padding:22px 18px;
        border-radius:20px;
    }

    .form-row{
        grid-template-columns:1fr;
    }

    .booking-summary-head{
        flex-direction:column;
        align-items:flex-start;
    }
}


input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1);
    cursor: pointer;
}

.price-note{
background: rgba(255,255,255,0.03);
border: 1px solid rgba(255,255,255,0.08);
padding: 12px;
border-radius: 8px;
margin: 10px 0 15px;
font-size: 13px;
color: #ccc;
}

.price-note strong{
color: #ff1c1c;
font-size: 14px;
display:block;
margin-bottom:4px;
}

.price-note .highlight{
color:#fff;
font-weight:500;
}

#auth-links a,
#auth-links button {
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
  text-decoration: none;
}

/* MOJ PROFIL (crveni) */
#auth-links a {
  background: red;
  color: white;
  border: none;
  transition: 0.2s;
}

/* ODJAVA (bijeli outline) */
#auth-links button {
  background: transparent;
  color: white;
  border: 1px solid rgba(255,255,255,0.6);
}

/* hover efekti */
#auth-links a:hover {
  background: #ff1a1a;
  box-shadow: 0 0 12px rgba(255,0,0,0.6);
  transform: translateY(-1px);
}

#auth-links button:hover {
  border-color: white;
}

#auth-links {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: 20px; /* 👈 ovo ga odmiče od linkova */
}

.total-price {
  margin-top: 15px;
  font-size: 18px;
  font-weight: bold;
  color: #00c853;
}

@media (min-width: 1101px){

.menu{
display:flex;
align-items:center;
gap:20px;
}

#auth-links{
display:flex;
align-items:center;
gap:10px;
margin-left:20px;
border:none;
padding:0;
}

#auth-links a,
#auth-links button{
width:auto;
max-width:none;
}
}

.brands-section{
  position:relative;
  background:#fff !important;
  padding:36px 0;
  overflow:visible; /* OVO PROMIJENI */
  z-index:2;
}

.brands-section::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  transform:translateX(-50%);
  width:100vw;
  height:2px;
  background:#ff1c1c;
  box-shadow:
    0 0 10px #ff1c1c,
    0 0 25px rgba(255,28,28,0.9),
    0 0 60px rgba(255,28,28,0.6);
  z-index:3;
}

.brands-section::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  transform:translateX(-50%);
  width:100vw;
  height:2px;
  background:#ff1c1c;
  box-shadow:
    0 0 10px #ff1c1c,
    0 0 25px rgba(255,28,28,0.9),
    0 0 60px rgba(255,28,28,0.6);
  z-index:3;
}

.brands-strip{
  position:relative;
  z-index:2;
  width:100%;
  background:#fff !important;
  overflow:hidden;
}

.brands-track{
  display:flex;
  align-items:center;
  gap:60px;
  animation:scrollBrands 20s linear infinite;
  width:max-content;
}

.brands-track img{
  height:55px;
  opacity:1;
  filter:none !important;
  display:block;
  background:transparent;
}

@keyframes scrollBrands {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

#location{
    position:relative;
    padding:90px 20px 110px;
    background:
        linear-gradient(180deg, rgba(255,0,0,0.06), rgba(0,0,0,0.88) 28%, #050505 100%);
    overflow:hidden;
    scroll-margin-top:80px;
}

#location::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255,0,0,0.10), transparent 30%),
        radial-gradient(circle at 80% 30%, rgba(255,255,255,0.04), transparent 25%),
        radial-gradient(circle at 50% 100%, rgba(255,0,0,0.06), transparent 35%);
    pointer-events:none;
}

.location-container{
    position:relative;
    z-index:1;
    width:min(1250px, 94vw);
    margin:0 auto;
}

.location-header{
    text-align:center;
    max-width:760px;
    margin:0 auto 40px;
}

.location-header h2{
    font-size:42px;
    margin-bottom:16px;
}

.location-header p{
    color:rgba(255,255,255,0.82);
    line-height:1.7;
    font-size:16px;
}

.location-grid{
    display:grid;
    grid-template-columns:0.95fr 1.25fr;
    gap:34px;
    align-items:stretch;
    margin-top:40px;
}

.location-info,
.location-map{
    border-radius:24px;
    padding:32px;
    background:linear-gradient(135deg, rgba(255,255,255,0.05), rgba(255,255,255,0.025));
    border:1px solid rgba(255,255,255,0.08);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    box-shadow:
        0 18px 50px rgba(0,0,0,0.38),
        inset 0 1px 0 rgba(255,255,255,0.04);
}

.location-info{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.location-card{
    padding:18px 20px;
    border-radius:18px;
    background:rgba(255,255,255,0.03);
    border:1px solid rgba(255,255,255,0.06);
}

.location-card h3{
    margin:0 0 12px 0;
    font-size:20px;
    color:#fff;
}

.location-card p{
    margin:0 0 10px 0;
    color:rgba(255,255,255,0.82);
    line-height:1.6;
    font-size:15px;
}

.location-card p:last-child{
    margin-bottom:0;
}

.location-card a{
    color:#ff4b4b;
    text-decoration:none;
    transition:0.25s;
}

.location-card a:hover{
    color:white;
}

.location-actions{
    margin-top:6px;
}

.location-map{
    min-height:460px;
    overflow:hidden;
    padding:0;
}

.location-map iframe{
    width:100%;
    height:100%;
    display:block;
    border:none;
    border-radius:24px;
}

.popup{
  position: fixed;
  inset: 0;
  display: none;
  justify-content: center;
  align-items: center;
  background: rgba(0,0,0,0.78);
  z-index: 999999;
}

.popup.show{
  display: flex;
}

.popup-content{
  background: #1a1a1a;
  width: min(760px, 95vw);
  max-width: 760px;
  max-height: 85vh;
  overflow-y: auto;
  padding: 45px;
  border-radius: 20px;
  position: relative;
  box-shadow: 0 0 35px rgba(0,0,0,0.8);

  opacity: 0;
  transform: translateY(12px) scale(.98);
  transition: opacity .22s ease, transform .22s ease;
  will-change: transform, opacity;
}

.popup.show .popup-content{
  opacity: 1;
  transform: translateY(0) scale(1);
}

.popup-nav{
  position:absolute;
  top:50%;
  left:0;
  right:0;
  display:flex;
  justify-content:space-between;
  transform:translateY(-50%);
  pointer-events:none;
  z-index:10;
}

.popup-arrow{
  pointer-events:auto;
  background:rgba(0,0,0,0.6);
  border:1px solid rgba(255,255,255,0.2);
  color:white;
  font-size:20px;
  padding:8px 12px;
  border-radius:10px;
  cursor:pointer;
  transition:0.2s;
}

.popup-arrow:hover{
  background:rgba(255,0,0,0.7);
  transform:scale(1.1);
}
/* MOBILE */

@media (max-width:599px){
/* HERO */

.hero{
min-height:72vh;
padding:100px 20px 140px;
text-align:center;
}

.hero-content{
display:flex;
flex-direction:column;
align-items:center;
}

.hero-logo{
width:80px;
margin-bottom:6px;
}

.hero h1{
font-size:30px;
margin-bottom:6px;
}

.hero h2{
font-size:18px;
margin-bottom:12px;
}

.hero-text{
font-size:14px;
line-height:1.5;
max-width:90%;
margin:auto;
}

.hero-buttons{
margin-top:16px;
}

.hero-buttons a{
padding:10px 18px;
font-size:14px;
}

.scroll-arrow{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    bottom:5vh;
    color:#ff1c1c;
    font-size:48px;
    text-decoration:none;
    animation:arrowFloat 2.4s ease-in-out infinite;
    transition:0.3s;
    text-shadow:
        0 0 10px #ff1c1c,
        0 0 20px rgba(255,0,0,0.6);
    z-index:4;
}
.scroll-arrow:hover{
color:white;
transform:translateX(-50%) scale(1.25);
}

/* BRANDS */
  .brands-section{
    padding:20px 0;
  }

  .brands-track{
    gap:30px;
    animation:scrollBrands 14s linear infinite;
  }

  .brands-track img{
    height:35px;
  }

#location{
    padding:60px 12px 100px;
}

.location-header h2{
    font-size:24px;
    margin-bottom:10px;
}

.location-header p{
    font-size:13px;
    line-height:1.5;
    margin-bottom:0;
}

.location-grid{
    grid-template-columns:1fr;
    gap:18px;
    margin-top:24px;
}

.location-info,
.location-map{
    padding:18px 16px;
    border-radius:20px;
}

.location-card{
    padding:16px;
    border-radius:14px;
}

.location-card h3{
    font-size:17px;
    margin-bottom:8px;
}

.location-card p{
    font-size:13px;
    line-height:1.5;
}

.location-map{
    min-height:320px;
    padding:0;
}

/* NAVBAR */

nav{
position:fixed;
top:0;
left:0;
width:100%;
padding:6px 12px;
overflow:visible;
}

.logo img{
height:38px;
}

nav.scrolled{
padding:5px 12px;
}

nav.scrolled .logo img{
height:32px;
}

.menu-toggle{
display:block;
position:relative;
z-index:1002;
margin-right:20px;
font-size:28px;
cursor:pointer;
}

.reservation-link{
position:absolute;
left:65px;
top:50%;
transform:translateY(-50%);
padding:6px 10px;
font-size:12px;
border-radius:8px;
background:rgba(255,0,0,0.15);
border:1px solid rgba(255,0,0,0.5);
box-shadow:none;
margin-left:0;
z-index:1001;
}

/* MENU */

.menu{
position:absolute;
top:100%;
right:12px;
left:auto;
transform:translateY(-10px);

opacity:0;
pointer-events:none;

display:flex;
flex-direction:column;
align-items:center;

width:min(220px, 88vw);

background:rgba(0,0,0,0.88);
padding:14px 18px;

border-radius:16px;
backdrop-filter:blur(10px);

transition:0.25s ease;

z-index:1001;

box-shadow:0 10px 40px rgba(0,0,0,0.6);
}

.menu.active{
opacity:1;
transform:translateY(8px);
pointer-events:auto;
}

.menu a{
margin:8px 0;
font-size:18px;
white-space:nowrap;
}

.menu-toggle{
display:block;
margin-right:20px;
font-size:28px;
}

/* SERVICES */
#services{
min-height:auto;
padding:80px 0;
}


.services{
display:grid;
grid-template-columns:repeat(2, 1fr);
gap:14px;
margin-top:36px;
padding:0 14px;
justify-items:center;
}

.service-card{
width:100%;
max-width:260px;
height:220px;
border-radius:12px;
}

.service-overlay{
padding:8px;
}

.service-overlay h3{
font-size:12px;
margin-bottom:4px;
}

.service-overlay p{
font-size:9px;
line-height:1.2;
}

.services-header{
max-width:92%;
margin:0 auto 36px auto;
}

.services-header h2{
font-size:30px;
margin-bottom:10px;
}

.services-header p{
font-size:14px;
line-height:1.5;
}

.service-card:active{
transform:scale(0.97);
}


/* POPUP */

.popup-content{
  width:92vw;
  max-width:92vw;
  max-height:85vh;
  overflow-y:auto;
  padding:20px 16px;
  border-radius:16px;
}

.popup h2{
font-size:20px;
line-height:1.25;
margin-bottom:10px;
padding-right:26px;
}

.popup-desc{
font-size:13px;
line-height:1.5;
margin-bottom:14px;
}

.popup-option{
padding:10px 12px;
margin-bottom:8px;
}

.popup-option strong{
font-size:14px;
line-height:1.4;
display:block;
}

.popup-option small{
font-size:12px;
line-height:1.4;
display:block;
margin-top:4px;
}

.popup-btn{
padding:10px 14px;
font-size:14px;
margin-top:18px;
}

.popup-nav{
left:6px;
right:6px;
}

.popup-arrow{
font-size:18px;
padding:6px 9px;
}

.close-popup{
top:10px;
right:12px;
font-size:22px;
}

/* WHATSAPP */

.whatsapp-float{
width:40px;
height:40px;
font-size:18px;
bottom:16px;
right:16px;
}



section{
overflow-x:hidden;
}

#packages{
padding-top:50px;
padding-bottom:100px;
}

#packages h2{
font-size:26px;
margin-bottom:14px;
}

#packages p{
margin-bottom:36px;
padding:0 14px;
font-size:14px;
}

.packages{
display:flex;
flex-direction:column;
align-items:center;
gap:18px;
margin:30px auto 0;
max-width:100%;
}

.package-card{
width:min(88vw, 320px);
min-height:auto;
padding:24px 18px;
transform:none !important;
border-radius:14px;
}

.package-card.diamond{
width:min(88vw, 320px);
transform:none !important;
}

.package-card h3{
font-size:26px;
margin-bottom:10px;
}

.package-icon{
font-size:28px;
margin-bottom:6px;
}

.package-price-box{
margin-top:20px;
margin-bottom:18px;
}

.package-price{
font-size:26px;
}

.price-label{
font-size:11px;
letter-spacing:1px;
}

.package-more{
font-size:12px;
max-width:100%;
margin-bottom:18px;
line-height:1.35;
}

.package-btn{
padding:10px 14px;
font-size:14px;
border-radius:8px;
}

.best-offer{
top:-10px;
font-size:10px;
padding:4px 8px;
}

#gallery{
padding:60px 12px 110px;
}

#gallery h2{
font-size:24px;
margin-bottom:28px;
}

.carousel{
height:360px;
margin-bottom:60px;
}

.carousel img{
width:180px;
border-radius:12px;
}

.carousel img.active{
transform:translate(-50%, -50%) scale(1.02);
}

.carousel img.active:hover{
transform:translate(-50%, -50%) scale(1.02);
}

.carousel img.left{
transform:translate(-115%, -50%) scale(0.72);
opacity:0.5;
}

.carousel img.right{
transform:translate(15%, -50%) scale(0.72);
opacity:0.5;
}

.carousel img.left2,
.carousel img.right2{
opacity:0;
pointer-events:none;
}

.nav{
font-size:22px;
padding:8px 12px;
}

.prev{
left:8px;
}

.next{
right:8px;
}

.gallery-divider{
width:85%;
margin:50px auto;
}

.compare{
position:relative;
display:flex;
justify-content:center;
align-items:center;
}

.compare-wrapper{
width:100%;
max-width:94vw;
height:340px;
margin:30px auto;
border-radius:16px;
}

.compare-bg{
inset:20px;
border-radius:12px;
filter:blur(16px) brightness(0.45);
}

.compare-base,
.compare-top{
object-fit:contain;
}

.compare-handle{
width:34px;
height:34px;
}

.compare-nav{
font-size:18px;
padding:8px 10px;
}

.compare-nav.prev{
left:6px;
}

.compare-nav.next{
right:6px;
}

.social-grid{
display:grid;
grid-template-columns:1fr;
gap:16px;
margin:40px auto 0;
padding:0 12px;
max-width:100%;
justify-items:center;
}

.social-item{
width:100%;
max-width:260px;
display:flex;
justify-content:center;
}

.social-grid .social-item:last-child{
grid-column:auto;
display:flex;
justify-content:center;
max-width:260px;
width:100%;
}

.social-card{
width:100%;
padding:14px 10px;
border-radius:18px;
min-height:auto;
height:auto;
display:flex;
flex-direction:column;
justify-content:flex-start;
}

.social-top{
margin-bottom:12px;
}

.social-top span{
font-size:22px;
}

.social-top img{
width:20px;
height:20px;
}

.social-media,
.video-wrapper{
width:100%;
max-width:100%;
height:180px;
border-radius:16px;
overflow:hidden;
}

.social-desc{
margin-top:12px;
font-size:12px;
line-height:1.35;
padding:0 4px;
}

.play-icon{
width:56px;
height:56px;
}

.gallery-end{
margin-top:50px;
padding:40px 12px;
}

.gallery-end h3{
font-size:24px;
margin-bottom:10px;
}

.gallery-end p{
font-size:14px;
line-height:1.5;
margin-bottom:0;
}


#about{
padding:60px 0;
display:flex;
justify-content:center;
}

#about .about-container{
width:90%;
max-width:360px;
margin:0 auto;
}

#about h2{
font-size:24px;
margin-bottom:10px;
}

#about p{
font-size:13px;
line-height:1.4;
margin-bottom:16px;
}
.about-content{
gap:20px;
}

.about-card{
padding:14px;
margin-bottom:12px;
}
.about-card h3{
font-size:18px;
}

.about-card p{
font-size:13px;
}

.about-text{
gap:12px;
}

#booking{
padding:60px 12px 100px;
}

#booking h2{
font-size:24px;
margin-bottom:10px;
}

#booking p{
font-size:13px;
margin-bottom:20px;
line-height:1.4;
}

.booking-form{
gap:10px;
}

.booking-form input,
.booking-form select,
.booking-form textarea{
height:44px;
font-size:13px;
padding:0 10px;
border-radius:10px;
}

.booking-form textarea{
height:80px;
padding:10px;
}

.booking-form label{
font-size:12px;
margin-bottom:4px;
}

.booking-form button{
height:44px;
font-size:14px;
border-radius:10px;
margin-top:8px;
}

#saved-cars-wrap{
margin-bottom:10px;
}

#savedCarSelect{
height:42px;
font-size:13px;
}

.form-group{
margin-bottom:8px;
}

}

@media (min-width:600px) and (max-width:1100px){

  /* NAVBAR */
  nav{
    padding:8px 16px;
    gap:12px;
    overflow:visible;
  }

  .logo img{
    height:44px;
  }

  nav.scrolled{
    padding:6px 16px;
  }

  nav.scrolled .logo img{
    height:38px;
  }

  .menu-toggle{
    display:block;
    position:relative;
    z-index:1002;
    margin-left:auto;
    margin-right:18px;
    font-size:30px;
  }

  .reservation-link{
    position:absolute;
    left:72px;
    top:50%;
    transform:translateY(-50%);
    padding:6px 10px;
    font-size:12px;
    border-radius:8px;
    background:rgba(255,0,0,0.15);
    border:1px solid rgba(255,0,0,0.5);
    box-shadow:none;
    margin-left:0;
    z-index:1001;
  }

  .menu{
    position:absolute;
    top:100%;
    right:12px;
    left:auto;
    transform:translateY(-10px);
    opacity:0;
    pointer-events:none;
    display:flex;
    flex-direction:column;
    align-items:center;
    width:min(240px, 88vw);
    background:rgba(0,0,0,0.9);
    padding:14px 18px;
    border-radius:16px;
    backdrop-filter:blur(10px);
    transition:0.25s ease;
    z-index:1001;
    box-shadow:0 10px 40px rgba(0,0,0,0.6);
  }

  .menu.active{
    opacity:1;
    transform:translateY(8px);
    pointer-events:auto;
  }

  .menu a{
    margin:8px 0;
    font-size:18px;
    white-space:nowrap;
  }

  #auth-links{
    margin-left:0;
    width:100%;
    justify-content:center;
    flex-wrap:wrap;
  }

  /* HERO */
  .hero{
    min-height:88vh;
    padding:110px 24px 100px;
  }

  .hero-content{
    max-width:760px;
    width:100%;
    padding:20px;
  }

  .hero-logo{
    width:160px;
    margin:0 auto 10px auto;
  }

  .hero h1{
    font-size:52px;
    line-height:1.05;
    margin:0 0 8px 0;
  }

  .hero h2{
    font-size:22px;
    margin-top:14px;
    margin-bottom:10px;
  }

  .hero-text{
    font-size:15px;
    line-height:1.55;
    max-width:560px;
    margin:10px auto 0 auto;
  }

  .btn{
    padding:12px 22px;
    font-size:14px;
    margin-top:22px;
  }

  /* SERVICES */
  #services{
    min-height:auto;
    padding:90px 0;
  }

  .services-header{
    max-width:760px;
    margin:0 auto 40px auto;
    padding:0 20px;
  }

  .services-header h2{
    font-size:36px;
  }

  .services-header p{
    font-size:15px;
  }

  .services{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:18px;
    max-width:760px;
    margin:50px auto 0;
    padding:0 18px;
  }

  .service-card{
    width:100%;
    max-width:none;
    height:250px;
  }

  .service-overlay{
    padding:14px;
  }

  .service-overlay h3{
    font-size:16px;
    margin-bottom:6px;
  }

  .service-overlay p{
    font-size:12px;
    line-height:1.35;
  }

  /* PACKAGES */
  #packages{
    padding-top:60px;
    padding-bottom:100px;
  }

  #packages h2{
    font-size:34px;
    margin-bottom:16px;
  }

  #packages p{
    margin-bottom:50px;
    padding:0 20px;
    font-size:15px;
  }

  .packages{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:20px;
    margin:40px auto 0;
    padding:0 18px;
    max-width:100%;
  }

  .package-card,
  .package-card.diamond,
  .package-card.gold,
  .package-card.bronze{
    width:min(88vw, 400px);
    min-height:auto;
    padding:28px 22px;
    transform:none !important;
  }

  .package-card h3{
    font-size:30px;
  }

  .package-price{
    font-size:28px;
  }

  .package-more{
    max-width:100%;
  }

  /* GALLERY */
  #gallery{
    padding:70px 16px 110px;
  }

  #gallery h2{
    font-size:28px;
    margin-bottom:34px;
  }

  .carousel{
    height:420px;
    margin-bottom:70px;
  }

  .carousel img{
    width:210px;
  }

  .carousel img.active{
    transform:translate(-50%, -50%) scale(1.05);
  }

  .carousel img.left{
    transform:translate(-120%, -50%) scale(0.68);
    opacity:0.5;
  }

  .carousel img.right{
    transform:translate(20%, -50%) scale(0.68);
    opacity:0.5;
  }

  .carousel img.left2,
  .carousel img.right2{
    opacity:0;
    pointer-events:none;
  }

  .prev{
    left:10px;
  }

  .next{
    right:10px;
  }

  .gallery-divider{
    width:85%;
    margin:60px auto;
  }

  .compare-wrapper{
    width:94%;
    max-width:860px;
    height:420px;
    min-height:unset;
    margin:40px auto;
    border-radius:16px;
  }

  .compare-bg{
    inset:24px;
    border-radius:12px;
  }

  .compare-nav{
    font-size:18px;
    padding:8px 10px;
  }

  .compare-nav.prev{
    left:8px;
  }

  .compare-nav.next{
    right:8px;
  }

  /* SOCIAL */
  .social-grid{
    grid-template-columns:1fr;
    max-width:430px;
    gap:24px;
    padding:0 16px;
  }

  .social-item{
    width:100%;
    max-width:none;
  }

  .social-card{
    min-height:unset;
    height:auto;
    padding:18px 14px;
    border-radius:22px;
  }

  .social-top{
    margin-bottom:16px;
  }

  .social-top span{
    font-size:28px;
  }

  .social-top img{
    width:24px;
    height:24px;
  }

  .social-media,
  .video-wrapper{
    max-width:300px;
    margin:0 auto;
  }

  .social-desc{
    font-size:14px;
    line-height:1.45;
    margin-top:16px;
  }

  /* ABOUT */
  #about{
    padding:60px 16px 80px;
  }

  .about-container{
    width:min(92vw, 720px);
    padding:26px 20px;
    border-radius:22px;
  }

  .about-container h2{
    font-size:28px;
  }

  .about-lead{
    font-size:14px;
  }

  .about-content p{
    font-size:13px;
    line-height:1.65;
  }

  .about-stats{
    grid-template-columns:1fr;
    gap:10px;
  }

  /* BOOKING */
  #booking{
    padding:70px 16px 100px;
  }

  .booking-header h2{
    font-size:30px;
  }

  .booking-header p{
    font-size:14px;
    line-height:1.5;
  }

  .booking-grid{
    grid-template-columns:1fr;
    gap:22px;
  }

  .booking-info,
  .booking-form-wrap{
    padding:22px 18px;
    border-radius:20px;
  }

  .form-row{
    grid-template-columns:1fr;
  }

  .booking-summary-head{
    flex-direction:column;
    align-items:flex-start;
  }

  /* HOURS */
  #hours-section{
    padding:60px 16px 80px;
  }

  .hours-row{
    padding:16px 18px;
    font-size:15px;
  }

  /* LOCATION */
  #location{
    padding:70px 16px 100px;
  }

  .location-header h2{
    font-size:30px;
    margin-bottom:12px;
  }

  .location-header p{
    font-size:14px;
    line-height:1.5;
  }

  .location-grid{
    grid-template-columns:1fr;
    gap:22px;
    margin-top:30px;
  }

  .location-info,
  .location-map{
    padding:22px 18px;
    border-radius:20px;
  }

  .location-card{
    padding:16px;
    border-radius:14px;
  }

  .location-card h3{
    font-size:18px;
  }

  .location-card p{
    font-size:14px;
    line-height:1.5;
  }

  .location-map{
    min-height:360px;
    padding:0;
  }
}

/* =========================
   FOOTER
========================= */

.site-footer{
    position:relative;
    background:
        linear-gradient(180deg, rgba(255,0,0,0.06), rgba(0,0,0,0.94) 25%, #050505 100%);
    padding:70px 20px 30px;
    overflow:hidden;
}

.site-footer::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255,0,0,0.10), transparent 28%),
        radial-gradient(circle at 80% 30%, rgba(255,255,255,0.04), transparent 24%);
    pointer-events:none;
}

.footer-container{
    position:relative;
    z-index:1;
    width:min(1250px, 94vw);
    margin:0 auto;
}

.footer-top{
    display:grid;
    grid-template-columns:1.2fr 1fr 1fr 1fr;
    gap:20px;
    align-items:start;
    padding:24px;
    border-radius:26px;
    background:linear-gradient(135deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
    border:1px solid rgba(255,255,255,0.08);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    box-shadow:
        0 18px 50px rgba(0,0,0,0.38),
        inset 0 1px 0 rgba(255,255,255,0.04);
        justify-items:center;
text-align:center;
}
.footer-column{
width:100%;
max-width:220px;
}

.footer-brand h2{
    margin:0 0 12px;
    font-size:30px;
}

.footer-brand p{
    margin:0;
    color:rgba(255,255,255,0.78);
    line-height:1.7;
    font-size:15px;
}

.footer-logo{
    width:90px;
    filter:drop-shadow(0 0 10px rgba(255,0,0,0.4));
    transition:0.3s;
}

.footer-logo:hover{
    transform:scale(1.05);
    filter:drop-shadow(0 0 16px rgba(255,0,0,0.7));
}

.footer-column h3{
    margin:0 0 14px;
    font-size:18px;
    color:#fff;
}

.footer-column p{
    margin:0 0 10px;
    color:rgba(255,255,255,0.78);
    line-height:1.6;
    font-size:14px;
}

.footer-column a{
    color:#ff4b4b;
    text-decoration:none;
    transition:0.25s;
}

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

.socials{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin-bottom:18px;
}

.socials a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:100%;
    padding:10px 14px;
    border-radius:10px;
    background:rgba(255,255,255,0.04);
    border:1px solid rgba(255,255,255,0.08);
    color:white;
    text-decoration:none;
    font-weight:500;
    transition:0.25s;
}

.socials a:hover{
    transform:translateY(-2px);
    border-color:#ff1c1c;
    background:rgba(255,0,0,0.12);
    box-shadow:0 0 14px rgba(255,0,0,0.25);
}
.footer-map-btn{
    display:inline-block;
    padding:12px 18px;
    border-radius:10px;
    background:linear-gradient(90deg,#ff1c1c,#ff3b3b);
    color:white !important;
    text-decoration:none;
    font-weight:700;
    box-shadow:0 10px 30px rgba(255,28,28,0.4);
    transition:0.25s;
}

.footer-map-btn:hover{
    transform:translateY(-3px);
    box-shadow:0 18px 40px rgba(255,28,28,0.5);
}
.footer-bottom{
    text-align:center;
    margin-top:24px;
    padding-top:18px;
}

.footer-bottom p{
    margin:0;
    color:rgba(255,255,255,0.62);
    font-size:13px;
    letter-spacing:0.2px;
}

@media (max-width:1100px){
    .footer-top{
        grid-template-columns:1fr 1fr;
    }
}

@media (max-width:599px){
    .site-footer{
        padding:55px 12px 25px;
    }

    .footer-top{
        grid-template-columns:1fr;
        gap:22px;
        padding:22px 16px;
        border-radius:20px;
    }

    .footer-brand h2{
        font-size:24px;
    }

    .footer-brand p,
    .footer-column p{
        font-size:13px;
        line-height:1.55;
    }

    .footer-column h3{
        font-size:17px;
    }

    .footer-logo{
        width:72px;
        margin-bottom:10px;
    }

    .socials a{
        width:100%;
        justify-content:center;
        font-size:14px;
    }

    .footer-map-btn{
        width:100%;
        text-align:center;
        font-size:14px;
    }
    .section-bottom-glow{
display:none !important;
}

}

/* Zumiranje slike isključivo unutar TikTok kartice */
.social-card.tiktok .video-wrapper img {
    transform: scale(1.1); /* 1.1 znači 110%. Možeš staviti i 1.15 ili 1.2 ako želiš veću */
}


