/* Reset & Base */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

body {
  color: #002d39;
  font-family: "Merriweather Sans", sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.25;
  overflow-x: hidden;
}

img {
  border-style: none;
  display: block;
  height: auto;
  max-width: 100%;
}

/* Layout */
.page-wrapper {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-x: hidden;
}

.page-wrapper .page-main {
  flex: 1 0 auto;
}

.page-wrapper .page-main section {
  padding: 100px 0;
}

@media (max-width: 1024px) {
  .page-wrapper .page-main section {
    padding: 50px 0;
  }
}

/*
 Smanjivanje razmaka samo za stranicu s cjenikom (ISPRAVNA VERZIJA)
*/
.stranica-cjenik .page-wrapper .page-main section {
  padding: 60px 0 !important;
}

@media (max-width: 1024px) {
  .stranica-cjenik .page-wrapper .page-main section {
    padding: 40px 0 !important;
  }
}

.container {
  margin: 0 auto;
  max-width: 1200px;
  padding: 0 16px;
  width: 100%;
}

/* Typography */
.is-font-size-48 {
  font-size: 48px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .is-font-size-48 {
    font-size: 42px;
  }
}

@media (max-width: 800px) {
  .is-font-size-48 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .is-font-size-48 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .is-font-size-48 {
    font-size: 24px;
  }
}

.is-font-size-56 {
  font-size: 56px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .is-font-size-56 {
    font-size: 48px;
  }
}

@media (max-width: 800px) {
  .is-font-size-56 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .is-font-size-56 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .is-font-size-56 {
    font-size: 24px;
  }
}

.is-font-size-28 {
  font-size: 28px;
  line-height: 1.3;
}

@media (max-width: 800px) {
  .is-font-size-28 {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .is-font-size-28 {
    font-size: 18px;
  }
}

.is-font-size-20 {
  font-size: 20px;
  line-height: 1.3;
}

@media (max-width: 800px) {
  .is-font-size-20 {
    font-size: 18px;
  }
}

.is-font-size-42 {
  font-size: 42px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .is-font-size-42 {
    font-size: 36px;
  }
}

@media (max-width: 800px) {
  .is-font-size-42 {
    font-size: 30px;
  }
}

@media (max-width: 600px) {
  .is-font-size-42 {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .is-font-size-42 {
    font-size: 18px;
  }
}

/* Buttons */
.button {
  background: none;
  color: #4c0f7b;
  cursor: pointer;
  display: inline-block;
  line-height: 1.5;
  outline: none;
  padding: 10px 35px;
  text-decoration: none;
  font-weight: 700;
  transition: all 0.2s ease;
  text-align: center;
  font-size: 16px;
}

.button:hover {
  text-decoration: none;
}

.button.primary-button {
  text-transform: uppercase;
  font-weight: 800;
  background-color: #ff992e;
  color: #4c0f7b;
  border: solid 1px #ff992e;
}

.button.primary-button:hover {
  background-color: rgba(255, 153, 46, 0.9);
  border: solid 1px rgba(255, 153, 46, 0.9);
}

.button.outline {
  border: solid 2px #fff;
  color: #fff;
  text-transform: uppercase;
}

.button.outline:hover {
  color: #fff;
  opacity: 0.7;
}

.button.outline-dark {
  border: solid 1px #002d39;
  color: #002d39;
}

.button.outline-dark:hover {
  color: #002d39;
  opacity: 0.7;
}

.button.radius-100 {
  border-radius: 100px;
}

@media (max-width: 480px) {
  .button {
    padding: 10px 25px;
    font-size: 16px;
  }
}

/* Hero Section */
.hero {
  background-color: #24073a;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQ0MCIgaGVpZ2h0PSI4MDAiIHZpZXdCb3g9IjAgMCAxNDQwIDgwMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTAgMEgxNDQwVjgwMEgwVjBaIiBmaWxsPSJ1cmwoI3BhaW50MF9saW5lYXJfMjEzXzE4NSkiLz4KPGC0ZWZzPgo8bGluZWFyR3JhZGllbnQgaWQ9InBhaW50MF9saW5lYXJfMjEzXzE4NSIgeDI9IjE0NDAiIHkyPSI4MDAiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzI0MDczQSIvPgo8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiM0QzBGN0IiLz4KPC9saW5lYXJHcmFkaWVudD4KPC9kZWZzPgo8L3N2Zz4=);
  background-size: cover;
  background-repeat: no-repeat;
  color: #fff;
  padding: 80px 0 !important;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

@media (max-width: 1024px) {
  .hero {
    padding: 50px 0 !important;
  }
}

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

.hero .container .hero-content h1 {
  margin-bottom: 38px;
  color: #fff;
  font-size: 56px;
  line-height: 1.3;
  font-weight: 800;
}

@media (max-width: 1024px) {
  .hero .container .hero-content h1 {
    font-size: 48px;
  }
}

@media (max-width: 800px) {
  .hero .container .hero-content h1 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .hero .container .hero-content h1 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .hero .container .hero-content h1 {
    font-size: 24px;
  }
}

.hero .container .hero-content p {
  font-size: 20px;
  margin-bottom: 20px;
}

.hero .container .hero-content .hero-cta .button {
  text-transform: uppercase;
  font-weight: 800;
}

/* Pricing Block */
.pricing-block .container {
  display: flex;
  align-items: center;
  flex-direction: column;
}

.pricing-block .container .title-block {
  text-align: center;
  margin-bottom: 50px;
}

@media (max-width: 600px) {
  .pricing-block .container .title-block {
    margin-bottom: 40px;
  }
}

.pricing-block .container .title-block h2 {
  font-weight: 800;
  color: #4c0f7b;
  margin-bottom: 30px;
  font-size: 48px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .pricing-block .container .title-block h2 {
    font-size: 42px;
  }
}

@media (max-width: 800px) {
  .pricing-block .container .title-block h2 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .pricing-block .container .title-block h2 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .pricing-block .container .title-block h2 {
    font-size: 24px;
  }
}

.pricing-block .container .title-block p {
  font-weight: 300;
  font-size: 28px;
  line-height: 1.3;
}

@media (max-width: 800px) {
  .pricing-block .container .title-block p {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .pricing-block .container .title-block p {
    font-size: 18px;
  }
}

.pricing-block .container .items {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
}

.pricing-block .container .items .item {
  padding: 10px;
  flex-basis: 33.33%;
  min-width: 260px;
}

@media (max-width: 1200px) {
  .pricing-block .container .items .item {
    min-width: 300px;
  }
}

@media (max-width: 600px) {
  .pricing-block .container .items .item {
    flex-basis: 100%;
    margin-bottom: 20px;
  }
}

.pricing-block .container .items .item.active {
  padding: 0;
}

.pricing-block .container .items .item.active .inner {
  border: solid 10px rgba(76, 15, 100, 0.3);
  max-width: 360px;
}

@media (max-width: 600px) {
  .pricing-block .container .items .item.active .inner {
    max-width: 100%;
  }
}

.pricing-block .container .items .item .inner {
  display: flex;
  width: 100%;
  height: 100%;
  background-color: #fff;
  border-radius: 6px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  padding: 0;
  align-items: center;
  flex-direction: column;
  max-width: 340px;
}

@media (max-width: 800px) {
  .pricing-block .container .items .item .inner {
    max-width: 100%;
  }
}

.pricing-block .container .items .item .inner .name {
  height: 54px;
  border-bottom: solid 3px #cbd2e3;
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
  position: relative;
  color: #4c0f7b;
  font-weight: 800;
}

.pricing-block .container .items .item .inner .name:before {
  content: "";
  position: absolute;
  bottom: -3px;
  width: 75px;
  height: 3px;
  background-color: #4c0f7b;
}

.pricing-block .container .items .item .inner .price-block {
  background-color: #e5edff;
  display: flex;
  flex-direction: column;
  width: 100%;
  text-align: center;
  height: 165px;
  position: relative;
  align-items: center;
  justify-content: center;
}

.pricing-block .container .items .item .inner .price-block p {
  font-size: 12px;
}

.pricing-block .container .items .item .inner .price-block h3 {
  font-size: 30px;
  color: #4c0f7b;
  margin-bottom: 5px;
}

.pricing-block .container .items .item .inner .price-block a.button {
  max-width: 90%;
  position: absolute;
  bottom: -22px;
  width: 100%;
}

@media (max-width: 1200px) {
  .pricing-block .container .items .item .inner .price-block a.button {
    font-size: 14px;
    padding-left: 10px;
    padding-right: 10px;
  }
}

.pricing-block .container .items .item .inner .content-block {
  padding: 45px 20px 20px;
  font-size: 12px;
}

@media (max-width: 800px) {
  .pricing-block .container .items .item .inner .content-block {
    width: 100%;
  }
}

.pricing-block .container .items .item .inner .content-block p {
  line-height: 20px;
  margin-bottom: 10px;
}

.pricing-block .container .items .item .inner .content-block p strong {
  font-weight: 700;
}

.pricing-block .container .items .item .inner .content-block p span {
  color: #4c0f7b;
}

.pricing-block .container .items .item .inner .content-block ul {
  padding-left: 10px;
}

.pricing-block .container .items .item .inner .content-block ul li {
  padding: 10px 0 0 10px;
  position: relative;
  line-height: 20px;
  display: block;
}

.pricing-block .container .items .item .inner .content-block ul li:before {
  background-color: rgba(0, 0, 0, 0);
  width: auto;
  height: auto;
  top: 10px;
  border-radius: unset;
  content: "✓";
  margin-right: 10px;
  position: absolute;
  left: -10px;
  color: #4c0f7b;
  font-weight: 700;
}

/* CSS za Mjesečno/Godišnje birač */
.pricing-toggle-container {
  display: inline-flex;
  border: 1px solid var(--color-light-purple);
  border-radius: 100px;
  background-color: var(--color-grey1);
  padding: 5px;
  margin-top: 30px;
}

/* Centriranje teksta u karticama za Promocijske planove */
#promocijski-planovi .item .content-block {
  text-align: center;
}

.toggle-btn {
  background: transparent;
  border: none;
  border-radius: 100px;
  padding: 12px 25px;
  cursor: pointer;
  font-family: "Merriweather Sans", sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: var(--color-dark-turquoise2);
  transition: all 0.3s ease-in-out;
  text-align: center;
}

.toggle-btn.active {
  background-color: var(--color-orange);
  color: var(--color-purple);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.toggle-btn small {
  display: block;
  font-size: 11px;
  font-weight: 500;
  margin-top: 2px;
  opacity: 0.8;
}

/* Block Type 1 */
.block-type-1 {
  background-color: #e5edff;
  padding: 100px 0 !important;
}

.block-type-1,
.testimonial-block {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.block-type-1 .container .title-block {
  text-align: center;
  margin-bottom: 50px;
}

.block-type-1 .container .title-block h2 {
  font-weight: 800;
  color: #4c0f7b;
  margin-bottom: 30px;
  font-size: 48px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .block-type-1 .container .title-block h2 {
    font-size: 42px;
  }
}

@media (max-width: 800px) {
  .block-type-1 .container .title-block h2 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .block-type-1 .container .title-block h2 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .block-type-1 .container .title-block h2 {
    font-size: 24px;
  }
}

.block-type-1 .container .title-block p {
  font-weight: 300;
  font-size: 28px;
  line-height: 1.3;
}

@media (max-width: 800px) {
  .block-type-1 .container .title-block p {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .block-type-1 .container .title-block p {
    font-size: 18px;
  }
}

.block-type-1 .container .items {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto;
  grid-gap: 30px;
}

@media (max-width: 800px) {
  .block-type-1 .container .items {
    grid-template-columns: 1fr 1fr;
    grid-gap: 20px;
  }
}

@media (max-width: 480px) {
  .block-type-1 .container .items {
    grid-template-columns: 1fr;
    grid-gap: 20px;
  }
}

.block-type-1 .container .items .item {
  border-radius: 4px;
  background-color: #fff;
  padding: 30px;
  text-align: center;
}

.block-type-1 .container .items .item .icon {
  font-size: 64px;
  color: #4c0f7b;
  margin-bottom: 20px;
}

.block-type-1 .container .items .item p {
  font-weight: 300;
  line-height: 26px;
  font-size: 16px;
}

/* Block Type 5 */
.block-type-5 {
  background-color: #e5edff;
}

.block-type-5 .container .title-block {
  text-align: center;
  margin-bottom: 100px;
}

@media (max-width: 600px) {
  .block-type-5 .container .title-block {
    margin-bottom: 40px;
  }
}

.block-type-5 .container .title-block h2 {
  font-weight: 800;
  color: #4c0f7b;
  margin-bottom: 30px;
  font-size: 48px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .block-type-5 .container .title-block h2 {
    font-size: 42px;
  }
}

@media (max-width: 800px) {
  .block-type-5 .container .title-block h2 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .block-type-5 .container .title-block h2 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .block-type-5 .container .title-block h2 {
    font-size: 24px;
  }
}

.block-type-5 .container .title-block p {
  font-weight: 300;
  font-size: 28px;
  line-height: 1.3;
}

@media (max-width: 800px) {
  .block-type-5 .container .title-block p {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .block-type-5 .container .title-block p {
    font-size: 18px;
  }
}

.block-type-5 .container .items {
  display: grid;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-gap: 30px;
}

@media (max-width: 600px) {
  .block-type-5 .container .items {
    grid-template-columns: 1fr;
    grid-gap: 15px;
  }
}

.block-type-5 .container .items .item {
  display: flex;
  width: 100%;
  height: 100%;
  background-color: #fff;
  border-radius: 10px;
  box-shadow: 0 3px 0 #4c0f7b;
  border: solid 1px #cbd2e3;
  padding: 30px;
  align-items: center;
}

.block-type-5 .container .items .item .icon-block {
  font-size: 42px;
  padding-right: 20px;
  color: #4c0f7b;
}

.block-type-5 .container .items .item .content-block {
  font-weight: 500;
  font-size: 18px;
  line-height: 28px;
}

@media (max-width: 600px) {
  .block-type-5 .container .items .item .content-block {
    font-size: 16px;
    line-height: 24px;
  }
}

/* Poboljšanje prikaza za 4 pogodnosti na većim ekranima */
@media (min-width: 801px) {
  #premium-pogodnosti .items {
    grid-template-columns: 1fr 1fr;
  }
}

/* Testimonial Block */
.testimonial-block .container .title-block {
  text-align: center;
  margin-bottom: 50px;
}

.testimonial-block .container .title-block h2 {
  font-weight: 800;
  color: #4c0f7b;
  margin-bottom: 30px;
  font-size: 48px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .testimonial-block .container .title-block h2 {
    font-size: 42px;
  }
}

@media (max-width: 800px) {
  .testimonial-block .container .title-block h2 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .testimonial-block .container .title-block h2 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .testimonial-block .container .title-block h2 {
    font-size: 24px;
  }
}

.testimonial-block .container .title-block p {
  font-weight: 300;
  font-size: 28px;
  line-height: 1.3;
}

@media (max-width: 800px) {
  .testimonial-block .container .title-block p {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .testimonial-block .container .title-block p {
    font-size: 18px;
  }
}
/* ====================================================== */
/* == NOVI STILOVI ZA TESTIMONIJALE (PLANS & PRICING) == */
/* ====================================================== */

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

.testimonial-block .testimonial {
  background-color: #e5edff;
  box-shadow: 0 3px 0 #4c0f7b;
  border-radius: 10px;
  padding: 30px;
  text-align: center;
  height: 100%;
}

/* NOVO PRAVILO */
.testimonial-block .testimonial__content {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.testimonial-block .testimonial__image {
  margin: 0 auto 20px auto; /* Centriranje i razmak ispod */
  width: 100px; /* Povećana širina */
  height: 100px; /* Povećana visina */
}

.testimonial-block .testimonial__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  border: 4px solid var(--color-white);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.testimonial-block .testimonial__text {
  color: #4c0f7b;
  font-style: italic;
  margin-bottom: 25px;
  font-size: 18px;
  line-height: 1.6;
  flex-grow: 1; /* Osigurava da tekst zauzme prostor i poravna autore */
}

.testimonial-block .testimonial__author {
  color: #002d39;
  font-weight: 800;
  font-size: 16px;
  margin-bottom: 5px;
}

.testimonial-block .testimonial__source {
  color: #005275;
  font-size: 14px;
}

/* CTA Block */
.cta-block {
  background-color: #4c0f7b;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQ0MCIgaGVpZ2h0PSI4MDAiIHZpZXdCb3g9IjAgMCAxNDQwIDgwMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTAgMEgxNDQwVjgwMEgwVjBaIiBmaWxsPSJ1cmwoI3BhaW50MF9saW5lYXJfMjEzXzE4NSkiLz4KPGC0ZWZzPgo8bGluZWFyR3JhZGllbnQgaWQ9InBhaW50MF9saW5lYXJfMjEzXzE4NSIgeDI9IjE0NDAiIHkyPSI4MDAiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzI0MDczQSIvPgo8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiM0QzBGN0IiLz4KPC9saW5lYXJHcmFkaWVudD4KPC9kZWZzPgo8L3N2Zz4=);
  background-size: cover;
  background-repeat: no-repeat;
  color: #fff;
  padding: 80px 0 !important;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.cta-block .container .title-block {
  text-align: center;
  margin-bottom: 50px;
}

.cta-block .container .title-block h2 {
  font-weight: 800;
  color: #fff;
  margin-bottom: 30px;
  font-size: 48px;
  line-height: 1.3;
}

@media (max-width: 1024px) {
  .cta-block .container .title-block h2 {
    font-size: 42px;
  }
}

@media (max-width: 800px) {
  .cta-block .container .title-block h2 {
    font-size: 36px;
    line-height: 1.3;
  }
}

@media (max-width: 600px) {
  .cta-block .container .title-block h2 {
    font-size: 28px;
  }
}

@media (max-width: 480px) {
  .cta-block .container .title-block h2 {
    font-size: 24px;
  }
}

.cta-block .container .title-block p {
  font-weight: 300;
  font-size: 28px;
  line-height: 1.3;
}

@media (max-width: 800px) {
  .cta-block .container .title-block p {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .cta-block .container .title-block p {
    font-size: 18px;
  }
}

.cta-block .container .btn-block {
  text-align: center;
}

.cta-block .container .btn-block a.button {
  margin-bottom: 10px;
}

.cta-block .container .btn-block p {
  font-size: 14px;
}

/* Custom Components for Pricing Page */

/* Comparison Table */
.comparison-table-container {
  overflow-x: auto;
  margin: 40px 0;
  border-radius: 10px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.comparison-table {
  width: 100%;
  min-width: 800px;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  table-layout: fixed;
}

.comparison-table th,
.comparison-table td {
  padding: 15px 12px;
  text-align: center;
  border-bottom: 1px solid #e5edff;
  position: relative;
}

.comparison-table th {
  background: #4c0f7b;
  color: white;
  font-weight: 800;
  font-size: 16px;
}

.comparison-table .feature-name {
  text-align: left;
  background: #f8f9ff;
  font-weight: 600;
  color: #002d39;
  width: 30%;
}

.comparison-table .feature-name a {
  color: #4c0f7b;
  text-decoration: none;
  border-bottom: 1px dashed #4c0f7b;
}

.comparison-table .feature-name a:hover {
  color: #24073a;
  border-bottom-color: #24073a;
}

/*
  Omogućavanje prelamanja teksta u stupcima plana za bolju responzivnost
*/
.comparison-table td:not(.feature-name),
.comparison-table th:not(.feature-name) {
  word-break: break-word;
}

.check-icon {
  color: #00c851;
  font-size: 18px;
  font-weight: bold;
}

.cross-icon {
  color: #ff4444;
  font-size: 18px;
  font-weight: bold;
}

@media (max-width: 600px) {
  .comparison-table-container {
    margin: 20px -20px;
  }
}

/* Plan Selector Tool */
.plan-selector-tool {
  background: linear-gradient(135deg, #e5edff 0%, #dac6ed 100%);

  padding: 40px;
  margin: 0;
  text-align: center;
}

.plan-selector-tool h3 {
  color: #4c0f7b;
  margin-bottom: 20px;
  font-weight: 800;
  font-size: 28px;
}

.plan-selector-tool p {
  color: #002d39;
  margin-bottom: 30px;
  font-size: 18px;
}

.ghost-button {
  background: transparent;
  border: 2px solid #4c0f7b;
  color: #4c0f7b;
  padding: 15px 30px;
  border-radius: 50px;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s ease;
  cursor: pointer;
}

.ghost-button:hover {
  background: #4c0f7b;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(76, 15, 123, 0.3);
}

/* FAQ Styles */
.faq-container {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid #e5edff;
  margin-bottom: 20px;
}

.faq-question {
  font-weight: 700;
  color: #4c0f7b;
  padding: 20px 0;
  cursor: pointer;
  position: relative;
  font-size: 22px;
}

.faq-question:after {
  content: "+";
  position: absolute;
  right: 0;
  font-size: 24px;
  font-weight: 300;
}

.faq-answer {
  padding-bottom: 20px;
  color: #002d39;
  line-height: 1.6;
  display: none; /* Sakriva odgovore po defaultu */
}

/* ====================================================== */
/* == NOVI STILOVI ZA SADRŽAJ UNUTAR FAQ SEKCIJE      == */
/* ====================================================== */

/* Osnovni stil za kontejner i razmak između paragrafa */
.faq-answer {
  text-align: left; /* Osigurava poravnanje ulijevo */
}
.faq-answer p {
  margin-bottom: 16px; /* Razmak ispod svakog paragrafa */
  line-height: 1.6;
}

/* Stil za podnaslove unutar odgovora */
.faq-answer .faq-subheading {
  font-weight: 700;
  font-size: 1.1em;
  color: var(--color-purple);
  margin-top: 24px;
  margin-bottom: 12px;
}

/* Glavni stil za liste */
.faq-answer ul {
  list-style: none;
  padding-left: 0;
  margin-bottom: 16px;
}
.faq-answer li {
  position: relative;
  padding-left: 25px; /* Prostor za kvačicu */
  margin-bottom: 12px;
  line-height: 1.6;
}
.faq-answer li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 1px;
  color: var(--color-purple);
  font-weight: 700;
}

/* Stil za ugniježđene (uvučene) liste */
.faq-answer ul ul {
  margin-top: 12px;
}
.faq-answer ul ul li::before {
  content: "•"; /* Mijenja kvačicu u točkicu za pod-stavke */
  color: var(--color-orange);
}

/* Stil za oznake (badges) */
.badge-new {
  display: inline-block;
  background-color: var(--color-orange);
  color: var(--color-purple);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.8em;
  font-weight: 700;
  margin-right: 6px;
  line-height: 1;
}

.faq-question.active:after {
  content: "−"; /* Mijenja plus u minus kada je pitanje aktivno */
}

/* Kombo Highlight */
/* AŽURIRANO PRAVILO - PROMJENA BOJE */
/* AŽURIRANO PRAVILO ZA POZADINU KOMBO SEKCIJE */

.kombo-highlight {
  background: linear-gradient(135deg, var(--color-dark-purple) 0%, var(--color-purple) 100%);

  padding: 50px 30px;
  margin: 0;
  text-align: center;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.kombo-highlight h2 {
  color: white;
  margin-bottom: 20px;
  font-size: 48px;
  font-weight: 800;
}

@media (max-width: 1024px) {
  .kombo-highlight h2 {
    font-size: 42px;
  }
}

@media (max-width: 800px) {
  .kombo-highlight h2 {
    font-size: 36px;
  }
}

@media (max-width: 600px) {
  .kombo-highlight h2 {
    font-size: 28px;
  }
}

.kombo-highlight p {
  font-size: 28px;
  margin-bottom: 40px;
}

@media (max-width: 800px) {
  .kombo-highlight p {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .kombo-highlight p {
    font-size: 18px;
  }
}

/* NOVI STILOVI ZA IZGLED KOMBO KARTICA */
#kombo-planovi .items {
  max-width: 800px; /* Ograničava širinu da se kartice ne razvuku previše */
  margin: 0 auto; /* Centriranje */
}

#kombo-planovi .item {
  flex-basis: 50%; /* Svaka kartica zauzima pola prostora */
}

@media (max-width: 800px) {
  #kombo-planovi .item {
    flex-basis: 100%; /* Na manjim ekranima idu jedna ispod druge */
  }
}

/* Smanjivanje fonta za podnaslov u Kombo paketi sekciji */
#kombo-planovi .title-block p {
  font-size: 20px;
}

@media (max-width: 800px) {
  #kombo-planovi .title-block p {
    font-size: 18px;
  }
}

/*
  Ispravak: Forsiranje malog fonta za opisni tekst u Kombo karticama
*/
#kombo-planovi .content-block p {
  font-size: 12px;
  line-height: 1.6;
}

/* Stil za prekriženu (staru) cijenu u Kombo karticama */
.price-block .old-price {
  font-size: 15px;
  opacity: 0.7;
  color: var(--color-dark-turquoise2);
  margin-bottom: 5px; /* Malo podešavanje razmaka */
}

/* Utility classes */
.text-center {
  text-align: center;
}

/* Stil za sekundarni gumb u CTA bloku */
.button.secondary-button {
  background-color: transparent;
  color: white;
  border: 2px solid white;
  text-transform: uppercase;
  font-weight: 800;
}

.button.secondary-button:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: white;
  opacity: 1;
}

/* ====================================================== */
/* == CSS KOD ZA MODAL I KVIZ (ZALIJEPITI U <style> TAG) == */
/* ====================================================== */

/* Stilovi za Modal (Popup) */
.modal-overlay {
  display: none; /* Inicijalno skriven */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: 1000;
  justify-content: center;
  align-items: center;
  padding: 20px;
}
.modal-overlay.active {
  display: flex; /* Prikazuje se dodavanjem klase .active */
}
.modal-content {
  background: #f4f7ff;
  border-radius: 10px;
  padding: 40px;
  position: relative;
  width: 100%;
  max-width: 650px;
  max-height: 90vh;
  overflow-y: auto;
  text-align: center;
}
.modal-close {
  position: absolute;
  top: 10px;
  right: 15px;
  background: none;
  border: none;
  font-size: 30px;
  color: #888;
  cursor: pointer;
  line-height: 1;
}
.modal-close:hover {
  color: #333;
}

/* Stilovi za kviz za odabir plana */
.quiz-step {
  display: none; /* Svi koraci su skriveni po defaultu */
  margin-top: 30px;
  border-top: 1px solid rgba(76, 15, 123, 0.2);
  padding-top: 30px;
}
.quiz-step.active {
  display: block; /* Prikazuje se samo aktivni korak */
}
.quiz-step h4 {
  color: var(--color-purple);
  margin-bottom: 20px;
  font-size: 20px;
}
.quiz-answers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 15px;
}
@media (max-width: 600px) {
  .quiz-answers {
    grid-template-columns: 1fr;
  }
}
.quiz-answer-btn {
  background: white;
  border: 2px solid var(--color-light-purple);
  color: var(--color-dark-turquoise2);
  padding: 15px;
  border-radius: 8px;
  font-weight: 400;
  text-align: center;
  transition: all 0.3s ease;
  cursor: pointer;
  width: 100%;
  font-family: "Merriweather Sans", sans-serif;
  font-size: 16px;
}
.quiz-answer-btn:hover {
  background: var(--color-purple);
  color: white;
  border-color: var(--color-purple);
}
.quiz-answer-btn small {
  display: block;
  margin-top: 5px;
  opacity: 0.7;
  font-size: 13px;
  line-height: 1.4;
}

/* Stilovi za rezultat kviza */
#quiz-result {
  text-align: center;
  padding-top: 20px;
}
#quiz-result h4 {
  font-weight: 500;
}
#quiz-result h3 {
  font-size: 28px;
  color: var(--color-purple);
  margin: 10px 0;
}
#quiz-result p {
  font-size: 16px;
  margin-bottom: 25px;
}

/* Stilovi za opcije plaćanja u rezultatu kviza */
.result-options {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-bottom: 15px;
}
.result-options label {
  display: inline-block;
  padding: 8px 15px;
  border: 1px solid var(--color-light-purple);
  border-radius: 50px;
  cursor: pointer;
  font-size: 14px;
  transition: all 0.2s ease-in-out;
  background: white;
}
.result-options input[type="radio"] {
  display: none; /* Skrivamo pravi radio gumb */
}
.result-options input[type="radio"]:checked + label {
  background-color: var(--color-purple);
  color: white;
  border-color: var(--color-purple);
}

/* Stil za napomene u rezultatu kviza */
.result-note {
  font-size: 14px;
  font-style: italic;
  color: #555;
  background-color: rgba(76, 15, 123, 0.05);
  padding: 10px;
  border-radius: 5px;
  margin-bottom: 20px;
  line-height: 1.5;
}

/* Stil za prikaz odabranih opcija (breadcrumbs) */
.quiz-breadcrumbs {
  margin-top: 20px;
  padding: 10px;
  background-color: rgba(76, 15, 123, 0.05);
  border-radius: 5px;
  font-size: 14px;
}
.quiz-breadcrumbs ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.quiz-breadcrumbs li {
  color: #555;
  padding-bottom: 5px;
}
.quiz-breadcrumbs li strong {
  color: var(--color-purple);
}
