/*
-- Spis treści --
0. Podstawowe
1. Typografia
2. Formularze
3. Nagłowek
5. Stopka
6. Mobile
*/


@import url('https://fonts.googleapis.com/css2?family=Orelega+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');


/* 0. Podstawowe */

html {
    scroll-behavior: smooth;
}

body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    font-family: "Poppins", sans-serif;
    color: #6D6D6D;
    background-color: #fff;
}

html,body {
    overflow-x: hidden;
}

a {
    color: #000;
}

.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

.bgwhite {
    background-color: #fff;
}

figure.dgwt-jg-item.jg-entry.jg-entry-visible {
    border-radius: 8px;
}

.head-mobile {
    display: none;
}

.head-0 {
    margin: 0;
    padding: 0;
}


/* 1. Typografia */

h1, h2, h3, h4, h5, h6 {
    font-family: "Orelega One", serif;
    font-weight: 400;
    font-style: normal;
    color: #000;
}

h1 {
    font-size: 3rem;
}

h2 {
    font-size: 2.8rem;
}

h3 {
    font-size: 1.8rem;
    margin: 10px 0;
}




/* 2. Formularze */


input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: #000;
    padding: 14px;
    border: 2px solid #000;
    border-radius: 8px;
    vertical-align: middle;
	width: 100%;
	font-size: 18px;
    margin-bottom: 17px;
    box-sizing: border-box;
}

input[type="text"]:focus,
textarea:focus,
input[type="email"]:focus {
    background-color: #eee;
    border: 2px solid #444;
}

input[type="text"]::placeholder,
textarea::placeholder,
input[type="email"]::placeholder {
	font-size: 14px;
	color: #666;
}

button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.btn,
.reply a {
    background-color: #EAFAFF;
    border: 2px solid #000;
    border-radius: 8px;
	padding: 15px 20px;
    font-size: 18px;
    font-weight: 700;
	color: #000;
}

button:active, 
button:focus {
    background-color: #ddf4fb;
}

.wpcf7 form.sent .wpcf7-response-output {
    border-radius: 5px;
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
    border-radius: 5px;
}

.wpcf7 form.spam .wpcf7-response-output {
    border-radius: 5px;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    border-radius: 5px;
}

label {
    font-size: 14px;
    margin: 0;
}    

.contact-div {
    padding: 15px;
}

/* 3. Nagłowek */

.site-header {
    padding: 10px 0 0 0;
    background-position: center center;
    background-size: cover;
}



/* -------------- nawigacja -------------- */

#site-navigation {
    display: flex;
    align-items: center;
    padding: 5px 0 0 0;
    justify-content: center;
}

.nav-menu {
    width: 100%;
    margin: 20px auto 0 auto;
    vertical-align: middle;
    background-color: #EAFAFF;
    padding: 7px;
    border: 2px solid #000;
    border-radius: 8px;
}

.menulinks {
    display: none;
    text-align: center;
    width: 35px;
    height: 35px;
    color: #fff;
    position: absolute;
    cursor: pointer;
    top: 14px;
    right: 6px;
}

ul.mainmenu {
    vertical-align: middle;
    display: inline-block;
    margin: 0;
    padding: 0;
    list-style: none;
    text-align: left;

}

ul.mainmenu>li {
    display: inline-block;
    padding: 0 5px;
    position: relative;
}

ul.mainmenu>li>a:link,
ul.mainmenu>li>a:visited {
    text-decoration: none;
    font-family: "Orelega One", serif;
    font-size: 27px;
    letter-spacing: 1px;
    display:block;
    padding: 8px 30px;
    text-align: center;
    position: relative;
}

ul.mainmenu>li:hover>a,
ul.mainmenu>li>a.current {
    color: #686868;
    text-decoration: none;
    background-color: #fff;
    border-radius: 8px;
}

ul.mainmenu>li>a.current {
    border-bottom-color: #686868;
}

ul.mainmenu>li>a.current:after {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-width: 8px;
    margin-left: -8px;
}

ul.mainmenu ul {
    position: absolute;
    left: 0;
    width: 250px;
    list-style: none;
    margin: 0;
    padding: 7px;
    border: 2px solid #000;
    background-color: #EAFAFF;
    border-radius: 8px;
    padding: 10px;
    z-index: 2;
    display: none;
}

ul.mainmenu ul li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    position: relative;
}

ul.mainmenu ul li:last-child {
    border-bottom: none;
}

ul.mainmenu li li a:link,
ul.mainmenu li li a:visited {
    display: block;
    padding: 8px 15px;
    font-family: "Orelega One", serif;
    font-size: 19px;
    text-decoration: none;
}

ul.mainmenu li li a:hover {
    color: #686868;
    background-color: #fff;
    border-radius: 8px;
}

ul.mainmenu ul ul {
    position: absolute;
    left: 100%;
    top: 0;
    display: none;
}


@media (min-width: 1024px) {

    ul.mainmenu {
        display: flex;
        justify-content: space-evenly;
    }

    ul.mainmenu li:hover>ul {
        display: block;
    }

    ul.mainmenu ul li:hover ul {
        display: block;
    }

    .mobile-buttons {
        display: none;
    }
}


@media (max-width: 1023px) {

    .top-nav {
        margin-top: 40px;
    }

    .nav-menu {
        background-color: #fff;
        border: 0;
        margin: 0;
    }

    .mobile-buttons {
        display: block;
        margin-right: 45px;
    }

    .mobile-button {
        width: 40px;
        float: right;
    }

    .menulinks {
        display: inline-block;
    }

    ul.mainmenu {
        text-align: left;
        position: absolute;
        top: 131px;
        padding: 10px;
        right: 0;
        width: 100%;
        box-sizing: border-box;
        background: #EAFAFF;
        border: 2px solid #000;
        border-radius: 8px;
        display: none;
        z-index: 9999999;
    }

    ul.mainmenu>li {
        float: left;
        width: 100%;
        padding: 0px;
        margin: 0;
        position: relative;
    }

    ul.mainmenu>li:first-child {
        border: none;
    }

    ul.mainmenu>li>a:link,
    ul.mainmenu>li>a:visited {
        padding: 10px 15px;
        font-size: 24px;
        float: left;
        width: 100%;
        border: none;
        text-align: left;
        color: #000;
    }

    ul.mainmenu>li:hover>a,
    ul.mainmenu>li>a.current {
        background-color: transparent
    }

    ul.mainmenu li li a:hover {
        background-color: #fff;
        border-radius: 0;
    }

    ul.mainmenu ul {
        border: 0;
        padding-left: 10px;
        padding: 0;
    }

    a.menulinks i {
        display: inline;
        position: relative;
        top: -2px;
        margin-left: 0;
        -webkit-transition-duration: 0s;
        -webkit-transition-delay: .2s;
        -moz-transition-duration: 0s;
        -moz-transition-delay: .2s;
        transition-duration: 0s;
        transition-delay: .2s;
    }

    a.menulinks i:before,
    a.menulinks i:after {
        position: absolute;
        content: '';
        left: 0;
    }

    a.menulinks i,
    a.menulinks i:before,
    a.menulinks i:after {
        width: 30px;
        height: 4px;
        background-color: #00bb00;
        display: inline-block;
        border-radius: 5px;
    }

    a.menulinks i:after {
        background-color: #5099ff;
    }

    a.menulinks i {
        background-color: #FF0000;
        left: -5px;
    }

    a.menulinks i:before {
        margin-top: -10px;
        transition-property: margin, -webkit-transform;
        transition-duration: .2s;
        transition-delay: .2s, 0;
        -webkit-transition-property: margin, -webkit-transform;
        -webkit-transition-duration: .2s;
        -webkit-transition-delay: .2s, 0;
    }

    a.menulinks i:after {
        margin-top: 10px;
        transition-property: margin, -webkit-transform;
        transition-duration: .2s;
        transition-delay: .2s, 0;
        -webkit-transition-property: margin, -webkit-transform;
        -webkit-transition-duration: .2s;
        -webkit-transition-delay: .2s, 0;
    }

    .mobile-open a.menulinks i {
        background-color: rgba(0, 0, 0, 0.0);
        transition-delay: .2s;
        box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
        -webkit-transition-delay: .2s;
        -webkit-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
        -moz-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);

    }

    .mobile-open a.menulinks i:before {
        margin-top: 0;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
        transition-delay: 0, .2s;
        -webkit-transition-delay: 0, .2s;
        -webkit-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
        -moz-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
        box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
    }

    .mobile-open a.menulinks i:after {
        margin-top: 0;
        -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg);
        transition-delay: 0, .2s;
        -webkit-transition-delay: 0, .2s;
        -webkit-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
        -moz-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
        box-shadow: 0px 1px 1px rgba(0, 0, 0, 0);
    }

    ul.mainmenu>li>a.current:after {
        display: none;
    }

    ul.mainmenu ul {
        position: relative;
        top: auto;
        left: auto;
        float: left;
        width: 100%;
    }

    ul.mainmenu ul li {
        position: relative;
        margin-left: 20px;
    }

    ul.mainmenu ul li a {
        padding: 8px 15px 8px 25px;
        color: #000;
    }

    ul.mainmenu ul ul {
        position: relative;
        left: auto;
        top: auto;
        float: left;
        width: 100%;
    }

    ul.mainmenu ul ul li {
        padding-left: 10px;
    }

    a.child-triggerm {
        display: block !important;
        cursor: pointer;
        position: absolute !important;
        top: 0px;
        right: 0px;
        width: 50px !important;
        min-width: 50px !important;
        height: 38px !important;
        padding: 0 !important;
        border-radius: 8px;
        border: 2px solid #000;
    }

    a.child-triggerm:hover {
        color: #FF0000;
    }

    a.child-triggerm span {
        position: relative;
        top: 50%;
        margin: 0 auto !important;
        -webkit-transition-duration: .2s;
        -moz-transition-duration: .2s;
        transition-duration: .2s;
    }

    a.child-triggerm span:after {
        position: absolute;
        content: '';
    }

    a.child-triggerm span,
    a.child-triggerm span:after {
        width: 15px;
        height: 3px;
        background-color: #FF0000;
        display: block;
    }

    a.child-triggerm span:after {
        -webkit-transform: rotate(-90deg);
        -ms-transform: rotate(-90deg);
        transform: rotate(-90deg);
        -webkit-transition-duration: .2s;
        -moz-transition-duration: .2s;
        transition-duration: .2s;
    }

    a.child-triggerm.child-open span:after {
        -webkit-transform: rotate(-180deg);
        -ms-transform: rotate(-180deg);
        transform: rotate(-180deg);
        -webkit-transition-duration: .2s;
        -moz-transition-duration: .2s;
        transition-duration: .2s;
    }

    a.child-triggerm.child-open span {
        -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
        -webkit-transition-duration: .2s;
        -moz-transition-duration: .2s;
        transition-duration: .2s;
    }

    a.child-triggerm:hover span,
    a.child-triggerm:hover span:after {
        background-color: #FF0000;
    }

    

}



@media (max-width: 768px) {

    .user-icon {
        display: none !important;
    }
  
}







/* --- top icons - wspólne --- */
.site-header > .grid.container:first-of-type{
  align-items:center;
}

.topicons{
  display:flex;
  align-items:center;
  gap: 30px;
  list-style:none;
  margin:0; padding:0;
}

/* jeśli chcesz ścisnąć prawą stronę przy prawej krawędzi */
.topicons--right{
  justify-content:flex-end;
}

.topicon-link{
  /* reset linka/przycisku */
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:45px; height:45px;  /* NIE zmieniamy rozmiaru */
  padding:0;
  cursor:pointer;
  text-decoration:none;
  line-height:1;
}

.topicon{
  display:block;
  width:45px; height:45px;  /* Ikony SVG mają dokładnie 45x45 */
}

.topicon-link:hover,
.topicon-link:focus-visible{
  opacity: 0.6;
}

/* --- dropdowny --- */

.top-nav{ position:relative; }  /* kotwica dla paneli w obrębie kolumny */

.dropdown{
  position:relative;
}

.dropdown.is-open .dropdown-panel{
  display:block;
}

.dropdown button.topicon-link{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid transparent;
  background:transparent;
}

.dropdown--search .dropdown-panel{
  max-width:min(92vw, 520px);
  width:clamp(260px, 48vw, 520px);
  padding:16px;
}

.searchform{
  display:flex;
  gap:10px;
  align-items:center;
}

.searchform input[type="search"]{
  flex:1 1 auto;
  height:38px;
  padding:0 12px;
  border: 0;
  font-size:18px;
  font-weight: 600;
  margin-top: 15px;
  letter-spacing: 0.5px;
}

.searchform .btn{
  padding: 12px;
  border-radius: 8px;
  border: 2px solid #000;
  background:#EAFAFF;
  font-weight: 600;
  cursor:pointer;
}

/* Ekrany wąskie: ułóż pionowo */
@media (max-width: 480px){
  .searchform{
    flex-direction:column;
    align-items:stretch;
  }
  .searchform .btn{ width:100%; }
}

/* Ukryta etykieta dla dostępności */
.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0);
  border:0;
}

/* panel – ustawienie domyślne (wyśrodkowany pod ikoną) */
.dropdown-panel{
  position:absolute;
  left:50%;
  top:calc(100% + 10px);
  transform:translateX(-50%);
  right:auto;
  min-width:240px;
  max-width:min(90vw, 340px);  /* nigdy nie wyjedzie poza ekran */
  padding:14px 16px;
  background:#fff;
  border: 2px solid #000;
  border-radius: 8px;
  box-shadow:0 12px 28px rgba(0,0,0,.10);
  display:none;
  z-index:1000;
  font-size:0.95rem;
  transform-origin: top center;
}

/* pokaż bez JS */
.top-nav .dropdown:not(.is-open) .dropdown-panel{
  display: none !important;
}

/* drobne elementy w panelu */
.dropdown-panel p{ margin:0 0 8px; }


/* strzałka – domyślnie środek */
.dropdown-panel::before{
  content:"";
  position:absolute;
  left:50%;
  top:-8px;
  width:12px; height:12px;
  background:#fff;
  border-left: 2px solid #000;
  border-top: 2px solid #000;
  transform:translateX(-50%) rotate(45deg);
}


/* Lewy nav: panel przylega do lewej krawędzi kolumny */
.top-nav--left .dropdown-panel{
  left:0;
  right:auto;
  transform:none; 
  max-width:min(92vw, 520px); 
  width:clamp(260px, 48vw, 520px);
}
.top-nav--left .dropdown-panel::before{
  left:20px; right:auto; transform:rotate(45deg);
}

/* Prawy nav: panel przylega do prawej krawędzi kolumny */
.top-nav--right .dropdown-panel{
  right:0;
  left:auto;
  transform:none;
  max-width:min(92vw, 520px);
  width:clamp(260px, 48vw, 520px);
}
.top-nav--right .dropdown-panel::before{
  right:20px; left:auto; transform:rotate(45deg);
}

/* Tylko wyszukiwarka ma szeroki panel */
.dropdown--search .dropdown-panel{
  max-width:min(92vw, 520px);
  width:clamp(260px, 48vw, 520px);
  padding:16px;
}

/* Wszystkie inne dropdowny (np. kontakt) – wracają do kompaktowej szerokości */
.top-nav--left .dropdown:not(.dropdown--search) .dropdown-panel,
.top-nav--right .dropdown:not(.dropdown--search) .dropdown-panel{
  width:auto; 
  max-width:min(90vw, 340px); 
  padding:14px 16px; 
}











@media screen and (max-width: 1023px) {

    .menu-toggle {
        margin: 0;
        padding: 0;
    }

    .topicons {
        gap: 5px;
    }

    .topicon {
        display: block;
        width: 38px;
        height: 38px;
    }

}

/* ------------------------- 4. Stopka ------------------------- */
footer {
    padding: 80px 0 30px 0;
    font-size: 18px;
    position: relative;
    z-index: 4;
}

footer a {
    text-decoration: none;
}

footer h2 {
    font-size: 47px;
    color: #000;
    text-align: center;
    font-weight: 600;
    font-style: normal;
}

footer h3 {
    margin-bottom: 40px;
}

footer .widget_nav_menu ul li {
    font-size: 16px;
    line-height: 33px;
}

footer .widget_text p {
    font-size: 16px;
    line-height: 21px;
    margin-bottom: 20px;
}

.footer2 {
    margin: 50px 0 0 0;
    padding: 60px 0 0 0;
    border-top: 1px solid #DBDBDB;
    letter-spacing: 2px;
    font-size: 13px;
    box-sizing: border-box;
}



/* back to top */

#back-to-top {
    position: fixed;
    bottom: 20px;
    right: 30px;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    text-align: center;
    line-height: 50px;
    font-size: 17px;
    cursor: pointer;
    display: none;
    z-index: 2000;
    transition: background-color 0.3s ease;
}

#back-to-top:hover {
    animation: pulse 1.5s infinite;
}

@keyframes pulse {

    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.1);
    }
}

.progress-circle {
    position: absolute;
    top: -4px;
    left: -4px;
    width: calc(100% + 8px);
    height: calc(100% + 8px);
    pointer-events: none;
}

.progress-circle svg {
    width: 100%;
    height: 100%;
    transform: rotate(0deg);
}

.progress-circle .circle-bg {
    fill: none;
    stroke-width: 2px;
}

.progress-circle .circle-progress {
    fill: none;
    stroke-width: 2px;
    stroke-dasharray: 100, 100;
    stroke-dashoffset: 100;
    transition: stroke-dashoffset 0.1s linear;
}


/* back to top - kolory */
#back-to-top {
    background-color: transparent;
    color: #9a9a9a;
}

#back-to-top:hover {
    background-color: #f8f8f8;
}

.progress-circle .circle-bg {
    stroke: #eee;
}

.progress-circle .circle-progress {
    stroke: #9a9a9a;
}



/* mgk stopka */

[data-tooltip] {
    position: relative;
    z-index: 2;
    cursor: pointer;
}

[data-tooltip]:before,
[data-tooltip]:after {
    visibility: hidden;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=0);
    opacity: 0;
    pointer-events: none;
}

[data-tooltip]:before {
    position: absolute;
    bottom: 150%;
    left: 50%;
    margin-bottom: 5px;
    margin-left: -90px;
    padding: 7px;
    width: 170px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    background-color: #000;
    color: #fff;
    content: attr(data-tooltip);
    text-align: center;
    font-size: 13px;
    letter-spacing: normal;
    line-height: 1.2;
}

[data-tooltip]:after {
    position: absolute;
    bottom: 150%;
    left: 50%;
    margin-left: -5px;
    width: 0;
    border-top: 5px solid #000;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    content: " ";
    font-size: 0;
    line-height: 0;
}

[data-tooltip]:hover:before,
[data-tooltip]:hover:after {
    visibility: visible;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=100);
    opacity: 1;
}

/* mgk stopka (koniec) */


/* ------------------------ 5. Mobile -------------------------------- */

@media screen and (max-width: 1024px) {
    header, main, footer {
        margin: 0 10px;
    }
   
    .head-mobile {
        display:flex;
    }

    .logo-img {
        max-width: 140px;
        height: auto;
        margin-left: 0;
    }

    .main-navigation {
        justify-content: center;
    }

    .main-navigation ul.nav-menu.toggled-on {
        top: 180px;
    }

    .entry-title {
        text-align: center;
    }

    .entry-content {
        margin:0;
        padding: 20px;
    } 

    .n-tlo1, .n-tlo2 {
        display: none;
    }

    .slogan {
        font-size: 62px;
    }
  
    footer h2 {
        font-size: 35px;
        margin-bottom: 30px;
    }

    footer {
        padding: 50px 0 10px 0;
    }
    
} 

