@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/**
 *  clearfixc For modern browsers
 */
.cf:before,
.cf:after {
  content: "";
  display: table;
}

.cf:after {
  clear: both;
}

/**
 * For IE 6/7 (trigger hasLayout)
 */
.cf {
  *zoom: 1;
}

.first {
  margin-left: 0px !important;
}

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

.bold-text {
  font-family: "geo-b";
}

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

.clear {
  clear: both;
}

.hidden {
  display: none;
}

strong,
b {
  font-family: "ga_b";
}

/*** FONT FACE ***/
@font-face {
  font-family: "ga";
  src: url("ga.eot");
  src: url("ga.eot?#iefix") format("embedded-opentype"), url("ga.woff2") format("woff2"), url("ga.woff") format("woff"), url("ga.ttf") format("truetype"), url("ga.svg#ga") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "ga_b";
  src: url("ga_b.eot");
  src: url("ga_b.eot?#iefix") format("embedded-opentype"), url("ga_b.woff2") format("woff2"), url("ga_b.woff") format("woff"), url("ga_b.ttf") format("truetype"), url("ga_b.svg#ga_b") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "gi";
  src: url("gi.eot");
  src: url("gi.eot?#iefix") format("embedded-opentype"), url("gi.woff2") format("woff2"), url("gi.woff") format("woff"), url("gi.ttf") format("truetype"), url("gi.svg#gi") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "gi_l";
  src: url("gi_l.eot");
  src: url("gi_l.eot?#iefix") format("embedded-opentype"), url("gi_l.woff2") format("woff2"), url("gi_l.woff") format("woff"), url("gi_l.ttf") format("truetype"), url("gi_l.svg#gi_l") format("svg");
  font-weight: normal;
  font-style: normal;
}
html,
body {
  padding: 0;
  margin: 0;
}

body {
  -webkit-font-smoothing: antialiased;
  font-family: "ga", sans-serif;
  color: #585858;
}

@media only screen and (min-width: 1024px) {
  body {
    font-size: 100%;
  }
}
@media only screen and (min-width: 640px) and (max-width: 1024px) {
  body {
    font-size: 90%;
  }
}
@media only screen and (max-width: 640px) {
  body {
    font-size: 80%;
  }
}
/*
body{
	font-size: 60%;
}
*/
/*** STANDARDS ***/
div#site-wrapper {
  margin-top: 90px;
}

div.pagesection {
  width: 95%;
  padding-top: 80px;
  padding-bottom: 80px;
  padding-left: 2.5%;
  padding-right: 2.5%;
  background-size: cover;
  background-attachment: fixed;
  background-position: center center;
}

div.pagesection.mid-pad {
  padding-top: 60px;
  padding-bottom: 60px;
}

div.pagesection.big-pad {
  padding-top: 120px;
  padding-bottom: 120px;
}

div.pagesection.no-bot-pad {
  padding-bottom: 0px;
}

div.pagesection.no-pad {
  padding-top: 0px;
  padding-bottom: 0px;
}

div.content {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
}

div.content > img.fw {
  margin-top: 2rem;
}

div.content.filter {
  max-width: 1520px;
}

div.pagesection h1 {
  font-family: "ga";
  text-align: center;
  text-transform: uppercase;
  font-size: 1.375em;
  color: #767676;
  line-height: 120%;
}

div.pagesection h1.align-left {
  text-align: left;
}

div.pagesection h1.big {
  font-family: "gi_l" !important;
  text-transform: none;
  font-size: 2.1875rem;
  color: #585858;
}

div.text-container {
  width: 80%;
  max-width: 800px;
  margin: 28px auto 0px;
  text-align: center;
  font-size: 1.375em;
  line-height: 140%;
}

div.text-container.sm {
  max-width: 550px;
  margin-top: 10px;
}

div.text-container a {
  color: #b18d4e;
  text-decoration: none;
}

div.text-container a:hover {
  text-decoration: underline;
}

.stop-scrolling {
  height: 100%;
  overflow: hidden;
}

div.link-wrapper-center {
  text-align: center;
}

a.cta {
  font-family: "geo-m";
  text-align: center;
  margin: 50px 20px 0px;
  background: #f38181;
  color: #fff;
  display: inline-block;
  padding: 19px 30px;
  border-radius: 500px;
  font-size: 1.625em;
  text-decoration: none;
  text-transform: uppercase;
  transition: all 0.25s ease-in-out;
  -moz-transition: all 0.25s ease-in-out;
  -webkit-transition: all 0.25s ease-in-out;
}

a.cta:hover {
  background: #fff;
  color: #f38181;
}

img.fw {
  display: block;
  width: 100%;
}

@media only screen and (min-width: 640px) and (max-width: 1024px) {
  div#site-wrapper {
    margin-top: 60px;
  }
  div.pagesection {
    width: 92%;
    padding: 6% 4%;
    background-attachment: scroll;
  }
  div.text-container {
    width: 100%;
    margin: 40px auto 0px auto;
  }
}
@media only screen and (max-width: 640px) {
  div#site-wrapper {
    margin-top: 60px;
  }
  div.pagesection {
    width: 90%;
    padding: 10% 5%;
    background-attachment: scroll;
  }
  div.text-container {
    width: 100%;
    margin: 30px auto 0px auto;
    font-size: 1.5em;
  }
  a.cta {
    margin: 40px 5px 0px;
    padding: 15px 20px;
    font-size: 1.375em;
  }
}
/*** Layout ***/
div.wrapped-flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.flex-2,
.flex-3,
.flex-4 {
  flex-grow: 0;
  flex-shrink: 0;
}

.flex-2 {
  /*width: 48%;*/
  flex-basis: 48%;
  margin-top: 4%;
}

.flex-3 {
  /*width: 31%;*/
  flex-basis: 31%;
  margin-top: 3.5%;
}

.flex-4 {
  /*width: 22%;*/
  flex-basis: 22%;
  margin-top: 4%;
}

@media only screen and (min-width: 720px) and (max-width: 1024px) {
  .flex-4 {
    /*width: 31%;*/
    flex-basis: 31%;
    margin-top: 3.5%;
  }
}
@media only screen and (min-width: 640px) and (max-width: 720px) {
  .flex-3,
  .flex-4 {
    /*width: 48%;*/
    flex-basis: 48%;
    margin-top: 4%;
  }
}
@media only screen and (max-width: 640px) {
  .flex-2,
  .flex-3 {
    /*width: 100%;*/
    flex-basis: 100%;
    margin-top: 4%;
  }
  .flex-4 {
    /*width: 47%;*/
    flex-basis: 47%;
    margin-top: 4%;
  }
}
/*** Underlines **/
.underline {
  position: relative;
  padding-bottom: 8px;
}

.underline:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 80px;
  border-bottom: 1px solid #dac39a;
}

hr {
  border-color: #dac39a;
}

/*** Colors ***/
div.pagesection.white {
  background-color: #ffffff;
}

div.pagesection.gray {
  background-color: #fafafa;
}

.gray {
  color: #404040;
}

.light {
  color: #ffffff !important;
}

.light h1 {
  color: #ffffff !important;
}

/****** LADNING PAGE ******/
/*** TOP BAR ***/
div#topbar {
  width: 100%;
  position: fixed;
  top: 0px;
  left: 0px;
  z-index: 500;
  background-color: #fff;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  border-bottom: 1px solid #dac39a;
  /*opacity: 0;*/
  /*
  	-webkit-box-shadow: rgba(100, 100, 100, 0.2) 0px 0px 4px 0px;
  	-moz-box-shadow: rgba(100, 100, 100, 0.2) 0px 0px 4px 0px;
  	box-shadow: rgba(100, 100, 100, 0.2) 0px 0px 4px 0px;
  	*/
}

div#header {
  position: relative;
  width: 94%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 30px 3%;
}

.button_container {
  display: none;
  position: fixed;
  top: 6px;
  right: 0px;
  padding: 10px 16px 16px;
  /*top: 16px;
  left: 16%3%;*/
  height: 27px;
  width: 35px;
  cursor: pointer;
  z-index: 1500;
  -webkit-transition: opacity 0.25s ease;
  transition: opacity 0.25s ease;
}

.button_container:hover {
  opacity: 0.7;
}

.button_container.active .top {
  -webkit-transform: translateY(7px) translateX(0) rotate(45deg);
  -ms-transform: translateY(7px) translateX(0) rotate(45deg);
  transform: translateY(7px) translateX(0) rotate(45deg);
  background: #444;
}

.button_container.active .middle {
  opacity: 0;
  background: #444;
}

.button_container.active .bottom {
  /*-webkit-transform: translateY(-11px) translateX(0) rotate(-45deg);*/
  -webkit-transform: translateY(-7px) translateX(0) rotate(-45deg);
  -ms-transform: translateY(-7px) translateX(0) rotate(-45deg);
  transform: translateY(-7px) translateX(0) rotate(-45deg);
  background: #444;
}

.button_container span {
  background: #444;
  border: none;
  height: 2px;
  width: 24px;
  position: absolute;
  top: 16px;
  margin-left: 3%;
  margin-right: 3%;
  -webkit-transition: all 0.35s ease;
  transition: all 0.35s ease;
  cursor: pointer;
}

.button_container span:nth-of-type(2) {
  /*top: 27px;*/
  top: 23px;
}

.button_container span:nth-of-type(3) {
  /*top: 38px;*/
  top: 30px;
}

.overlay {
  position: fixed;
  background: #fff;
  /*background: #DAC39A;*/
  top: 0;
  left: 0;
  width: 100%;
  height: 0%;
  opacity: 0;
  visibility: hidden;
  display: none;
  -webkit-transition: opacity 0.35s, visibility 0.35s, height 0.35s;
  transition: opacity 0.35s, visibility 0.35s, height 0.35s;
  overflow: hidden;
}

.overlay.open {
  opacity: 1;
  visibility: visible;
  height: 100%;
  z-index: 1000;
}

.overlay.open li {
  -webkit-animation: fadeInLeft 0.5s ease forwards;
  animation: fadeInLeft 0.5s ease forwards;
  -webkit-animation-delay: 0.3s;
  animation-delay: 0.3s;
}

.overlay.open li:nth-of-type(2) {
  -webkit-animation-delay: 0.4s;
  animation-delay: 0.4s;
}

.overlay.open li:nth-of-type(3) {
  -webkit-animation-delay: 0.5s;
  animation-delay: 0.5s;
}

.overlay.open li:nth-of-type(4) {
  -webkit-animation-delay: 0.6s;
  animation-delay: 0.6s;
}

.overlay.open li:nth-of-type(5) {
  -webkit-animation-delay: 0.7s;
  animation-delay: 0.7s;
}

.overlay.open li:nth-of-type(6) {
  -webkit-animation-delay: 0.8s;
  animation-delay: 0.8s;
}

.overlay.open li:nth-of-type(7) {
  -webkit-animation-delay: 0.9s;
  animation-delay: 0.9s;
}

.overlay.open li:nth-of-type(8) {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
}

.overlay nav {
  position: relative;
  height: 70%;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 30px;
  text-align: center;
}

.overlay ul {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  display: inline-block;
  position: relative;
  height: 100%;
}

.overlay ul li {
  display: block;
  height: 16%;
  height: 14.2857142857%;
  min-height: 40px;
  /*text-transform: uppercase;*/
  position: relative;
  opacity: 0;
}

.overlay ul li a {
  display: block;
  position: relative;
  color: #767676;
  /*color: rgb(148, 123, 80);*/
  text-decoration: none;
  font-family: "ga";
  /*overflow: hidden;*/
}

.overlay ul li.current a {
  color: #b18d4e;
}

.overlay ul li a:hover:after,
.overlay ul li a:focus:after,
.overlay ul li a:active:after {
  width: 100%;
}

/*
.overlay ul li a:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  height: 3px;
  background: #FFF;
  -webkit-transition: .35s;
          transition: .35s;
}*/
@-webkit-keyframes fadeInLeft {
  0% {
    opacity: 0;
    left: -20%;
  }
  100% {
    opacity: 1;
    left: 0;
  }
}
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    left: -20%;
  }
  100% {
    opacity: 1;
    left: 0;
  }
}
div#logo-container {
  width: 242px;
  height: 30px;
  position: relative;
  float: left;
}

div#logo-container img {
  width: 100%;
  display: block;
}

ul#menu {
  float: right;
  margin-top: 13px;
}

ul#menu li {
  display: inline;
  list-style-type: none;
  margin-right: 8px;
  color: #fff;
}

ul#menu li a {
  font-family: "gi_l";
  color: #767676;
  font-size: 16px;
  letter-spacing: 0.5px;
  text-decoration: none;
  padding: 7px 9px;
}

ul#menu li.current a {
  color: #292929;
}

@media only screen and (max-width: 1024px) {
  /*
  div#topbar
  {
  	background-color: #fff !important;
    	-webkit-box-shadow: rgba(100, 100, 100, 0.5) 0px 0px 10px 0px !important;
    	-moz-box-shadow: rgba(100, 100, 100, 0.5) 0px 0px 10px 0px !important;
    	box-shadow: rgba(100, 100, 100, 0.5) 0px 0px 10px 0px !important;
  		top: 0px !important;
  }
  */
  div#header {
    height: 40px !important;
    padding: 10px 3% !important;
  }
  .button_container {
    display: block;
  }
  div#overlay {
    display: block;
  }
  div#logo-container {
    width: 150px;
    height: 19px;
    position: absolute;
    left: 16px;
    top: 20px;
  }
  ul#menu {
    display: none;
  }
}
@media only screen and (max-width: 640px) {
  div#logo-container {
    left: 5%;
  }
}
/*** Frontpage ***/
/* Slider */
.hero-slide {
  position: relative;
  width: 100%;
  /*padding-top: 50%;*/
  aspect-ratio: 2/1;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  background-color: rgba(218, 195, 154, 0.15);
}

.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  opacity: 1;
}

.slick-dots li button:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 20px;
  position: absolute;
  top: 10px;
  left: 0;
  width: 20px;
  height: 20px;
  content: "•";
  text-align: center;
  opacity: 0.25;
  color: black;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
  opacity: 0.75;
  color: black;
}

@media only screen and (max-width: 640px) {
  .hero-slide {
    aspect-ratio: 3/2;
  }
  .slick-dots {
    bottom: -35px;
  }
  .slick-dots li {
    width: 30px;
    height: 30px;
    margin: 0 5px;
  }
  .slick-dots li button {
    width: 30px;
    height: 30px;
    padding: 5px;
  }
  .slick-dots li button:before {
    font-size: 30px;
    line-height: 30px;
    width: 30px;
    height: 30px;
  }
}
/* News */
div.news-item div.img {
  display: block;
  width: 100%;
  padding-top: 130%;
  background-size: cover;
  background-position: center center;
}

div.news-item div.img.top {
  background-position-y: top;
}

div.news-item div.img.bottom {
  background-position-y: bottom;
}

div.news-item div.img.center {
  background-position-y: center;
}

div.news-item div.title {
  margin-top: 24px;
  font-family: "gi_l";
  font-size: 1.75em;
  color: #767676;
  line-height: 100%;
}

div.news-item div.text {
  margin-top: 10px;
  font-size: 1.125em;
  color: #767676;
  line-height: 140%;
}

div.news-item a {
  color: #b18d4e;
}

@media only screen and (max-width: 640px) {
  div.news-item div.title {
    margin-top: 16px;
  }
  div.news-item div.text {
    margin-bottom: 20px;
    font-size: 1.25em;
    line-height: 140%;
  }
}
/* Collections */
a.collection-item {
  display: block;
  position: relative;
  padding-top: 56%;
  background-size: cover;
  background-position: center center;
}

.collection-item.collection-item-bridal {
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 50%, rgb(255, 255, 255) 91%), url(../img/collection_brud_2026.jpg);
}

.collection-item.collection-item-party {
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 50%, rgb(255, 255, 255) 91%), url(../img/collection_fest_2026.jpg);
}

.collection-item.collection-item-accessories {
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 50%, rgb(255, 255, 255) 91%), url(../img/collection_accessoarer_2024.jpg);
}

div.collection-info {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 100px 0 15px;
  /* display: flex; */
  /* flex-direction: column; */
  color: #585858;
  text-align: center;
  text-transform: uppercase;
  /* background: linear-gradient(180deg, transparent, white); */
  /*background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 82%);*/
}

div.collection-info div.title {
  font-size: 2.625em;
  letter-spacing: 3px;
  line-height: 115%;
  text-shadow: 0px 0px 8px white;
}

div.collection-info div.text {
  font-family: "gi";
  font-size: 1.375em;
  line-height: 115%;
}

@media only screen and (max-width: 720px) {
  div.collection-info div.title {
    font-size: 2.375em;
  }
}
@media only screen and (max-width: 640px) {
  a.collection-item {
    padding-top: 70%;
  }
  .collection-item.collection-item-bridal {
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 40%, rgb(255, 255, 255) 80%), url(../img/collection_brud_2026.jpg);
  }
  .collection-item.collection-item-party {
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 40%, rgb(255, 255, 255) 80%), url(../img/collection_fest_2026.jpg);
  }
  .collection-item.collection-item-accessories {
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 40%, rgb(255, 255, 255) 80%), url(../img/collection_accessoarer_2024.jpg);
    background-size: 100%;
    background-position: center 20%;
  }
  a.collection-item.top-bg {
    background-position: center 10%;
  }
}
/* Book now */
a#book-now-btn {
  display: inline-block;
  padding: 20px 60px;
  margin-top: 48px;
  font-family: "gi_l";
  font-size: 1.625em;
  color: #585858;
  line-height: 100%;
  text-decoration: none;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.4);
  border: 2px solid #dac39a;
  border-radius: 100px;
}

a#book-now-btn:hover {
  background: rgba(255, 255, 255, 0.6);
  color: #dac39a;
}

/** Before visit **/
.before-visit-wrapper {
  display: flex;
  flex-direction: row;
  gap: 2rem;
  margin-top: 2.5rem;
}

.before-visit-img {
  width: 42%;
  margin-top: 1.5rem;
}

.before-visit-text.text-container {
  flex: 1;
  max-width: unset;
  width: 100%;
  margin: 0;
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  text-align: left;
}

@media only screen and (max-width: 720px) {
  .before-visit-wrapper {
    gap: 0;
  }
  .before-visit-wrapper:nth-of-type(odd) {
    flex-direction: column-reverse;
  }
  .before-visit-wrapper:nth-of-type(even) {
    flex-direction: column;
  }
  .before-visit-img {
    width: 100%;
    margin-top: 1rem;
  }
  .before-visit-text.text-container {
    margin-top: 0rem;
  }
}
/*** Collection - gallery ***/
a.store-link {
  display: inline-block;
  text-decoration: none;
}

/*a.store-link h1 { color: #DAC39A; }*/
a.store-link:hover {
  color: #dac39a;
  text-decoration: underline;
}

div.gallery-wrapper.wrapped-flex {
  margin-top: 60px;
  /*align-items: center;*/
  justify-content: center;
  flex-flow: row wrap;
}

.gallery-item {
  display: block;
  text-decoration: none;
}

.gallery-item .bridal {
  display: block;
  padding-top: 150%;
  background-position: top center;
  background-size: cover;
  background-color: rgba(218, 195, 154, 0.15);
}

.gallery-item img {
  transition: all 0.25s ease-in-out;
  -moz-transition: all 0.25s ease-in-out;
  -webkit-transition: all 0.25s ease-in-out;
}

a.gallery-item:hover img .gallery-item a.bridal:hover {
  opacity: 0.85;
}

.gallery-item.flex-4 {
  margin: 3% 1.5% 1.5%;
}

.gallery-item div.dress-name {
  margin-top: 5px;
  font-family: "gi_l";
  font-size: 1.75em;
  color: #767676;
  line-height: 120%;
}

div#filter-wrapper {
  display: flex;
  margin-top: 60px;
}

div#filter-bar {
  flex: 0 0 240px;
}

div.filter-group-wrapper {
  display: flex;
  flex-direction: column;
}

div.filter-group {
  margin-top: 20px;
}

div.filter-group div.title {
  font-size: 1.25em;
}

div.filter-group div.checkbox-wrapper {
  font-size: 1.125em;
  margin-top: 8px;
}

input#filter-btn {
  display: inline-block;
  margin-top: 20px;
  padding: 10px 15px;
  background: rgba(218, 195, 154, 0.76);
  font-family: "gi";
  font-size: 16px;
  text-transform: uppercase;
  color: #ffffff;
  text-decoration: none;
  border: none;
  outline: none;
}

input#filter-btn:hover {
  background: rgba(218, 195, 154, 0.96);
}

div.gallery-wrapper.wrapped-flex.filter {
  margin-top: 0px;
  justify-content: flex-start;
}

div#customer_message {
  width: 80%;
  max-width: 800px;
  margin: 32px auto 0px;
  text-align: center;
  font-size: 1.25em;
  font-family: "gi_l";
  line-height: 1.4;
}

div#customer_message a {
  font-weight: bold;
  color: #dac39a;
  text-decoration: none;
}

@media only screen and (max-width: 1024px) {
  div#filter-wrapper {
    flex-direction: column;
  }
  div#filter-bar {
    flex: 1;
    margin-bottom: 6%;
  }
  div.filter-group-wrapper {
    flex-direction: row;
  }
  div.filter-group:first-of-type {
    margin-right: 40px;
  }
}
@media only screen and (min-width: 720px) and (max-width: 1024px) {
  a.gallery-item.flex-4 {
    margin: 1.25%;
    margin: 2.5 1.25% 1.25%;
  }
}
@media only screen and (min-width: 640px) and (max-width: 720px) {
  a.gallery-item.flex-4 {
    margin: 1%;
    margin: 2% 1% 1%;
  }
}
/*** Single - dress ***/
div#dress-wrapper {
  /*
  display: flex;
  justify-content: space-between;
  */
  display: grid;
  column-gap: 30px;
  /* grid-auto-flow: row; */
}

div#dress > div.content > div:has(> :nth-child(2):last-child) {
  grid-template-columns: 65fr 35fr;
  grid-template-areas: "image info";
}

div#dress > div.content > div:has(> :nth-child(3):last-child) {
  grid-template-columns: 125px 65fr 35fr;
  grid-template-areas: "thumbnails image info";
}

div#dress-images {
  /*flex: 0 0 65%;*/
  grid-area: image;
}

div#thumbnail-wrapper {
  grid-area: thumbnails;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

div#thumbnail-wrapper a.thumbnail-link {
  display: block;
  /*flex: 0 0 125px;*/
  width: 125px;
  margin: 30px 0 0 0;
  opacity: 0.7;
  transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -webkit-transition: all 0.2s ease-in-out;
}

div#thumbnail-wrapper a.thumbnail-link.active-thumbnail {
  opacity: 1;
}

div#thumbnail-wrapper > a:first-of-type {
  margin-top: 0;
}

/*
div#dress-images div#thumbnail-wrapper a.thumbnail-link img {
  transition: all 0.25s ease-in-out;
  -moz-transition: all 0.25s ease-in-out;
	-webkit-transition: all 0.25s ease-in-out;
}
*/
/*
div#dress-images div#thumbnail-wrapper a.thumbnail-link:hover img {
  opacity: 0.85;
}
*/
div#dress-info {
  /*flex: 0 0 32%;*/
  grid-area: info;
}

div#dress-info div.name {
  /* Rani: */
  font-family: "gi_l";
  font-size: 2.25em;
  color: #767676;
  line-height: 100%;
}

div#dress-info div.brand {
  margin-top: 12px;
  font-size: 1.625em;
  text-transform: uppercase;
}

div#dress-info div.brand a {
  color: #dac39a;
  text-decoration: none;
}

div#dress-info div.brand a:hover {
  text-decoration: underline;
}

div#dress-info div.type {
  margin-top: 32px;
  font-size: 1.625em;
  font-family: "gi_l";
  color: #767676;
  line-height: 140%;
}

div#dress-info div.store {
  margin-top: 0px;
  font-family: "gi_l";
  font-style: italic;
  font-size: 1.625em;
  color: #767676;
  line-height: 140%;
}

div#dress-info div.store.top-margin {
  margin-top: 14px;
}

div#customer_message_single {
  margin-top: 24px;
  font-size: 1.375em;
  line-height: 140%;
  color: #767676;
  font-family: "gi_l";
}

div#dress-info div.book-fitting {
  margin-top: 50px;
  /* Vill du veta mer? Bo: */
  font-family: "gi";
  font-size: 1.5em;
  line-height: 130%;
  color: #dac39a;
}

div#dress-info div.book-fitting a {
  color: #dac39a;
}

@media only screen and (max-width: 1024px) {
  div#dress-wrapper {
    /*flex-direction: column;*/
    grid-template-columns: 1fr;
    /* grid-auto-flow: row; */
    grid-template-areas: "image" "thumbnails" "info";
  }
  div#dress > div.content > div:has(> :nth-child(2):last-child) {
    grid-template-columns: 1fr;
    grid-template-areas: "image" "info";
  }
  div#dress > div.content > div:has(> :nth-child(3):last-child) {
    grid-template-columns: 1fr;
    grid-template-areas: "image" "thumbnails" "info";
  }
  div#dress-images,
  div#dress-info {
    flex-basis: 100%;
  }
  div#dress-images {
    /*margin-bottom: 5%;*/
  }
  div#thumbnail-wrapper {
    /*
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    */
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    column-gap: 2rem;
  }
  div#thumbnail-wrapper a.thumbnail-link {
    width: 100%;
    margin-right: 0;
    margin-top: 2rem;
    /*
    display: flex;
    flex: 0 0 25%;
    margin-top: 2rem;
    gap: 2rem;
    */
  }
  div#dress-info {
    margin-top: 3rem;
  }
}
@media only screen and (max-width: 720px) {
  div#thumbnail-wrapper {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 1.25rem;
  }
  div#thumbnail-wrapper a.thumbnail-link {
    margin-right: 0;
    margin-top: 1.25rem;
  }
  div#dress-info {
    margin-top: 2rem;
  }
}
@media only screen and (max-width: 480px) {
  /*
  div#dress.pagesection {
    padding-top: 0;
  }
  */
  div#dress-images {
    /*
    width: 118%;
    margin-left: -8%;
    */
  }
  div#thumbnail-wrapper {
    /*
    width: 118%;
    margin-left: -8%;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 0;
    */
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 1rem;
  }
  div#thumbnail-wrapper a.thumbnail-link {
    margin-top: 0;
    margin-right: 0;
    margin-top: 1rem;
  }
  div#dress-info {
    margin-top: 1.75rem;
  }
}
/*** Tailoring ***/
/* General video container setup */
.video-container {
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* Make video responsive */
.responsive-video {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Crop the video on mobile */
@media (max-width: 1024px) {
  .responsive-video {
    height: 70vw; /* 5:4 aspect ratio */
    /*height: 80vw; /* 5:4 aspect ratio */
    object-fit: cover;
  }
}
/*** Couples ***/
.masonry-sizer,
.masonry-item {
  width: 31%;
}

.masonry-gutter {
  width: 3.5%;
}

#accessories-masonry .masonry-sizer,
#accessories-masonry .masonry-item {
  width: 22%;
}

#accessories-masonry .masonry-gutter {
  width: 4%;
}

div.masonry-item {
  background: #fff;
  margin-top: 4%;
  /*
   box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.05);

   transition: opacity 0.5s ease-in-out;
   -moz-transition: opacity 0.5s ease-in-out;
   -webkit-transition: opacity 0.5s ease-in-out;

  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
  */
}

div.masonry-item img {
  display: block;
  width: 100%;
}

div.masonry-item div.info {
  width: 90%;
  padding: 6% 5%;
  background-color: #ffffff;
}

div.masonry-item div.info div.quote {
  font-size: 1.25em;
  color: #767676;
  line-height: 130%;
}

div.masonry-item div.info div.names {
  margin-top: 10px;
  font-family: "gi";
  font-size: 1.25em;
  text-align: right;
}

@media only screen and (max-width: 809px) {
  .masonry-sizer,
  .masonry-item {
    width: 47.5%;
  }
  .masonry-gutter {
    width: 5%;
  }
}
/*** Book ***/
form#booking-form {
  margin-top: 50px;
  width: 100%;
}

div.form-row-wrapper {
  width: 100%;
  margin-top: 40px;
}

div.form-row {
  float: left;
}

div.form-row-wrapper.one-col div.form-row {
  width: 100%;
  float: none;
}

div.form-row-wrapper.two-col div.form-row {
  width: 48%;
}

div.form-row-wrapper.three-col div.form-row {
  width: 30.6%;
}

div.form-row.full {
  width: 100%;
  float: none;
}

div.form-row:nth-child(n+2) {
  margin-left: 4%;
}

div.form-row label {
  font-family: "gi_l";
  font-size: 1.375em;
  line-height: 130%;
  display: block;
  padding-bottom: 10px;
  color: #585858;
}

input.textinput,
textarea.textinput {
  width: 100%;
  padding: 18px 12px;
  box-sizing: border-box;
  font-size: 1.125em;
  color: #585858;
  background: #ffffff;
  border: 1px solid #dac39a;
  border-radius: 0px;
}

textarea.textinput {
  height: 200px;
  line-height: 160%;
}

div.select-wrapper {
  position: relative;
}

div.select-wrapper:after {
  content: url("../img/down_arrow.png");
  display: inline-block;
  position: absolute;
  right: 18px;
  top: 24px;
  pointer-events: none;
}

select.textinput {
  position: relative;
  width: 100%;
  padding: 18px 12px;
  box-sizing: border-box;
  font-size: 1.125em;
  color: #585858;
  background: #ffffff;
  border: 1px solid #dac39a;
  border-radius: 0px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

input:focus,
textarea:focus,
select:focus {
  outline: none !important;
  border-color: #d7c692;
  /*box-shadow: 0 0 10px #D7C692;*/
}

div#error-msg,
div#success-msg {
  display: none;
}

div#error-msg {
  text-align: center;
  font-family: "gi";
  font-size: 1.375em;
  line-height: 125%;
  color: #dbc498;
  margin-top: 40px;
}

div#success-msg .title {
  text-align: center;
  font-family: "gi";
  font-size: 1.875em;
  line-height: 125%;
  color: #dbc498;
  margin-top: 60px;
}

div.checkbox-wrapper {
  width: 100%;
  max-width: 586px;
  margin: 50px auto 0px;
}

div.checkbox-img {
  float: left;
  width: 60px;
  cursor: pointer;
}

div.checkbox-text-wrapper {
  float: left;
  width: 85%;
  /*display: table;
  height: 28px;*/
  margin-left: 20px;
}

div.checkbox-text-wrapper .title {
  font-family: "gi";
  font-size: 1.875em;
  line-height: 125%;
  color: #dbc498;
}

div.checkbox-text-wrapper .title span {
  font-size: 0.875em;
}

div.checkbox-text-wrapper .text {
  font-family: "ga";
  font-size: 1.375em;
  line-height: 150%;
  color: #767676;
}

div.checkbox-text-wrapper .text span {
  display: block;
  font-size: 0.75em;
  line-height: 140%;
  margin-top: 10px;
}

div.checkbox-text a {
  color: #000;
}

a#appointment-btn {
  display: inline-block;
  padding: 20px 80px;
  margin-top: 64px;
  font-family: "gi";
  font-size: 28px;
  color: #ffffff;
  line-height: 100%;
  text-decoration: none;
  text-transform: uppercase;
  background: rgba(218, 195, 154, 0.76);
  transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -webkit-transition: all 0.5s ease-in-out;
}

a#appointment-btn:hover {
  background: rgba(218, 195, 154, 0.95);
}

@media only screen and (max-width: 1024px) {
  form#booking-form {
    margin-top: 20px;
  }
  div.form-row-wrapper {
    margin-top: 0px;
  }
  div.form-row-wrapper.one-col div.form-row,
  div.form-row-wrapper.two-col div.form-row,
  div.form-row-wrapper.three-col div.form-row {
    float: none;
    width: 100%;
    margin-left: 0px;
    margin-top: 25px;
  }
  div.form-row label {
    font-size: 1.25em;
    padding-bottom: 6px;
  }
  div.checkbox-wrapper {
    max-width: none;
    margin-top: 30px;
  }
}
/*** FAQ ***/
div.faq-wrapper {
  align-items: flex-start;
}

div.faq-item-wrapper {
  position: relative;
  padding: 17px 30px;
  box-sizing: border-box;
  background-color: #fff;
  border: 1px solid #dac39a;
  cursor: pointer;
  /*
    transition: max-height 0.5s ease-in-out;
    -moz-transition: max-height 0.5s ease-in-out;
  	-webkit-transition: max-height 0.5s ease-in-out;
  */
}

div.faq-item-wrapper img {
  display: block;
  position: absolute;
  top: 30px;
  right: 30px;
  width: 22px;
  transition: all 0.25s ease-in-out;
  -moz-transition: all 0.25s ease-in-out;
  -webkit-transition: all 0.25s ease-in-out;
}

div.faq-item-wrapper.open img {
  -ms-transform: rotate(180deg); /* IE 9 */
  -webkit-transform: rotate(180deg); /* Safari */
  transform: rotate(180deg);
  top: 30px;
}

/*
div.faq-item
{

}
*/
div.faq-question {
  font-family: "gi_l";
  font-size: 1.625em;
  line-height: 140%;
}

div.faq-answer {
  display: none;
  font-size: 1.375em;
  color: #767676;
  line-height: 140%;
  /*
  max-height: 0;
  overflow: hidden;

  -webkit-transform: translate3d(0, 0, 0);

  transition: all 1s ease-in-out;
  -moz-transition: all 1s ease-in-out;
  -webkit-transition: all 1s ease-in-out;
  */
}

div.faq-answer-inner {
  margin-top: 12px;
}

div.faq-answer b {
  font-family: "ga_b";
}

div.faq-answer a {
  font-weight: bold;
  color: #dac39a;
  text-decoration: none;
}

div.faq-item-wrapper.open div.faq-answer {
  /*
  max-height: 1000px;
  transition: all 0.75s ease-in-out;
  -moz-transition: all 0.75s ease-in-out;
  -webkit-transition: all 0.75s ease-in-out;
  */
}

/*** About ***/
.team-wrapper {
  display: grid;
  gap: 1.5rem;
  margin-top: 4rem;
  margin-bottom: 3rem;
  grid-template-columns: repeat(3, 1fr); /* Three columns */
}
.team-wrapper.full {
  display: block;
}
.team-wrapper .team-member-image {
  position: relative;
  display: inline-block;
}
.team-wrapper .team-member-image::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(250, 250, 250, 0) 30%, rgb(250, 250, 250) 91%);
  pointer-events: none; /* Makes sure clicks go through the gradient */
}
.team-wrapper .team-member-image img {
  display: block;
  width: 100%;
  height: auto;
}
.team-wrapper .team-member-image .team-member-info {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 100px 0 0;
  /* display: flex; */
  /* flex-direction: column; */
  color: #585858;
  text-align: center;
  text-transform: uppercase;
  /* background: linear-gradient(180deg, transparent, white); */
  /*background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 82%);*/
}
.team-wrapper .team-member-image .team-member-info h1 {
  font-size: 2rem;
}
.team-wrapper .team-member-image .team-member-info span {
  display: block;
  font-family: "gi";
  letter-spacing: 0.25px;
  font-size: 100%;
  margin-top: 0.125rem;
}
.team-wrapper .text-container {
  margin-top: 0.5rem;
  font-size: 1.25em;
}
@media (max-width: 480px) {
  .team-wrapper {
    grid-template-columns: 1fr; /* One column for smallest screens */
  }
}

@media (max-width: 920px) {
  .team-wrapper {
    grid-template-columns: repeat(2, 1fr); /* Two columns for smaller screens */
  }
  .team-wrapper.full .team-member-image img {
    aspect-ratio: 1/1;
    object-fit: cover;
  }
}
@media (max-width: 640px) {
  .team-wrapper {
    grid-template-columns: repeat(2, 1fr); /* Two columns for smaller screens */
  }
  .team-wrapper .team-member-image::before {
    background: linear-gradient(180deg, rgba(250, 250, 250, 0) 62%, rgb(250, 250, 250) 94%);
  }
  .team-wrapper .team-member-image .team-member-info span {
    font-size: 110%;
  }
  .team-wrapper .text-container {
    font-size: 1.5em;
  }
}
@media (max-width: 480px) {
  .team-wrapper {
    grid-template-columns: 1fr; /* One column for smallest screens */
  }
  .team-wrapper.full .team-member-image img {
    aspect-ratio: 2/3;
    object-fit: cover;
  }
}
div.about-text {
  font-size: 1.375em;
  color: #767676;
  line-height: 140%;
}

/*** Contact ***/
div.contact-text div.title {
  /* Milagro de Nahrin: */
  font-family: "gi_l";
  font-size: 2.625em;
  color: #767676;
  line-height: 100%;
}

div.contact-text .hours div.title {
  font-size: 2em;
}

div.contact-text div.info {
  margin-top: 32px;
  font-size: 1.625em;
  color: #767676;
  line-height: 135%;
}

div.contact-text div.info a {
  color: #dac39a;
  text-decoration: underline;
}

div.contact-text div.contact-social-media div.title {
  margin-top: 48px;
}
div.contact-text div.contact-social-media div.social-media {
  justify-content: center;
  gap: 20px;
}
div.contact-text div.contact-social-media div.social-media a {
  margin-right: 0;
}

div.contact-social-media div.title {
  margin-top: 64px;
  margin-bottom: 10px;
  font-family: "gi_l";
  font-size: 2.125em;
  color: #dac39a;
  line-height: 100%;
}

div.contact-social-media div.social-media {
  display: flex;
  align-content: flex-start;
}

div.contact-social-media div.social-media a {
  display: block;
  width: 80px;
  margin-top: 15px;
  margin-right: 20px;
}

div.store-wrapper {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
}

div.store-wrapper div.store {
  margin-top: 4%;
  color: #767676;
  text-align: center;
}

div.store-wrapper div.store div.title,
div.store-wrapper div.store div.title {
  font-family: "gi_l";
  line-height: 100%;
  margin-bottom: 5px;
}

div.store div.address div.title {
  margin-top: 42px;
  font-size: 2.625em;
}

div.store div.hours div.title {
  margin-top: 36px;
  font-size: 32px;
}

div.store div.hours div.title.small {
  margin-top: 36px;
  font-size: 28px;
  margin-bottom: 12px;
}

div.store div.hours.alt div.title {
  margin-top: 36px;
  font-size: 28px;
  font-family: "gi";
}

div.store-wrapper div.store div.info {
  font-size: 1.5em;
  line-height: 130%;
}

div.store-wrapper div.store .alt div.info {
  /*font-size: 1.375em;*/
  /*font-family: "ga_b";*/
}

div.store-wrapper div.store div.msg {
  margin-top: 14px;
  font-size: 1.375em;
  line-height: 120%;
  font-family: "ga_b";
}

@media only screen and (max-width: 1024px) {
  div.store-wrapper {
    max-width: unset;
  }
}
@media only screen and (max-width: 640px) {
  div.contact-text {
    margin-top: 3rem;
  }
  div.contact-text + div.contact-text {
    margin-top: 4rem;
  }
}
div#jobba-pa-milagro {
  margin-top: 64px;
}

/*** Footer ***/
@media only screen and (min-width: 640px) and (max-width: 1024px) {
  div.footer-element.flex-4 {
    /*width: 48%;*/
    flex-basis: 48%;
    margin-top: 4%;
  }
  div.footer-element.flex-2 {
    /*width: 100%;*/
    flex-basis: 100%;
    margin-top: 4%;
  }
}
@media only screen and (max-width: 640px) {
  div.footer-element.flex-2,
  div.footer-element.flex-4 {
    /*width: 100%;*/
    flex-basis: 100%;
    margin-top: 6%;
  }
}
div.footer-element div.title {
  margin-bottom: 16px;
  font-family: "gi_l";
  font-size: 24px;
  color: #767676;
  line-height: 28px;
}

div.footer-element div.text {
  font-size: 20px;
  color: #767676;
  line-height: 26px;
}

div.footer-element div#nl-error.text {
  display: none;
  font-weight: bold;
  color: #dac39a;
  margin-top: 15px;
  margin-bottom: 10px;
}

div.footer-element div.text a {
  font-weight: bold;
  color: #dac39a;
  text-decoration: none;
}

div.footer-element div#social-media {
  display: flex;
  align-content: flex-start;
  padding-bottom: 16px;
  margin-bottom: 16px;
  /*border-bottom: 1px solid #DAC39A;*/
}

div.footer-element div#social-media a {
  display: block;
  width: 50px;
  margin-right: 16px;
}

input#nl-email {
  width: 100%;
  margin-top: 16px;
  font-family: "gi_l";
  font-size: 20px;
  padding: 14px 8px;
  box-sizing: border-box;
  border: 1px solid #dac39a;
}

a#nl-submit-btn {
  display: inline-block;
  margin-top: 10px;
  padding: 16px 24px;
  background: rgba(218, 195, 154, 0.76);
  font-family: "gi";
  font-size: 20px;
  text-transform: uppercase;
  color: #ffffff;
  text-decoration: none;
}

a#nl-submit-btn:hover {
  background: rgba(218, 195, 154, 0.96);
}

div#nl-signup-thanks {
  display: none;
}

div#instagram-wrapper {
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
}

div#instagram-wrapper a {
  width: 20%;
}

div#instagram-wrapper a * {
  display: block;
  width: 100%;
}

div#instagram-wrapper a img {
  aspect-ratio: 9/16;
  object-fit: cover;
}

/*
div#instagram-wrapper a {
  display: block;
  width: 23%;
  margin-bottom: 16px;
}

@media only screen and (max-width: 640px) {
  div#instagram-wrapper a {
    width: 48%;
    margin-bottom: 16px;
  }
}
*/
@media only screen and (max-width: 640px) {
  div#instagram-wrapper {
    flex-wrap: wrap;
    gap: 1rem;
  }
  div#instagram-wrapper a {
    width: calc(50% - 0.5rem);
  }
}
@media only screen and (min-width: 640px) {
  div#instagram-wrapper a:last-of-type {
    display: none;
  }
}
/** Bottom footer **/
div#bottom-footer {
  margin-top: 2%;
  border-top: 1px solid #dac39a;
}

div#footer-links {
  padding: 24px 0px;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}

div#footer-links a {
  display: block;
  margin-right: 24px;
  font-family: "gi_l";
  font-size: 1.125em;
  color: #767676;
  text-decoration: none;
}
