
@-moz-document url-prefix() {
  body {

  }
}

/* .virtual{
  letter-spacing: 5px;
} */

/* ================= ACCESSIBILITY STYLES ================= */

/* High Contrast Mode */
body.high-contrast {
  background: #000000 !important;
  color: #ffffff !important;
}

.navbar-toggler.nav-button .bg-light {
  background-color: white !important;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: #ffffff !important;
}

body.high-contrast * {
  background: black !important;
  color: #ffffff !important;
  border-color: #ffffff !important;
}

body.high-contrast header {
  background: #000000 !important;
  background-image: none !important;
}

body.high-contrast .about {
  background: #000000 !important;
  background-image: none !important;
}

body.high-contrast .contact {
  background: #000000 !important;
  background-image: none !important;
}

body.high-contrast .footer {
  background: #000000 !important;
  background-image: none !important;
}

body.high-contrast .nav-menu {
  background: #000000 !important;
}

body.high-contrast .pic1,
body.high-contrast .pic2,
body.high-contrast .pic3 {
  border: 2px solid #ffffff !important;
  background: #333333 !important;
}

body.high-contrast .card {
  background: #000000 !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast .packet-name-1,
body.high-contrast .packet-name-2,
body.high-contrast .packet-name-3,
body.high-contrast .packet-name-4,
body.high-contrast .packet-name-5 {
  background: #000000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast .packet-name-1-price,
body.high-contrast .packet-name-2-price {
  background: #000000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast .quote-box {
  background: #000000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast .btn {
  background: #000000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast .btn:hover {
  background: #333333 !important;
  color: #ffffff !important;
}

body.high-contrast .input {
  background: #000000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast textarea {
  background: #000000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast .submit-button {
  background: #000000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}

body.high-contrast .submit-button:hover {
  background: #333333 !important;
  color: #ffffff !important;
}

body.high-contrast .label {
  color: #ffffff !important;
}

body.high-contrast .menu-item {
  color: #ffffff !important;
}

body.high-contrast .menu-item:hover {
  color: #cccccc !important;
}

body.high-contrast a {
  color: #ffffff !important;
  text-decoration: underline !important;
}

body.high-contrast a:hover {
  color: #cccccc !important;
}

/* Large Font Mode */
html.large-font {
  font-size: 125% !important;
}

html.large-font body {
  font-size: 1.25em !important;
}

html.large-font h1 {
  font-size: 3rem !important;
}

html.large-font h2 {
  font-size: 2.5rem !important;
}

html.large-font h3 {
  font-size: 2rem !important;
}

html.large-font h4 {
  font-size: 1.75rem !important;
}

html.large-font h5 {
  font-size: 1.5rem !important;
}

html.large-font h6 {
  font-size: 1.25rem !important;
}

html.large-font .btn {
  font-size: 1.25em !important;
  padding: 0.75rem 1.5rem !important;
}

html.large-font .menu-item {
  font-size: 1.25em !important;
}

html.large-font .brand-name {
  font-size: 1.25em !important;
}

html.large-font .div {
  font-size: 1.25em !important;
}

html.large-font .packet-name {
  font-size: 1.5em !important;
}

html.large-font .input,
html.large-font textarea {
  font-size: 1.25em !important;
}

html.large-font .label {
  font-size: 1.1em !important;
}

/* Increased Letter Spacing */
html.increased-spacing {
  letter-spacing: 0.1em !important;
}

html.increased-spacing * {
  letter-spacing: 0.1em !important;
}

html.increased-spacing h1,
html.increased-spacing h2,
html.increased-spacing h3,
html.increased-spacing h4,
html.increased-spacing h5,
html.increased-spacing h6 {
  letter-spacing: 0.15em !important;
  word-spacing: 0.2em !important;
}

html.increased-spacing .menu-item {
  letter-spacing: 0.2em !important;
}

html.increased-spacing .btn {
  letter-spacing: 0.1em !important;
}

html.increased-spacing p,
html.increased-spacing span,
html.increased-spacing div {
  letter-spacing: 0.08em !important;
  word-spacing: 0.1em !important;
}

html.increased-spacing .input,
html.increased-spacing textarea {
  letter-spacing: 0.05em !important;
}

/* Combination adjustments for better readability */
body.high-contrast.large-font {
  line-height: 1.6 !important;
}

html.large-font.increased-spacing {
  line-height: 1.5 !important;
}

html.large-font.increased-spacing p,
html.large-font.increased-spacing div {
  line-height: 1.7 !important;
}

/* Focus indicators for better accessibility */
html.large-font *:focus,
html.increased-spacing *:focus {
  outline: 3px solid #0065C3 !important;
  outline-offset: 2px !important;
}

body.high-contrast *:focus {
  outline: 3px solid #ffffff !important;
  outline-offset: 2px !important;
}

/* ================= END ACCESSIBILITY STYLES ================= */

/* ================= KEYBOARD NAVIGATION ACCESSIBILITY ================= */
[role="button"],
button,
a,
input,
textarea,
select,
.menu-item,
.nav-menu,
.submit-button {
  outline: none;
  transition: outline 0.2s;
}

[role="button"]:focus,
button:focus,
a:focus,
input:focus,
textarea:focus,
select:focus,
.menu-item:focus,
.nav-menu:focus,
.submit-button:focus {
  outline: 3px solid #0065C3 !important;
  outline-offset: 2px !important;
  z-index: 1000;
}

body.high-contrast [role="button"]:focus,
body.high-contrast button:focus,
body.high-contrast a:focus,
body.high-contrast input:focus,
body.high-contrast textarea:focus,
body.high-contrast select:focus,
body.high-contrast .menu-item:focus,
body.high-contrast .nav-menu:focus,
body.high-contrast .submit-button:focus {
  outline: 3px solid #ffffff !important;
  outline-offset: 2px !important;
}

/* Skip to content link for keyboard users */
.skip-link {
  position: absolute;
  left: -999px;
  top: 10px;
  background: #0065C3;
  color: #fff;
  padding: 8px 16px;
  z-index: 2000;
  font-size: 1rem;
  border-radius: 4px;
  text-decoration: none;
  transition: left 0.2s;
}
.skip-link:focus {
  left: 10px;
  outline: 3px solid #0065C3;
}
/* ================= END KEYBOARD NAVIGATION ACCESSIBILITY ================= */


body{
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'Montserrat', sans-serif;
  /*font-family: 'Play', sans-serif;*/
overflow-x: hidden;


}

header{
  height: 100vh;
  background-image: linear-gradient(rgba(0,0,0, 0.4), rgba(0,0,0, 0.4)), url(../img/office2.jpg);
  background-size: cover;
  background-position: center;
  position: relative;
}

/* ------------------- nawigacja ------------------------------------ */

.nav-menu{
  /* background: linear-gradient(rgba(0,0,0, 0.3), rgba(0,0,0, 0.3)); */
  background: linear-gradient(rgba(0,0,0, .8), rgba(0,0,0, .8));
}

.menu-item{
  font-size: 13px;
  letter-spacing: 3px;
  color: #eee;
  transition: all .5s;
}

.menu-item:hover{
  color: #84b3ff;
}

.line1, .line2, .line3{
  width: 23px;
  height: 3px;
  margin: 5px;
  transition: all .5s;
}

.change .line1{
  transform: rotate(-45deg) translate(-5px, 6px);
}
.change .line2{
  opacity: 0;
}
.change .line3{
  transform: rotate(45deg) translate(-5px, -6px);
}

.custom-navbar{
  padding: 0 30px;
}

/* ------------------- koniec nawigacji ------------------------------------ */

/* ------------------- header ------------------------------------ */

.brand-name{
    font-family: 'Days One', sans-serif;
    width: 600px;
    display: inline-block;
}

.div{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 50px
}

.change-btn{
  transition: all .6s;
}


/* ------------------- koniec header ------------------------------------ */

/* ------------------- about------------------------------------ */

.about{
  background-image: linear-gradient(rgba(0,0,0, 0.7), rgba(0,0,0, 0.7)), url(../img/city.jpg);
  background-size: cover;
  background-position: center;
}

.bg-ul{
  background-color: transparent;
  color: white;
  border: 1px solid white;
  border-top: none;
  border-left: none;
  border-right: none;
  border-radius: 0 !important;
}

.bg-ul:last-child{
  border-bottom: none;
}

.pic1{
  background-image: url(../img/gallery/gal/sala.jpg);
  background-size: cover;
  background-position: center;
  height: 25rem;
}
.pic2{
  background-image: url(../img/gallery/gal/desk.jpg);
  background-size: cover;
  background-position: center;
  height: 25rem;
}
.pic3{
  background-image: url(../img/gallery/gal/account.jpg);
  background-size: cover;
  background-position: center;
  height: 25rem;
}


/* ------------------- koniec about ------------------------------------ */

/* ------------------- artykul ------------------------------------ */

blockquote{
    border-left:none
}

.quote-badge{
    background-color: rgba(0, 0, 0, 0.2);   
}

.quote-box{
    overflow: hidden;
    margin-top: -50px;
    padding-top: -100px;
    border-radius: 17px;
    background-color: #4ADFCC;
    margin-top: 25px;
    color:white;
    box-shadow: 2px 2px 2px 2px #E0E0E0;
    
}

.quotation-mark{
    margin-top: -10px;
    font-weight: bold;
    font-size:100px;
    color:white;
    font-family: "Times New Roman", Georgia, Serif;
    
}

.quote-text{
    margin-top: -65px;
}

/* ------------------- koniec artykul ------------------------------------ */


/* ------------------- oferta1 ------------------------------------ */

div.only-for-clients-wrapper {
  width: 100%;
  display: flex;
  justify-content: flex-end;
}

p.only-for-clients {
  font-size: .8rem;
  padding: 1rem;
}

/* ------------------- koniec oferta1------------------------------------ */



/* ------------------- oferta------------------------------------ */

.card{
  /* min-height: 690px; */
}

.poly{
  clip-path: polygon(0% 0%, 100% 0%, 100% 85%, 0% 100%);
}


.packets{
  position: relative;
}

.packet-name{
  position: absolute;
  top: 20%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 26px;
  width: 100%;
  color: white;
}

.packet-name-1{
  background: linear-gradient(rgba(48, 204, 68, .8), rgba(48, 204, 68, .8));
}
.packet-name-1-price{
  background: linear-gradient(rgba(255, 63, 111, .8), rgba(255, 63, 111, .8));
  position: absolute;
  top: 50%;
  left: 0%;
  font-size: 26px;
  width: 200px;
  color: white;
}
.packet-name-2-price{
  background: linear-gradient(rgba(255, 182, 12, .8), rgba(255, 182, 12, .8));
  position: absolute;
  top: 50%;
  right: 0%;
  font-size: 26px;
  width: 200px;
  color: white;
}
.packet-name-2{
  background: linear-gradient(rgba(57, 146, 229, .8), rgba(57, 146, 229, .8));
}
.packet-name-3{
  background: linear-gradient(rgba(126, 57, 229, .8), rgba(126, 57, 229, .8));
}
.packet-name-4{
  background: linear-gradient(rgba(252, 47, 133, .8), rgba(252, 47, 133, .8));
}
.packet-name-5{
  background: linear-gradient(rgba(252, 183, 46, .8), rgba(252, 183, 46, .8));
}

.ikonka-1{
  color: #4BC556;
}

.ikonka-2{
  color: #3EB8EA;
}
.ikonka-3{
  color: #6F36BE;
}

/* ------------------- koniec oferty------------------------------------ */

/* ------------------- kontakt------------------------------------ */

.contact{

  background: linear-gradient(105deg, rgba(21,31,32, 1) 0%, rgba(21,31,32, .95) 50%, transparent 51%), url(../img/contact.jpg);
  background-position: center;
  background-size: cover;
}

.input{
  background: transparent;
  border-color: transparent;
  border-bottom: 2px solid #ccc;
  border-radius: 0;
  transition: all .8s;
  color: #fff;
}

.input:focus{
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  color: #fff;
  border-bottom: 2px solid #f5593d;
}

.submit-button{
  background: #f5593d;
  color: #eee;
  transition: all .3s;
}

.submit-button:hover{
  background: #f9793d;
  transform: translateY(-3px);
}

.label{
  color: #777;
  display: block;
  margin-top: -70px;
  margin-left: 4px;
  font-size: 13px;
  transition: all .3s;
}

.input:placeholder-shown + .label{
  transform: translate(20px, 20px);
  opacity: 0;
  visibility: hidden;
}

.textarea{
  color: #777;
  font-size: 13px;
}

textarea {
  color: white !important;
  background: transparent !important;
}

textarea:focus{
  border: 2px solid #f5593d !important;
}

.success{
  color: #53ba2a;
}

.error{
  color: #cc0c0c;
}

.info{
  font-size: 10px;
}

/* ------------------- koniec kontaktu ------------------------------------ */


/* ------------------- footer ------------------------------------ */


footer .section-title {
    text-align: center;
    color: #007b5e;
    margin-bottom: 50px;
    text-transform: uppercase;
}
.footer {
    background: linear-gradient(rgba(31, 99, 209, .6), rgba(31, 99, 209, 1)), url(../img/footer.jpg);
    background-position: center;
    background-size: cover;
}
/* .footer h5{
	padding-left: 10px;
    border-left: 3px solid #eeeeee;
    padding-bottom: 6px;
    margin-bottom: 20px;
    color:#ffffff;
} */
.footer a {
    color: #ffffff;
    text-decoration: none !important;
    background-color: transparent;
    -webkit-text-decoration-skip: objects;
}
.footer ul.social li{
	padding: 3px 0;
}
.footer ul.social li a i {
    margin-right: 5px;
	font-size:25px;
	-webkit-transition: .5s all ease;
	-moz-transition: .5s all ease;
	transition: .5s all ease;
}
.footer ul.social li:hover a i {
	font-size:30px;
	margin-top:-10px;
}
.footer ul.social li a,
.footer ul.quick-links li a{
	color:#ffffff;
}
.footer ul.social li a:hover{
	color:#eeeeee;
}
.footer ul.quick-links li{
	padding: 3px 0;
	-webkit-transition: .5s all ease;
	-moz-transition: .5s all ease;
	transition: .5s all ease;
}
.footer ul.quick-links li:hover{
	padding: 3px 0;
	margin-left:3px;
	font-weight:700;
}
.footer ul.quick-links li a i{
	margin-right: 5px;
}
.footer ul.quick-links li:hover a i {
    font-weight: 700;
}


div.logo2 {
    display: grid;
    width: 100%;
    grid-template-columns: repeat(auto-fit, minmax(80px, 110px));
    justify-content: space-around;
    align-items: center;
}

div.logo2 div {
    justify-self: center;
}

.logo2 img {
    padding: 1rem;
    width: 100%;
}

@media (max-width:767px){
	.footer h5 {
    padding-left: 0;
    border-left: transparent;
    padding-bottom: 0px;
    margin-bottom: 10px;
}

}

/* ------------------- koniec footer ------------------------------------ */


/* ------------------- media queries ------------------------------------ */
@media (max-width: 575.98px) {

  .img-brand{
    width: 180px;
  }

  .div{
    top: 60%;
  }

  .brand-name{
    font-size: 32px;
    width: 320px;
    /* font-weight: 700; */
  }

  .brand-content{
    /* font-size: 25px; */
  }

  .nav-menu{
    background: linear-gradient(rgba(0,0,0, .9), rgba(0,0,0, .9));
  }

  .contact{
    background: linear-gradient(rgba(0,0,0, .5), rgba(0,0,0, .5)), url(../img/contact.jpg);
    background-position: center;
    background-size: cover;
  }

  .contact-us{
    font-size: 40px;
    text-align: center;
  }

  .g-recaptcha {
      transform:scale(0.77);
      transform-origin:0 0;
  }

  .packet-name-1-price{
    font-size: 15px;
    top: 40%;
  }
  .packet-name-2-price{
    font-size: 15px;
    z-index: 100;
    top: 65%;
  }

  .padding-top{
    padding-top: 30px;
  }

  .input::placeholder{
    color: white;
  }

  .label{
    color: white;
  }

  .textarea{
    color: white;
  }

  .textarea-change::placeholder{
    color: white;
  }

}


@media (max-width: 767.98px) {

}


@media (max-width: 991.98px) {

}


@media (max-width: 1199.98px) {

  .img-brand{
    width: 150px;
  }

  .change-nav{
    font-size: 13px;
  }
}

@media (max-width:1420px) and (min-width:1200px) {
    .packet-name-1-price{
        font-size: 20px;
         top: 40%;
    }

    .packet-name-2-price{
        font-size: 20px;
        z-index: 100;
        top: 65%;
    }
}

@media (max-width:992px) and (min-width:768px) {
    .pic1{
        height: 37rem;
    }
    .pic2{
        height: 35rem;
    }
    .pic3{
        height: 35rem;
    }
}


/* ------------------- koniec media queries ------------------------------------ */

/* ================= ACCESSIBILITY RESPONSIVE ADJUSTMENTS ================= */

@media (max-width: 575.98px) {
  /* High contrast adjustments for mobile */
  body.high-contrast .packet-name-1-price,
  body.high-contrast .packet-name-2-price {
    border: 1px solid #ffffff !important;
    font-size: 1em !important;
  }

  /* Large font adjustments for mobile */
  html.large-font .brand-name {
    font-size: 2rem !important;
    width: 100% !important;
  }

  html.large-font .div {
    font-size: 2.5rem !important;
  }

  html.large-font .packet-name-1-price,
  html.large-font .packet-name-2-price {
    font-size: 1.1em !important;
  }

  html.large-font .contact-us {
    font-size: 2.5rem !important;
  }

  /* Increased spacing adjustments for mobile */
  html.increased-spacing .menu-item {
    letter-spacing: 0.15em !important;
  }

  html.increased-spacing .brand-name {
    letter-spacing: 0.1em !important;
  }

  /* Combined accessibility features for mobile */
  html.large-font.increased-spacing .brand-name {
    line-height: 1.4 !important;
  }

  body.high-contrast.large-font .g-recaptcha {
    border: 2px solid #ffffff !important;
  }
}

@media (max-width: 767.98px) {
  html.large-font .pic1,
  html.large-font .pic2,
  html.large-font .pic3 {
    height: auto !important;
    min-height: 20rem !important;
  }
}

@media (max-width: 991.98px) {
  html.large-font .img-brand {
    width: auto !important;
    max-width: 200px !important;
  }
}

/* ================= END ACCESSIBILITY RESPONSIVE ADJUSTMENTS ================= */
