/* ----------------------------------------------------------------
[Table of contents]

01. Google Fonts
02. Default style
03. Scrollbar
04. Selection
06. Sidebar style
07. Main style
08. Navigation style
09. Header style
10. Title style
11. Bride & Groom style
12. Wedding Countdown style
13. Our Story style
17. Gallery style
21. Button style
23. Footer style
24. Media Query style

------------------------------------------------------------------- */

/* ===== Google Fonts ===== */
@import url('https://fonts.googleapis.com/css2?family=Alex+Brush&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Alex+Brush&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&family=Nunito+Sans:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400;1,600;1,700&display=swap');

@font-face {
  font-family: 'Cerlions';
  src: url('../fonts/Cerlions-Regular.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Rotherdam Signature';
  src: url('../fonts/Rotherdam-Signature.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

html,
body {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  -moz-font-smoothing: antialiased;
  font-smoothing: antialiased;
}

body {
  font-family: 'Nunito Sans', sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.75em;
  color: #888;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: #000;
  font-weight: 500;
  line-height: 1.25em;
  margin: 0 0 20px 0;
}

p {
  font-family: 'Nunito Sans', sans-serif;
  font-weight: 400;
  line-height: 1.75em;
  color: #888;
  margin: 0 0 20px;
}

ul {
  list-style-type: none;
}

a {
  color: #000;
  display: inline-block;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
}

a:hover,
a:active,
a:focus {
  color: #a9af93;
  outline: none;
  text-decoration: none !important;
}

a:link {
  text-decoration: none;
}

img {
  width: 100%;
  height: auto;
}

.small,
small {
  font-size: 80%;
}

b,
strong {
  color: #000;
  font-weight: 600;
}

span {
  display: inline-block;
  text-decoration: none;
}

hr {
  margin-top: 0px;
  margin-bottom: -20px;
  border: 0;
}

table,
th,
tr,
td {
  border: 1px solid #000;
}

th,
tr,
td {
  padding: 10px;
}

input[type='submit'],
input[type='reset'],
input[type='button'],
button {
  font-family: 'Nunito Sans', sans-serif;
  background: #a9af93;
  border: 1px solid #a9af93;
  color: #fff;
  padding: 15px 25px;
  margin: 0;
  position: relative;
  font-size: 12px;
  line-height: 1em;
  text-transform: uppercase;
  letter-spacing: 2px;
  border-radius: 0px;
}

input[type='submit']:hover,
input[type='reset']:hover,
input[type='button']:hover,
button:hover {
  background-color: transparent;
  color: #000;
}

label {
  color: #777;
  transition: all 0.3s cubic-bezier(0.64, 0.09, 0.08, 1);
  display: inline-block;
  -moz-appearance: none;
  display: inline-block;
  vertical-align: middle;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.75em;
  margin-bottom: 0;
}

.mb-15 {
  margin-bottom: 15px;
}

.form-control {
  font-family: 'Nunito Sans', sans-serif;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  background: transparent;
  border-bottom: 0px solid #e5e5e5;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
  font-size: 15px;
  line-height: 1.75em;
  padding: 7px 15px;
  height: auto;
  background-color: #fff;
  display: block;
  width: 100%;
  font-weight: 400;
  color: #000;
  background-image: none;
  border: 1px solid #ececec;
  margin-bottom: 15px;
}

.form-control:active,
.form-control:focus {
  outline: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  background-color: #fff;
  border: 1px solid #ececec;
  border-bottom-width: 1px;
}

.form-control:focus {
  outline: none;
  border: 1px solid #ececec;
}

.form-container {
  padding: 40px;
}

.p-40 {
  padding: 40px;
}

.mb-0 {
  margin-bottom: 0;
}

.mb-30 {
  margin-bottom: 30px;
}

.mb-60 {
  margin-bottom: 60px;
}

.mb-80 {
  margin-bottom: 80px;
}

.container-fluid {
  padding-right: 30px;
  padding-left: 30px;
}

.container {
  padding-right: 60px;
  padding-left: 60px;
}

.section-padding {
  padding-top: 100px;
  padding-bottom: 100px;
}

.js .animate-box {
  opacity: 0;
}

.clear {
  clear: both;
}

.o-hidden {
  overflow: hidden;
}

.pos-re {
  position: relative;
}

.full-width {
  width: 100% !important;
}

.bg-img {
  background-size: cover;
  background-repeat: no-repeat;
}

.bg-fixed {
  position: relative;
  background-attachment: fixed;
}

.bg-fixed .container {
  position: relative;
  z-index: 10;
}

.bg-cover {
  background-size: cover !important;
}

.v-middle {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0%, -50%);
  transform: translate(0%, -50%);
}

.valign {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.bg-cream {
  background-color: #f7f3f0;
}

.bg-white {
  background-color: #fff;
}

:root {
  scroll-behavior: auto;
}

::-webkit-scrollbar {
  width: 0px;
}

::-webkit-scrollbar-track {
  background: #fff;
}

::-webkit-scrollbar-thumb {
  background: #a9af93;
}

::-webkit-scrollbar-thumb:hover {
  background: #a9af93;
}

/* ===== Selection ===== */
::-webkit-selection {
  color: #fff;
  background: rgba(189, 148, 90, 0.75);
}

::-moz-selection {
  color: #fff;
  background: rgba(189, 148, 90, 0.75);
}

::selection {
  color: #fff;
  background: rgba(189, 148, 90, 0.75);
}

/* ===== Sidebar style ===== */
.oliven-page {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.oliven-aside {
  padding: 50px 30px 15px;
  display: flex;
  flex-direction: column;
  width: 20%;
  position: fixed;
  bottom: 0;
  top: 0;
  left: 0;
  overflow-y: scroll;
  z-index: 1001;
  background: #a9af93;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
  scrollbar-width: none;
}

@media screen and (max-width: 768px) {
  .oliven-aside {
    width: 270px;
    -moz-transform: translateX(-270px);
    -webkit-transform: translateX(-270px);
    -ms-transform: translateX(-270px);
    -o-transform: translateX(-270px);
    transform: translateX(-270px);
    padding-top: 30px;
  }
}

.oliven-aside .oliven-logo {
  font-family: 'Alex Brush', cursive;
  text-align: center;
  font-size: 40px;
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 60px;
  display: block;
  width: 100%;
  position: relative;
  color: #000;
  line-height: 1.2em;
  letter-spacing: 0px;
}

.oliven-aside .oliven-logo span {
  font-weight: 400;
  text-transform: none;
  text-align: center;
  font-size: 24px;
  color: #fff;
}

.oliven-aside .oliven-logo img {
  width: 90px;
  margin-bottom: 0px;
}

@media screen and (max-width: 768px) {
  .oliven-aside .oliven-logo {
    margin-bottom: 60px;
  }
}

.oliven-aside .oliven-logo a {
  display: inline-block;
}

.oliven-aside .oliven-logo a span {
  display: block;
  font-size: 32px;
  color: #fff;
  font-family: 'Alex Brush', cursive;
  display: block;
  margin-top: 0px;
  text-align: center;
  line-height: 1.5em;
}

.oliven-aside .oliven-logo a i {
  color: #fff;
  font-size: 16px;
  vertical-align: super;
}

.oliven-aside .oliven-main-menu ul {
  text-align: center;
  margin: 0;
  padding: 0;
}

@media screen and (max-width: 768px) {
  .oliven-aside .oliven-main-menu ul {
    margin: 0 0 30px 0;
  }
}

.oliven-aside .oliven-main-menu ul li {
  margin: 3px 0 3px 0;
  padding: 0 0 3px 0;
  list-style: none;
  font-family: 'Cerlions', sans-serif;
}

.oliven-aside .oliven-main-menu ul li a {
  color: #000;
  text-decoration: none;
  position: relative;
  padding: 0;
  font-size: 18px;
  line-height: 2em;
  letter-spacing: 1.5px;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  border-bottom: 1px solid transparent;
}

.oliven-aside .oliven-main-menu ul li a:hover {
  color: #fff;
  border-bottom: 1px solid #fff;
  -webkit-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
}

.oliven-aside .oliven-main-menu ul li.oliven-active a {
  color: #fff;
}

.oliven-aside .oliven-main-menu ul li.oliven-active a:after {
  visibility: visible;
  -webkit-transform: scaleX(1);
  -moz-transform: scaleX(1);
  -ms-transform: scaleX(1);
  -o-transform: scaleX(1);
  transform: scaleX(1);
}

.oliven-aside .oliven-main-menu ul li a span:hover {
  color: #000;
}

.oliven-aside .footer1 {
  position: relative;
  text-align: center;
  align-content: flex-end;
  flex: 1;
}

.oliven-aside .footer1 p {
  font-size: 10px;
  color: #000;
  letter-spacing: 0.5px;
}

.oliven-aside .footer1 img {
  width: 75px;
}

.oliven-aside .footer1 a {
  color: #a9af93;
}

.oliven-aside .separator {
  width: 60px;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  border-bottom: 1px solid rgba(189, 148, 90, 0.4);
  margin: 5px auto;
}

/* ===== Main style ===== */
.oliven-main {
  width: 80%;
  float: right;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
}

@media screen and (max-width: 768px) {
  .oliven-main {
    width: 100%;
  }
}

/* ===== Navigation styles ===== */
.oliven-nav-toggle {
  cursor: pointer;
  text-decoration: none;
}

.oliven-nav-toggle.active i::before,
.oliven-nav-toggle.active i::after {
  background: #fff;
}

.oliven-nav-toggle.dark.active i::before,
.oliven-nav-toggle.dark.active i::after {
  background: #000;
}

.oliven-nav-toggle:hover,
.oliven-nav-toggle:focus,
.oliven-nav-toggle:active {
  outline: none;
  border-bottom: none !important;
}

.oliven-nav-toggle i {
  position: relative;
  display: -moz-inline-stack;
  display: inline-block;
  zoom: 1;
  width: 19px;
  height: 1px;
  color: #fff;
  font: bold 14px/0.4 Helvetica;
  text-transform: uppercase;
  text-indent: -55px;
  background: #fff;
  -webkit-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
  top: -4px;
}

.oliven-nav-toggle i::before,
.oliven-nav-toggle i::after {
  content: '';
  width: 20px;
  height: 1px;
  background: #fff;
  position: absolute;
  left: 0;
  -webkit-transition: 0.2s;
  -o-transition: 0.2s;
  transition: 0.2s;
}

.oliven-nav-toggle.dark i {
  position: relative;
  color: #000;
  background: #000;
  -webkit-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

.oliven-nav-toggle.dark i::before,
.oliven-nav-toggle.dark i::after {
  background: #000;
  -webkit-transition: 0.2s;
  -o-transition: 0.2s;
  transition: 0.2s;
}

.oliven-nav-toggle i::before {
  top: -7px;
}

.oliven-nav-toggle i::after {
  bottom: -7px;
}

.oliven-nav-toggle:hover i::before {
  top: -10px;
}

.oliven-nav-toggle:hover i::after {
  bottom: -10px;
}

.oliven-nav-toggle.active i {
  background: transparent;
}

.oliven-nav-toggle.active i::before {
  top: 0;
  -webkit-transform: rotateZ(45deg);
  -moz-transform: rotateZ(45deg);
  -ms-transform: rotateZ(45deg);
  -o-transform: rotateZ(45deg);
  transform: rotateZ(45deg);
}

.oliven-nav-toggle.active i::after {
  bottom: 0;
  -webkit-transform: rotateZ(-45deg);
  -moz-transform: rotateZ(-45deg);
  -ms-transform: rotateZ(-45deg);
  -o-transform: rotateZ(-45deg);
  transform: rotateZ(-45deg);
}

.oliven-nav-toggle {
  position: fixed;
  left: 0px;
  top: 0px;
  z-index: 9999;
  cursor: pointer;
  opacity: 1;
  visibility: hidden;
  padding: 10px 15px;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
  background: #a9af93;
  margin: 15px 30px;
  border-radius: 50%;
}

@media screen and (max-width: 768px) {
  .oliven-nav-toggle {
    opacity: 1;
    visibility: visible;
  }
}

/* important offcanvason for menu */
body.offcanvason {
  overflow-x: hidden;
}

body.offcanvason .oliven-aside {
  -moz-transform: translateX(0);
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  -o-transform: translateX(0);
  transform: translateX(0);
  width: 270px;
  z-index: 999;
  position: fixed;
}

body.offcanvason .oliven-main,
body.offcanvason .oliven-nav-toggle {
  top: 0;
  -moz-transform: translateX(270px);
  -webkit-transform: translateX(270px);
  -ms-transform: translateX(270px);
  -o-transform: translateX(270px);
  transform: translateX(270px);
}

/* ======= Header style ======= */
.header {
  min-height: 100vh;
  overflow: hidden;
  position: relative;
}

.header .caption .o-hidden {
  display: inline-block;
}

.header .caption h1 {
  font-family: 'Alex Brush', cursive;
  /* font-family: 'Rotherdam Signature', cursive; */
  font-weight: 400;
  margin: 0 0 15px 0;
  font-size: 100px;
  color: #fff;
  display: block;
  line-height: 1em;
  position: relative;
}

/* .header .caption h1 span {
  font-size: 40px;
} */

.header .caption p {
  font-family: 'Cerlions', sans-serif;
  font-size: 25px;
  font-weight: bold;
  letter-spacing: 4px;
  margin-bottom: 0;
  color: #fff;
  text-transform: uppercase;
}

.body-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  background-image: url('../images/background-img.jpg');
  background-size: cover;
  z-index: -1;
  transition: height 0.1s ease-out;
}

.body-bg:after {
  content: '';
  background: #000;
  opacity: 0.3;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 0;
}

.header .container {
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 991px) {
  .header {
    background-position: center center;
  }

  .header .caption h1 {
    font-size: 60px;
  }

  .header .caption h5 {
    font-size: 20px;
  }
}

/* bounce */
.header .arrow {
  position: relative;
  top: 27vh;
  width: 100%;
  text-align: center;
  z-index: 8;
}

.header .arrow.bounce {
  -webkit-animation: bounce 2s infinite;
  animation: bounce 2s infinite;
}

.header .arrow i {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 40px;
  line-height: 40px;
  color: #fff;
  font-size: 20px;
}

.header .arrow i:hover:after {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  opacity: 0;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

/* ===== Title style ===== */
.oliven-title {
  margin-bottom: 0px;
  color: #000;
  font-family: 'Cerlions', serif;
  font-size: 34px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.oliven-title span {
  display: block;
}

.oliven-story-title {
  color: #000;
  font-family: 'Cerlions', serif;
  font-weight: 500;
  font-size: 36px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.oliven-story-title.margin {
  margin-top: 30px;
}

.oliven-story-subtitle {
  display: block;
  position: relative;
  font-family: 'Alex Brush', cursive;
  font-weight: 400;
  font-size: 36px;
  color: #a9af93;
  line-height: 1.25em;
  margin-bottom: 10px;
}

.oliven-couple-title {
  /* font-family: 'Rotherdam Signature', cursive; */
  display: block;
  position: relative;
  font-family: 'Alex Brush', cursive;
  font-weight: 400;
  font-size: 60px;
  color: #a9af93;
  line-height: 1.5em;
  margin-bottom: 5px;
}

/* .oliven-couple-title .capitol {
  font-size: 60px;
}

.oliven-couple-title .normal {
  font-size: 60px;
} */

.oliven-couple-subtitle {
  font-weight: 400;
  font-size: 18px;
  margin-bottom: 0;
}

.oliven-title-meta {
  display: block;
  position: relative;
  font-family: 'Alex Brush', cursive;
  font-weight: 400;
  font-size: 30px;
  color: #a9af93;
  line-height: 1.5em;
  margin-bottom: 10px;
}

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

.map-container .oliven-title-meta {
  font-size: 40px;
  margin-bottom: 20px;
}

.map-container .oliven-couple-subtitle {
  font-size: 17px;
  margin-bottom: 30px;
}

.transport-subtitle {
  font-family: 'Cerlions', serif;
  letter-spacing: 2px;
  font-size: 24px;
  margin-top: 40px;
  margin-bottom: 12px;
}

/* ======= Bride & Groom style ======= */
.bridegroom .item {
  padding: 30px;
  border-radius: 0px;
  background: #fff;
  position: relative;
  overflow: hidden;
}

.bridegroom .img {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  overflow: hidden;
  float: left;
}

.bridegroom .info {
  margin-left: 160px;
}

.bridegroom .info h3 {
  font-family: 'Cerlions', serif;
  font-size: 28px;
  letter-spacing: 1.5px;
  margin-bottom: 5px;
}

.bridegroom .info h3 i {
  color: #a9af93;
  font-size: 16px;
}

.bridegroom .info > div > span {
  color: #a9af93;
  font-size: 30px;
  font-family: 'Alex Brush', cursive;
  margin-bottom: 5px;
}

.bridegroom .info p {
  margin-top: 10px;
}

.bridegroom .info .social {
  margin-top: 10px;
}

.bridegroom .info .social button {
  background-color: transparent;
  border: none;
}

.bridegroom .info .social a {
  color: #888;
  /* text-align: center;
  width: 35px;
  height: 35px;
  line-height: 35px;
  border-radius: 50%;
  border: 1px solid #eee;
  color: #888;
  margin-right: 10px;
  font-size: 12px; */
}

.bridegroom .info .social a:hover {
  color: #a9af93;
}

.bridegroom .toright .img {
  float: right;
}

.bridegroom .toright .info {
  margin-left: 0;
  margin-right: 160px;
  text-align: right;
}

.bridegroom .toright .info .social a {
  margin-right: 0;
  margin-left: 10px;
}

@media screen and (max-width: 991px) {
  .bridegroom .img {
    margin: auto;
    float: none !important;
  }

  .bridegroom .info {
    margin: 30px 0 0 0 !important;
  }

  .bridegroom .item,
  .bridegroom .toright .info {
    text-align: center;
  }
}

/* ======= Wedding Countdown style ======= */
.countdown {
  text-align: center;
  padding: 70px 0;
}

.countdown .section-head {
  margin-bottom: 15px;
  z-index: 1;
}

.countdown .section-head span {
  display: block;
  position: relative;
  font-weight: 400;
  font-size: 18px;
  color: #fff;
  margin-bottom: 0;
}

.countdown .section-head h4 {
  position: relative;
  color: #fff;
  font-family: 'Alex Brush', cursive;
  font-weight: 400;
  font-size: 60px;
  margin-bottom: 0;
}

.countdown .section-head p {
  color: #fff;
  font-size: 24px;
  margin-bottom: 0;
}

.countdown ul {
  margin-bottom: 0;
  padding: 0;
}

.countdown li {
  font-family: 'Cerlions', serif;
  font-weight: 400;
  display: inline-block;
  font-size: 20px;
  font-weight: bold;
  list-style-type: none;
  padding: 15px 20px;
  color: #fff;
  line-height: 2.5em;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.countdown li span {
  display: block;
  font-size: 60px;
}

@media all and (max-width: 768px) {
  .countdown li {
    font-size: 12px;
    padding: 15px;
  }

  .countdown li span {
    font-size: 60px;
  }
}

/* ======= Our Story style ======= */
.story .story-img {
  position: relative;
}

.story .story-img .img {
  padding: 0 30px 30px 15px;
  position: relative;
}

.story .story-img .img:before {
  content: '';
  position: absolute;
  top: 30px;
  right: 0;
  left: 45px;
  bottom: 0;
  border: 10px solid #ae959b;
}

.story .story-img .img img {
  position: relative;
  z-index: 2;
}

.story .story-img:after {
  content: '';
  width: 90%;
  position: absolute;
  top: -5%;
  bottom: -5%;
  left: 0;
  background-image: url(../images/dots.png);
  background-repeat: repeat;
  z-index: -1;
}

@media (min-width: 768px) {
  .story .story-img:after {
    top: -15%;
    bottom: -15%;
  }
}

.story-img-2 {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
}

.story-img .story-img-2 {
  width: 30% !important;
  height: 120px;
  position: absolute;
  top: 15px;
  right: 45px;
  z-index: 3;
}

/* story-wedding */

.story-wedding {
  -webkit-animation: rotation 12s infinite linear;
}

@-webkit-keyframes rotation {
  from {
    -webkit-transform: rotate(0deg);
  }

  to {
    -webkit-transform: rotate(359deg);
  }
}

@media screen and (max-width: 991px) {
  .story-img .story-img-2 {
    width: 30% !important;
    height: 135px;
    position: absolute;
    top: 40px;
    right: 45px;
  }
}

@media screen and (max-width: 768px) {
  .story-img .story-img-2 {
    width: 40% !important;
    height: 120px;
    position: absolute;
    top: 15px;
    right: 45px;
  }
}

/* ======= Schedule ======= */

.bg-white {
  background-color: #fff;
}

.schedule {
  padding-bottom: 50px;
}

.schedule .oliven-story-title {
  margin-bottom: 30px;
}

.schedule p {
  font-size: 17px;
  margin-bottom: 20px;
}

.schedule p i {
  color: #ae959b;
  font-size: 20px;
}

.link-button {
  font-family: 'Nunito Sans', sans-serif;
  background: #a9af93;
  border: 1px solid #a9af93;
  color: #fff;
  padding: 15px 25px;
  margin: 0;
  position: relative;
  font-size: 12px;
  line-height: 1em;
  text-transform: uppercase;
  letter-spacing: 2px;
  border-radius: 0px;
}

.link-button:hover,
.details-button:hover {
  background-color: transparent;
  color: #000;
}

@media screen and (max-width: 400px) {
  .link-button {
    padding: 15px 10px;
  }
}

.details-button {
  font-family: 'Nunito Sans', sans-serif;
  background: #a9af93;
  border: 1px solid #a9af93;
  color: #fff;
  padding: 15px 25px;
  margin: 20px 0 0;
  position: relative;
  font-size: 12px;
  line-height: 1em;
  text-transform: uppercase;
  border-radius: 0px;
}

@media screen and (max-width: 768px) {
  .details-button {
    padding: 15px 10px;
  }
}

#details-content {
  font-weight: bold;
}

.hide-details {
  display: none;
}

/* =====  Gallery style  ===== */
.gallery-menu li a {
  cursor: pointer;
  display: block;
  color: #888;
  margin-bottom: 5px;
  padding: 5px 15px;
  transition: all 0.5s;
  margin-top: 5px;
}

.gallery-menu a.active,
.gallery-menu a:hover {
  color: #fff;
  background-color: #a9af93;
}

.gallery-item {
  position: relative;
  padding: 15px;
}

.gallery-box {
  overflow: hidden;
  position: relative;
}

.gallery-box .gallery-img {
  position: relative;
  overflow: hidden;
  border-radius: 0;
}

.gallery-box .gallery-img:after {
  content: ' ';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 0;
  transition: all 0.27s cubic-bezier(0.3, 0.1, 0.58, 1);
}

.gallery-box .gallery-img > img {
  transition: all 0.3s cubic-bezier(0.3, 0.1, 0.58, 1);
  border-radius: 0;
}

.gallery-box .gallery-detail {
  opacity: 0;
  color: #fff;
  width: 100%;
  padding: 20px;
  box-sizing: border-box;
  position: absolute;
  left: 0;
  overflow: hidden;
  transition: all 0.27s cubic-bezier(0.3, 0.1, 0.58, 1);
  text-align: center;
}

.gallery-box .gallery-detail h4 {
  font-family: 'Alex Brush', cursive;
  font-weight: 400;
  font-size: 24px;
  color: #fff;
}

.gallery-box .gallery-detail p {
  color: #fff;
}

.gallery-box:hover .gallery-detail {
  top: 50%;
  transform: translate(0, -50%);
  opacity: 1;
}

.gallery-box:hover .gallery-img:after {
  background: rgba(0, 0, 0, 0.4);
}

.gallery-box:hover .gallery-img > img {
  transform: scale(1.05);
}

.trip-link {
  padding: 8px 0;
}

.trip-link:hover {
  color: #a9af93;
}

.trip-link i {
  top: 2px;
  position: relative;
  font-size: 24px;
}

.grecaptcha-badge {
  display: none !important;
}

/* =====  Button style  ===== */
.btn {
  padding: 0;
}

.buttono {
  position: relative;
  line-height: 1em;
  border: none;
}

.buttono a {
  background: #a9af93;
  border: 1px solid #a9af93;
  color: #fff;
  padding: 10px 20px;
  margin: 0;
  font-weight: 500;
  position: relative;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.buttono a:after {
  content: '';
  width: 0;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 100%;
  z-index: 1;
  background: #fff;
  color: #000;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.buttono a span {
  position: relative;
  z-index: 2;
}

.buttono a:hover:after {
  width: 100%;
  left: 0;
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}

.buttono a:hover,
.buttono a:hover span {
  color: #000;
}

input.mt-20 {
  margin-top: 20px;
}

/* ===== Footer style ===== */
.footer2 {
  padding: 70px 30px;
  background: #f7f3f0;
}

.footer2 img {
  width: 90px;
  margin-bottom: 10px;
}

.footer2 h2,
.footer2 h2 a {
  font-size: 36px;
  font-weight: 500;
  display: block;
  width: 100%;
  position: relative;
  color: #000;
  line-height: 1em;
  letter-spacing: 0px;
  margin-bottom: 0;
}

.footer2 h2 a span,
.footer2 h2 span {
  display: block;
  font-family: 'Alex Brush', cursive;
  font-weight: 400;
  color: #a9af93;
}

.footer2 h2 a i {
  color: #000;
  font-size: 16px;
  vertical-align: super;
}

.footer2 h6 {
  color: #888;
  margin-bottom: 0;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 14px;
}

.footer2 .copyright {
  margin: 0;
  font-style: italic;
  color: #888;
}

@media screen and (max-width: 768px) {
  .footer2 {
    padding: 100px 30px 80px 30px;
    text-align: center;
  }
}

/* ==== Preloader ==== */
.preloader {
  width: 100%;
  height: 100%;
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Heart */
.lds-heart {
  display: inline-block;
  position: relative;
  width: 64px;
  height: 64px;
  transform: rotate(45deg);
  transform-origin: 32px 32px;
}

.lds-heart div {
  top: 23px;
  left: 19px;
  position: absolute;
  width: 26px;
  height: 26px;
  background: #a9af93;
  animation: lds-heart 1.2s infinite cubic-bezier(0.215, 0.61, 0.355, 1);
}

.lds-heart div:after,
.lds-heart div:before {
  content: ' ';
  position: absolute;
  display: block;
  width: 26px;
  height: 26px;
  background: #a9af93;
}

.lds-heart div:before {
  left: -17px;
  border-radius: 50% 0 0 50%;
}

.lds-heart div:after {
  top: -17px;
  border-radius: 50% 50% 0 0;
}

.accordion-box {
  margin: 50px 0;
  position: relative;
  padding-left: 0;
}

.accordion-box .block {
  position: relative;
  background: #f7f3f0;
  border-radius: 0px;
  overflow: hidden;
  margin-bottom: 15px;
}

.accordion-box .block:last-child {
  margin-bottom: 0;
}

.accordion-box .block .acc-btn {
  position: relative;
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
  cursor: pointer;
  padding: 20px 40px;
  padding-right: 60px;
  color: #000;
  transition: all 500ms ease;
}

.accordion-box .block .acc-btn .count {
  color: #000;
  padding-right: 3px;
}

.accordion-box .block .acc-btn:before {
  position: absolute;
  right: 35px;
  top: 20px;
  height: 30px;
  font-size: 14px;
  font-weight: normal;
  color: #000;
  line-height: 27px;
  content: '\e61a';
  font-family: 'Themify';
  transition: all 500ms ease;
}

.accordion-box .block .acc-btn.active:before {
  color: 'Themify';
  content: '\e622';
}

.accordion-box .block .acc-content {
  position: relative;
  display: none;
}

.accordion-box .block .content {
  position: relative;
  padding: 20px 40px;
  background-color: #fff;
  color: #000;
}

.accordion-box .block .acc-content.current {
  display: block;
}

.accordion-box .block .content .text {
  display: block;
  position: relative;
  top: 0px;
  display: block;
}

@keyframes lds-heart {
  0% {
    transform: scale(0.95);
  }

  5% {
    transform: scale(1.1);
  }

  39% {
    transform: scale(0.85);
  }

  45% {
    transform: scale(1);
  }

  60% {
    transform: scale(0.95);
  }

  100% {
    transform: scale(0.9);
  }
}

/* ==== Media Query ==== */
@media screen and (max-width: 991px) {
  .container {
    padding-right: 30px;
    padding-left: 30px;
  }

  .oliven-couple-title {
    font-size: 45px;
    line-height: 1.2em;
    margin-bottom: 15px;
  }

  .oliven-couple-subtitle {
    font-size: 18px;
  }

  .countdown .section-head h4 {
    font-size: 32px;
    line-height: 1em;
  }

  .seeyou .section-head h4 {
    font-size: 32px;
    margin-bottom: 5px;
    line-height: 1em;
  }

  .seeyou .section-head h3 {
    font-size: 32px;
  }

  .form-container {
    padding: 30px;
  }

  .p-40 {
    padding: 20px;
    margin: 0 15px;
  }
}

@media (max-width: 992px) {
  .bg-fixed {
    background-attachment: scroll !important;
  }
}
