@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@200;400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Niconne&display=swap');
body {
    font-family: 'Poppins', sans-serif;
    margin: 0;
    padding: 10%;
    background-color: #c7b2d4e0;
    color:rgb(30, 8, 31)
}

h2 {
    font-family: Niconne, cursive;
    font-size: 3em;
    color: #1f012b;
    text-shadow: 1px 1px 7px #ffffff;
    font-size: clamp(1.8rem, 4vw, 4.2rem);
}
p {
    color: #1f012b;
    text-shadow: 1px 1px 3px #ffffff; 
    font-size: clamp(1rem, 2.2vw, 2.25rem);
    line-height: 1.5;
}

section {
    display: grid;
    padding-left: 10%;
    padding-right: 10%;
    place-items: center;
    align-content: center;
    min-height: 100vh; 
}

.hidden {
    opacity: 0;
    filter: blur(5px);
    transform: translateX(-100%);
    transition: all 1s;
}

.show {
    opacity: 1;
    filter:blur(0);
    transform: translateX(0);
}

.logos {
    display: flex;
}

.logo img {
    width: 150px;
    height: auto;
    margin: 10px;
    transition-delay: 1s;
}

.logo:nth-child(2) {
    transition-delay: 200;
}

.logo:nth-child(3) {
    transition-delay: 400;
}

.logo:nth-child(4) {
    transition-delay: 600;
}

.blommor {
    background-image: url('bakgrunder/bildram2.webp');
    background-size: cover;
    border-radius: 10px;
    min-height:100vh;
    padding-bottom: 100px;
}

.savethedate {
    background-image: url('bakgrunder/bildram2.webp');
    background-size: cover;
    border-radius: 10px;
    height:90vh;
}

.normal {
    padding-left: 10%;
    padding-right: 10%;
    border-radius: 20px;
}

.bg1 {
    background-image: url('bakgrunder/bg9-sep.webp');
    padding-left: 5%;
    padding-right: 5%;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    color: black;
}
.bg2 {
    background-image: url('bakgrunder/bg8-sep.webp');
    padding-left: 5%;
    padding-right: 5%;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    color: black;
    font-weight: 900;
}
.bg3 {
    background-image: url('bakgrunder/bg3.webp');
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
}

.logo {
    font-style: normal;
    color: #4c0f64;
    text-shadow: 2px 2px 8px #ffffff;
    letter-spacing: 0.4px;
    margin: 0;
    position: relative;
    text-align: center;
    line-height: 1.2;
}

.side-nav {
    position: fixed;
    top: 80px;
    left: -250px;
    width: 200px;
    background: rgba(255, 250, 252, 0.72);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    height: 100%;
    padding: 20px;
    transition: right 0.3s ease;
}

.side-nav.open {
    left: 0;
}

.menu-toggle {
    font-size: 24px;
    background: none;
    border: none;
    cursor: pointer;
    color: #b38ac7;
}

.follow {
    position: fixed;
    top: 20px;
    left: 20px;
}

.header {
    filter: drop-shadow(4 4 4 #acacac);
    display: grid;
    padding-top: 100px;
    padding-left: 20%;
    padding-right: 20%;
    place-items: center;
    align-content: center;
    left: 10%;
    width: 80%;

}

.headerimg{
    filter: blur(50%);
    width: 70%;
    height: auto;
}

/* Hero */
.hero {
    position: relative;
    overflow: hidden;
    /* mask removed to avoid clipping page-edge text; using overlay pseudo-element instead */
}

.hero-overlay {
    padding-left: 15%;
    padding-right: 15% ;
}

.carousel-container {
    position: relative;
    width: 100%;
    height: 420px;  /* eller 220px för mobile */
    overflow: hidden;
}

.hero-image {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: none;
    opacity: 0;
    transition: opacity 2s ease-in-out;
    border-radius: 12px;
}

.hero-image.active {
    display: block;
    opacity: 1;
}

html { scroll-behavior: smooth; }

.quick-menu{
  width: 60%;
  margin: 14px auto 0;
  padding: 12px;

  display: grid;
  grid-template-columns: 1fr 1fr;  /* två jämna kolumner */
  gap: 10px;

  background: rgba(255, 250, 252, 0.72);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border-radius: 14px;
  box-shadow: 0 10px 25px rgba(0,0,0,.10);
  box-sizing: border-box;
  justify-self: center;  /* grid-item centras i hero om hero är grid någonstans */
  margin-left: auto;
  margin-right: auto;
}

.quick-menu__item{
  display: block;
  width: 100%;
  text-align: center;

  text-decoration: none;
  font-weight: 700;
  color: #1f012b;
  background: #e7d8ef;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.08);
  box-sizing: border-box;
  font-family: Niconne, cursive;
    font-size: 2em;
    color: #1f012b;
    text-shadow: 1px 1px 7px #ffffff;
}
/* Blur frame that blends image edges with background */
/* carousel overlay removed to prevent covering nearby text */
/* hero-overlay removed: overlay text moved out */


/* Bonus: minska headerns padding på mobile */
.header{
  padding-top: 8px;
  padding-left: 6%;
  padding-right: 6%;
  width: 88%;
}
/* Hero ska INTE följa den generella section-layouten */
.hero{
  min-height: auto;      /* du har redan detta */
  padding-left: 5%;       /* viktigt: ta bort dubbel-padding */
  padding-right: 10%;      /* viktigt: ta bort dubbel-padding */
  place-items: unset;    /* tar bort centrering via grid */
  align-content: unset;  /* tar bort vertikal centrering */
}

.show {
  opacity: 1 !important;
  filter: blur(0) !important;
  transform: translateX(0) !important;
}
.quick-menu__item--add-guest{
  width: auto;           /* tar bort 100% */
  max-width: 220px;      /* välj själv */
  padding: 10px 14px;    /* valfritt */
  white-space: nowrap;   /* så den inte radbryter */
}