/* ===================================================== */
/* CASSIOPEIA 4.x – CZYSTY LAYOUT                        */
/* Logo lewo | Menu prawo | Nowoczesny styl medyczny    */
/* ===================================================== */


/* ====================== */
/* GLOBAL                 */
/* ====================== */

body{
    background:#ffffff;
    color:#222;
}


/* ====================== */
/* HEADER                 */
/* ====================== */

.container-header,
.header-sticky,
.header-transparent{
    background:#ffffff !important;
    background-image:none !important;
    box-shadow:none !important;
    border-bottom:1px solid #e5e5e5 !important;
}

.container-header::before,
.container-header::after{
    display:none !important;
}


/* ====================== */
/* UKŁAD HEADER           */
/* ====================== */

.container-header .container-nav{
    display:grid !important;
    grid-template-columns:auto 1fr !important;
    align-items:center !important;
    padding:10px 0 !important;
}


/* ====================== */
/* LOGO                   */
/* ====================== */

.navbar-brand{
    grid-column:1 !important;
    justify-self:start !important;
    padding:6px 0 !important;
    margin:0 !important;
}

.navbar-brand img{
    max-height:58px !important;
    height:auto !important;
    width:auto !important;
}


/* ====================== */
/* MENU                   */
/* ====================== */

.mod-menu{
    grid-column:2 !important;
    justify-self:end !important;
}

/* lista poziomo */
.mod-menu .nav{
    display:flex !important;
    justify-content:flex-end !important;
    align-items:center !important;
    gap:30px !important;
    margin:0 !important;
    padding:0 !important;
}

/* linki */
.container-header .mod-menu .nav-link,
.container-header .mod-menu a{
    color:#111111 !important;
    background:none !important;
    text-decoration:none !important;
    font-weight:600 !important;
    letter-spacing:0.2px;
    padding:8px 2px !important;
    position:relative;
}

/* hover */
.container-header .mod-menu .nav-link:hover{
    color:#0d6efd !important;
}

/* aktywna pozycja */
.container-header .mod-menu .active > .nav-link,
.container-header .mod-menu .nav-link.active{
    color:#0d6efd !important;
}

/* usuń niebieskie focus boxy */
.container-header .mod-menu a:focus{
    background:none !important;
    outline:none !important;
}


/* ====================== */
/* HERO / TREŚĆ           */
/* ====================== */

.item-page{
    padding-top:26px !important;
    background:linear-gradient(180deg,#f3f7ff 0%,#ffffff 240px) !important;
    border-radius:18px;
}

.item-page h1{
    font-size:46px !important;
    line-height:1.08 !important;
    margin:18px 0 !important;
}

.item-page h2{
    margin-top:54px !important;
    font-size:34px;
}

.item-page p{
    font-size:18px;
    line-height:1.6;
    max-width:980px;
}

.item-page li{
    margin-bottom:10px;
    line-height:1.5;
}


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

.cta-wrapper{
    margin:22px 0 40px 0;
}

.cta-button{
    display:inline-block;
    background:#0d6efd;
    color:#ffffff !important;
    padding:14px 26px;
    border-radius:40px;
    font-size:18px;
    font-weight:700;
    text-decoration:none;
    box-shadow:0 10px 25px rgba(13,110,253,0.25);
    transition:all .18s ease;
}

.cta-button:hover{
    background:#0a58ca;
    transform:translateY(-2px);
}


/* ====================== */
/* KAFELKI DLACZEGO       */
/* ====================== */

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

.why-box{
    background:#ffffff;
    padding:22px;
    border-radius:16px;
    box-shadow:0 8px 24px rgba(0,0,0,0.06);
    transition:transform .18s ease;
}

.why-box:hover{
    transform:translateY(-3px);
}

.why-box h3{
    font-size:20px;
    margin:0 0 8px 0;
    color:#0d6efd;
}


/* ====================== */
/* OFERTA                 */
/* ====================== */

.offer-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:22px;
    margin-top:22px;
}

.offer-box{
    background:#ffffff;
    padding:24px;
    border-radius:16px;
    border:1px solid rgba(0,0,0,0.06);
    box-shadow:0 8px 24px rgba(0,0,0,0.05);
}


/* ====================== */
/* STRONA KONTAKT         */
/* ====================== */

.contact-page{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
    margin-top:20px;
}

.contact-card{
    background:#ffffff;
    border:1px solid rgba(0,0,0,0.08);
    border-radius:16px;
    padding:24px;
    box-shadow:0 8px 24px rgba(0,0,0,0.05);
}

.contact-link{
    color:#0d6efd !important;
    font-weight:700;
    text-decoration:none;
}

.map-wrap iframe{
    border-radius:14px;
}


/* ====================== */
/* MOBILE                 */
/* ====================== */

@media (max-width:991px){

    .container-header .container-nav{
        grid-template-columns:1fr !important;
    }

    .mod-menu{
        justify-self:start !important;
        margin-top:10px !important;
    }

    .mod-menu .nav{
        flex-direction:column !important;
        align-items:flex-start !important;
        gap:10px !important;
    }

    .contact-page{
        grid-template-columns:1fr;
    }
}

/* ===================================================== */
/* FINAL OVERRIDE – MENU zawsze czytelne na każdej stronie */
/* ===================================================== */

/* kolor linków w nagłówku – łapiemy wszystkie warianty Cassiopeia/Bootstrap */
.container-header a,
.container-header .navbar a,
.container-header .navbar-nav .nav-link,
.container-header .mod-menu a,
.container-header .mod-menu .nav-link{
  color:#111 !important;
  background:transparent !important;
  box-shadow:none !important;
  text-shadow:none !important;
  opacity:1 !important;
  filter:none !important;
}

/* hover */
.container-header a:hover,
.container-header .navbar-nav .nav-link:hover,
.container-header .mod-menu a:hover,
.container-header .mod-menu .nav-link:hover{
  color:#0d6efd !important;
  background:transparent !important;
}

/* focus / focus-visible – usuwa „niebieskie kafelki” */
.container-header a:focus,
.container-header a:focus-visible,
.container-header .navbar-nav .nav-link:focus,
.container-header .navbar-nav .nav-link:focus-visible,
.container-header .mod-menu a:focus,
.container-header .mod-menu a:focus-visible{
  color:#0d6efd !important;
  background:transparent !important;
  outline:none !important;
  box-shadow:none !important;
}

/* aktywny element */
.container-header .active > a,
.container-header a.active,
.container-header .navbar-nav .active > .nav-link,
.cont

/* ===================================================== */
/* FIX: MENU BIAŁE NA PODSTRONACH (wymuszenie)            */
/* ===================================================== */

header .container-header,
header .container-header .navbar,
header .container-header .container-nav{
  background:#fff !important;
}

/* NAJWYŻSZY PRIORYTET – kolor linków menu */
header .container-header .mod-menu a,
header .container-header .mod-menu a:visited,
header .container-header .mod-menu .nav-link,
header .container-header .mod-menu .nav-link:visited,
header .container-header .navbar-nav .nav-link,
header .container-header .navbar-nav .nav-link:visited{
  color:#111 !important;
  background:transparent !important;
  box-shadow:none !important;
  text-shadow:none !important;
  opacity:1 !important;
  filter:none !important;
}

/* hover / focus / active */
header .container-header .mod-menu a:hover,
header .container-header .mod-menu a:focus,
header .container-header .mod-menu .nav-link:hover,
header .container-header .mod-menu .nav-link:focus,
header .container-header .navbar-nav .nav-link:hover,
header .container-header .navbar-nav .nav-link:focus{
  color:#0d6efd !important;
  background:transparent !important;
  outline:none !important;
  box-shadow:none !important;
}

header .container-header .active > a,
header .container-header a.active{
  color:#0d6efd !important;
}

/* jeśli tekst jest w spanie */
header .container-header a *,
header .container-header .nav-link *{
  color:inherit !important;
}

/* ============================= */
/* KONTAKT – wypasiona wersja    */
/* ============================= */

.contact-lead{
  font-size:18px;
  line-height:1.7;
  max-width:980px;
  margin: 10px 0 22px 0;
  opacity:.92;
}

.contact-page{
  display:grid !important;
  grid-template-columns: 1.05fr 0.95fr !important;
  gap:24px !important;
  margin-top:18px !important;
}

.contact-card{
  background: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  border-radius: 18px !important;
  padding: 26px !important;
  box-shadow: 0 10px 28px rgba(0,0,0,0.06) !important;
  backdrop-filter: blur(6px);
}

.contact-card h2{
  margin:0 0 16px 0 !important;
  font-size: 30px;
}

.contact-row{
  display:flex;
  gap:14px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}

.contact-row:last-of-type{
  border-bottom:none;
  padding-bottom: 6px;
}

.contact-ico{
  width:40px;
  height:40px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(13,110,253,0.10);
  font-size:18px;
  flex: 0 0 40px;
}

.contact-label{
  font-size: 13px;
  letter-spacing: .4px;
  text-transform: uppercase;
  opacity:.70;
  margin-bottom:4px;
}

.contact-plain{
  font-size:16px;
  line-height:1.55;
}

.contact-note{
  font-size: 13px;
  opacity:.75;
  margin-top:4px;
}

.contact-link{
  color:#0d6efd !important;
  font-weight:700 !important;
  text-decoration:none !important;
}

.contact-link:hover{
  text-decoration:underline !important;
}

.contact-big{
  font-size:20px;
}

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

.hours-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:16px;
}

.cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}

.cta-button{
  display:inline-block;
  background:#0d6efd;
  color:#fff !important;
  padding:14px 22px;
  border-radius: 999px;
  font-weight:800;
  text-decoration:none !important;
  box-shadow: 0 12px 30px rgba(13,110,253,0.28);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.cta-button:hover{
  background:#0a58ca;
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(13,110,253,0.34);
}

.cta-secondary{
  display:inline-block;
  padding:14px 18px;
  border-radius: 999px;
  border: 1px solid rgba(13,110,253,0.25);
  background: rgba(13,110,253,0.06);
  color:#0d6efd !important;
  font-weight:800;
  text-decoration:none !important;
  transition: transform .18s ease, background .18s ease;
}

.cta-secondary:hover{
  transform: translateY(-2px);
  background: rgba(13,110,253,0.10);
}

.contact-tip{
  margin-top:16px;
  padding:14px 16px;
  border-radius:14px;
  background: rgba(0,0,0,0.03);
  border: 1px dashed rgba(0,0,0,0.10);
  font-size:14px;
  line-height:1.55;
}

.map-wrap{
  border-radius: 16px !important;
  overflow:hidden !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  box-shadow: 0 10px 28px rgba(0,0,0,0.06) !important;
}

.map-note{
  margin-top:12px;
  font-size:14px;
  opacity:.80;
}

/* MOBILE */
@media (max-width: 991px){
  .contact-page{
    grid-template-columns:1fr !important;
  }
  .contact-card{
    padding: 20px !important;
  }
  .contact-card h2{
    font-size: 26px;
  }
}

/* ===== LOGO - większe i wyraźniejsze ===== */

.navbar-brand img,
.brand-logo img {
    max-height: 70px !important;   /* zwiększ z ~40-50px */
    width: auto !important;
}

.navbar-brand {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
}

/* Lekka poprawa ostrości */
.navbar-brand img {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}


/* ===================================================== */
/* MOBILE MENU FIX – Cassiopeia (Joomla 4/5)            */
/* Logo lewo | Burger prawo | Menu pod spodem           */
/* ===================================================== */

@media (max-width: 991px){

  /* ===== UKŁAD GRID ===== */
  .container-header .container-nav{
    grid-template-columns: 1fr auto !important;
    align-items: center !important;
    gap: 10px !important;
  }

  /* ===== LOGO ===== */
  .navbar-brand{
    justify-self: start !important;
    margin: 0 !important;
  }

  .navbar-brand img{
    max-height: 60px !important;
  }

  /* ===== BURGER (toggler) ===== */
  .navbar-toggler{
    display: inline-flex !important;
    justify-self: end !important;
    align-items: center !important;
    padding: 6px 10px !important;
    border-radius: 8px !important;
  }

  /* ===== MENU POD SPODem ===== */
  .mod-menu{
    grid-column: 1 / -1 !important;
    width: 100% !important;
    justify-self: stretch !important;
    margin-top: 10px !important;
  }

  /* tło rozwijanego menu */
  .container-header .mod-menu{
    background: #ffffff !important;
    border-top: 1px solid rgba(0,0,0,0.06) !important;
    padding-top: 6px !important;
  }

  /* ===== LISTA PIONOWO ===== */
  .mod-menu .nav{
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    width: 100% !important;
  }

  .mod-menu .nav > li{
    width: 100% !important;
  }

  /* ===== LINKI JAK KAFELKI ===== */
  .container-header .mod-menu a,
  .container-header .mod-menu .nav-link{
    display: block !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid rgba(0,0,0,0.06) !important;
  }

  .container-header .mod-menu .nav > li:last-child a{
    border-bottom: none !important;
  }

  /* hover */
  .container-header .mod-menu a:hover{
    background: rgba(13,110,253,0.06) !important;
  }

}

/* ===================================================== */
/* MOBILE FIX (bez hamburgera): menu pod logo, nie po prawej */
/* ===================================================== */

@media (max-width: 991px){

  /* zamiast siatki – prosty układ flex (pewny w Cassiopeia) */
  header .container-header .container-nav{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:10px !important;
  }

  /* logo */
  header .container-header .navbar-brand{
    order:1 !important;
    margin:0 !important;
  }

  /* jeśli jest hamburger – trafi na prawo */
  header .container-header .navbar-toggler{
    order:2 !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
  }

  /* menu zawsze pod spodem i na 100% szerokości */
  header .container-header .mod-menu{
    order:3 !important;
    width:100% !important;
    justify-self:stretch !important;
    text-align:left !important;
    margin-top:8px !important;
  }

  header .container-header .mod-menu .nav{
    display:flex !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    justify-content:flex-start !important;
    gap:10px !important;
    width:100% !important;
  }

  header .container-header .mod-menu .nav > li{
    width:100% !important;
  }

  header .container-header .mod-menu a,
  header .container-header .mod-menu .nav-link{
    display:block !important;
    padding:12px 0 !important;
  }
}

