/* ==========================================================
   AutoSolution • style.css  v3.16
   ========================================================== */

/* ----------------------------------------------------------
   0. VARIJABLE & RESET
   ---------------------------------------------------------- */
:root{
  --clr-primary:       #d81324;
  --clr-primary-dark:  #b2101e;
  --clr-secondary:     #0b2154;

  --clr-bg-light:      #f7f7f7;
  --clr-bg-dark:       #111;

  --container:         1200px;
  --radius:            6px;
  --shadow:            0 8px 20px rgba(0,0,0,.08);

  --transition:        .35s cubic-bezier(.4,0,.2,1);
  --fade-duration:     .7s;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Ubuntu",sans-serif;
  line-height:1.6;
  color:var(--clr-bg-dark);
  background:#fff;
}
img{max-width:100%;display:block;}


/* ----------------------------------------------------------
   1. POMOĆNE KLASE
   ---------------------------------------------------------- */
.container{
  width:90%;
  max-width:var(--container);
  margin-inline:auto;
}

.btn{
  display:inline-block;
  padding:.85rem 1.8rem;
  border:none;
  border-radius:var(--radius);
  background:var(--clr-primary);
  color:#fff;
  font-weight:600;
  text-decoration:none;
  transition:
    background var(--transition),
    transform  var(--transition);
}
.btn:hover{
  background:var(--clr-primary-dark);
  transform:translateY(-2px);
}

.section-title{margin-bottom:2.5rem;text-align:center;}
.section-title h2{
  font-size:clamp(1.8rem,3vw + .5rem,2.5rem);
  position:relative;
}
.section-title h2::after{
  content:"";
  display:block;
  width:70px;
  height:3px;
  background:var(--clr-primary);
  margin:1rem auto 0;
}

.section-heading{
  font-size:clamp(1.9rem,3vw + .6rem,2.7rem);
  text-align:center;
  margin:0 0 2rem;
}


/* ----------------------------------------------------------
   2. HEADER & NAVIGACIJA
   ---------------------------------------------------------- */
header{
  background:var(--clr-primary);
  color:#fff;
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 2px 8px rgba(0,0,0,.1);
}

/* -- 2.0 LOGO --------------------------------------------- */
.logo-link{
  display:inline-block;
  flex-shrink:0;
  margin-left:-45px
}
.logo-img{
  height:42px;
  width:auto;
}
@media(max-width:480px){
  .logo-img{height:36px;}
}

/* -- 2.1 raspored unutar kontejnera ----------------------- */
header .container{
  position:relative;
  display:flex;
  align-items:center;
  gap:1rem;
  padding:.75rem 0;
}
header h1{
  margin:0;
  font-size:1.7rem;
  flex-shrink:0;
}

/* -- 2.2 navigacioni linkovi ------------------------------ */
nav ul{
  display:flex;
  gap:1.6rem;
  list-style:none;
  margin:0;
  padding:0;
}
nav a{
  color:#fff;
  font-weight:500;
  text-decoration:none;
  position:relative;
  transition:color var(--transition);
}
nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-4px;
  width:0;
  height:2px;
  background:#fff;
  transition:width var(--transition);
}
nav a:hover::after{width:100%;}

/* centrirana navigacija na desktopu */
@media(min-width:781px){
  nav{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);}
  .burger{position:absolute;right:0;top:50%;transform:translateY(-50%);}
}

/* -- 2.3 kontakt-blok desno ------------------------------- */
.header-contact{
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  padding-right:12px;
  font-size:.9rem;
  line-height:1.35;
  text-align:right;
  color:#fff;
}
.header-contact i{margin-right:6px;color:#f7f7f7;}
.header-contact a{color:#fff;text-decoration:none;font-weight:600;}
@media(max-width:780px){.header-contact{display:none;}}

/* -- 2.4 burger dugme ------------------------------------- */
.burger{
  cursor:pointer;
  width:30px;height:24px;
  position:relative;
  display:none;
}
.burger span,
.burger::before,
.burger::after{
  content:"";
  position:absolute;
  left:0;
  width:100%;
  height:3px;
  background:#fff;
  transition:transform .4s ease,top .4s ease;
}
.burger span{top:10px;}
.burger::before{top:0;}
.burger::after {top:20px;}
.burger.active span{transform:scale(0);}
.burger.active::before{top:10px;transform:rotate(45deg);}
.burger.active::after {top:10px;transform:rotate(-45deg);}
@media(max-width:780px){
  .burger{display:block;}
}

/* ----------------------------------------------------------
   3. HERO
   ---------------------------------------------------------- */
.hero{
  position:relative;
  min-height:70vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.55);
  z-index:-1;
}
.hero img{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
  filter:brightness(.8);
  z-index:-2;
}
.hero-content{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
}
.hero h2{
  margin:0 auto;
  font-size:clamp(2rem,4vw + 1.5rem,3.5rem);
  max-width:750px;
}
.hero .btn{margin-top:1.2rem;}


/* ----------------------------------------------------------
   4. ISTAKNUTE USLUGE
   ---------------------------------------------------------- */
.services{background:var(--clr-bg-light);}

.service-list{
  display:grid;
  gap:2rem;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}

.service-card{
  position:relative;
  height:100%;
  padding:2rem 1.5rem;
  color:#fff;
  text-align:center;
  border-radius:var(--radius);
  background-size:cover;
  background-position:center;
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform var(--transition);
}
.service-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
  z-index:-1;
  transition:opacity var(--transition);
}
.service-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--clr-primary);
  transform:translateY(100%);
  z-index:-2;
  transition:transform var(--transition);
}
.service-card:hover{transform:translateY(-6px);}
.service-card:hover::before{transform:translateY(0);}
.service-card:hover::after{opacity:0;}


/* ----------------------------------------------------------
   5. STATISTIKA
   ---------------------------------------------------------- */
.stats-section{
  position:relative;
  padding:4rem 0;
  color:#fff;
  text-align:center;
}
.stats-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.35);}
.stats-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);}
.stats-wrap{
  position:relative;
  z-index:1;
  display:grid;
  gap:2rem;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
}
.stat-box i{font-size:2rem;margin-bottom:.5rem;}
.stat-box .count{display:block;font-size:2.25rem;font-weight:700;}
.stat-box p{margin:.25rem 0 0;font-size:1.05rem;font-weight:500;}
@media(max-width:600px){
  .stats-section{padding:3rem 0 2.5rem;}
  .stat-box .count{font-size:1.9rem;}
}


/* ----------------------------------------------------------
   6. O NAMA
   ---------------------------------------------------------- */
.about-section{padding:4rem 0;}

.about-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:3rem;
  align-items:center;
}

.about-img-box{
  flex:1 1 500px;
  min-width:280px;
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
}
.about-img-box img{width:100%;height:auto;object-fit:cover;}

.exp-badge{
  position:absolute;
  top:-30px;right:-30px;
  background:rgba(0,0,0,.05);
  padding:2.5rem 3rem;
}
.exp-years{
  display:block;
  font-size:3rem;
  font-weight:700;
  color:#fff;
  line-height:.9;
}
.exp-small{
  display:block;
  font-size:1.15rem;
  font-weight:600;
  color:#fff;
  text-transform:uppercase;
}

.about-content{flex:1 1 450px;min-width:280px;}
.about-sub{color:var(--clr-primary);letter-spacing:2px;font-weight:600;margin-bottom:.5rem;}
.about-title{
  font-size:clamp(1.8rem,3vw + .5rem,2.8rem);
  line-height:1.2;
  margin:0 0 1.5rem;
  color:var(--clr-secondary);
}
.about-title .accent{color:var(--clr-primary);}
.about-lead{margin-bottom:1.5rem;color:#555;}

.about-list{
  list-style:none;
  margin:0 0 2rem;
  padding:0;
  display:grid;
  gap:1.5rem;
}
.about-list li{display:flex;gap:1.25rem;align-items:flex-start;}
.about-list .num{
  background:var(--clr-bg-light);
  color:var(--clr-secondary);
  font-weight:700;
  padding:.8rem 1.1rem;
  border-radius:var(--radius);
}
.about-list h4{margin:.15rem 0 .3rem;font-size:1.05rem;color:var(--clr-secondary);}
.about-list p{margin:0;font-size:.95rem;color:#555;}

@media(max-width:900px){
  .about-img-box,.about-content{flex:1 1 100%;}
  .exp-badge{top:20px;right:20px;transform:scale(.8);}
}


/* ----------------------------------------------------------
   7. SPEKTAR USLUGA (opcionalno)
   ---------------------------------------------------------- */
/* … (ostavljeno neizmenjeno) … */


/* ----------------------------------------------------------
   8. BRENDOVI
   ---------------------------------------------------------- */
.brands-section{padding:4rem 0;background:#fff;}

.brands-grid{
  display:grid;
  gap:1.5rem;
  justify-content:center;
  grid-template-columns:repeat(auto-fill,minmax(120px,1fr));
}
.brands-grid img{
  width:100%;
  max-width:120px;
  aspect-ratio:1/1;
  object-fit:contain;
  
  transition:filter var(--transition),transform var(--transition);
}
.brands-grid img:hover{
 
  transform:scale(1.05);
}


/* ----------------------------------------------------------
   9. ČESTA PITANJA (FAQ)
   ---------------------------------------------------------- */
.faq-section{background:#fff;padding:4rem 0;}
.faq-section .container{max-width:800px;margin-inline:auto;}

.faq-item{border-top:1px solid #e4e4e4;}
.faq-item:last-child{border-bottom:1px solid #e4e4e4;}

.faq-question{
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:.65rem;
  padding:1.15rem 0;
  background:none;
  border:none;
  font-size:1.05rem;
  font-weight:700;
  color:var(--clr-secondary);
  cursor:pointer;
  transition:color var(--transition);
}
.faq-question i{transition:transform var(--transition);}
.faq-question.active{color:var(--clr-primary);}
.faq-question.active i{transform:rotate(-90deg);}

.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .4s ease;
  display:flex;
  justify-content:center;
}
.faq-answer ul{
  display:inline-block;
  list-style-position:outside;
  padding-left:1.25rem;
  margin:0 0 1rem;
  color:#555;
  font-size:.95rem;
  text-align:left;
}
.faq-answer li{margin-bottom:.35rem;line-height:1.4;}

@media(max-width:780px){.faq-question{font-size:1rem;}}


/* ----------------------------------------------------------
   10. KONTAKT
   ---------------------------------------------------------- */
.contact{
  background:var(--clr-primary);
  color:#fff;
  text-align:center;
  padding:3rem 5%;
}

.contact-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:2rem;
  align-items:flex-start;
  justify-content:center;
}

.contact-info{flex:1 1 340px;min-width:260px;}

.contact-map{flex:1 1 360px;min-width:260px;}
.contact-map iframe{
  width:100%;
  height:260px;
  border:0;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
@media(max-width:600px){.contact-map iframe{height:220px;}}

.contact a.btn{
  background:#fff;
  color:var(--clr-primary);
  margin-top:1.5rem;
}
.contact a.btn:hover{background:var(--clr-bg-light);}

/* ----------------------------------------------------------
   10.1  FOOTER
   ---------------------------------------------------------- */
footer{margin:0;padding:0;background:#000;color:#bbb;}

.footer-top{
  position:relative;
  background:#000;
  color:#fff;
  padding:3.5rem 0 2.5rem;
}
.footer-top::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.6);
  z-index:-1;
}

.footer-grid{
  display:flex;
  flex-wrap:wrap;
  gap:2.5rem;
  justify-content:space-between;
}

.footer-col{flex:1 1 250px;min-width:210px;}
.footer-col h3{
  margin:0 0 1.2rem;
  font-size:1.5rem;
  color:#fff;
}

.footer-col p,
.footer-col a{
  color:#ddd;
  font-size:1rem;
  line-height:1.6;
  text-decoration:none;
}
.footer-col i{
  margin-right:8px;
  color:var(--clr-primary);
}

.footer-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:.6rem;
}
.footer-list li{
  display:flex;
  align-items:center;
  gap:.6rem;
  font-size:1rem;
}
.footer-list li i{color:var(--clr-primary);}

.footer-bottom{
  background:#000;
  color:#bbb;
  text-align:center;
  padding:1.25rem .75rem;
  font-size:.875rem;
  border-top:1px solid rgba(255,255,255,.08);
}

@media(max-width:600px){
  .footer-col h3{font-size:1.35rem;}
}

/* ----------------------------------------------------------
   11. ANIMACIJE & RESPONSIVE MENU
   ---------------------------------------------------------- */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(30px);}
  to  {opacity:1;transform:translateY(0);}
}
[data-animate]{opacity:0;}
[data-animate].in-view{animation:fadeInUp var(--fade-duration) forwards;}

@media(max-width:780px){
  nav{position:static;transform:none;}
  nav ul{
    flex-direction:column;
    width:100%;
    max-height:0;
    overflow:hidden;
    transition:max-height .4s ease;
  }
  nav ul.expanded{max-height:300px;}
  header .container{flex-wrap:wrap;row-gap:.5rem;}

  /* NOVO – burger dugme skroz levo */
  .burger{
    order:-1;
    margin-right:auto;
  }
}


/* ----------------------------------------------------------
   12. GOOGLE RECENZIJE (Slider)
   ---------------------------------------------------------- */
.reviews-section{background:#f4f6fa;padding:4rem 0;position:relative;}

.reviews-intro{
  max-width:780px;
  margin:0 auto 2.5rem;
  font-size:1.05rem;
  line-height:1.55;
  text-align:center;
  color:#444;
}
.reviews-intro a{color:var(--clr-primary);font-weight:600;text-decoration:none;}
.reviews-intro a:hover{text-decoration:underline;}

.reviews-track{
  display:flex;
  gap:24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:0 12px 8px;
  scroll-padding-left:12px;
  scroll-padding-right:12px;
}
.reviews-track::-webkit-scrollbar{display:none;}

.review-card{
  flex:0 0 300px;
  max-width:300px;
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:1rem;
  background:#f5f5f5;
  border-radius:10px;
  box-shadow:var(--shadow);
  scroll-snap-align:start;
}

.header-content{
  display:flex;
  align-items:center;
  gap:25px;
  margin-bottom:10px;
}
.img-area{
  width:80px;height:80px;
  overflow:hidden;
  border-radius:50%;
}
.img-area img{width:100%;height:100%;object-fit:cover;}
.info h4{margin:0;font-size:22px;font-weight:600;color:var(--clr-secondary);}
.info p{margin:5px 0 0;font-size:14px;color:#666;}

.single-review p{margin:0;font-size:16px;line-height:1.7;color:#333;}

.review-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:14px;
  color:#666;
}
.rating{display:flex;gap:2px;font-size:18px;}
.rating span{color:#000;}
.rating span.active{color:#fbc02d;}

.reviews-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:40px;height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:none;
  border-radius:50%;
  background:#fff;
  color:var(--clr-secondary);
  box-shadow:0 0 8px rgba(0,0,0,.1);
  cursor:pointer;
  transition:background .25s;
}
.reviews-arrow:hover{background:#e6e6e6;}
.reviews-arrow.prev{left:12px;}
.reviews-arrow.next{right:12px;}

@media(max-width:700px){
  .review-card{flex:0 0 260px;max-width:260px;}
  .reviews-arrow{display:none;}
}
