@font-face {
  font-family: 'NeueHaasDisplayRoman';
  src: url('fonts/NeueHaasDisplayRoman.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'NeueHaasDisplayMedium';
  src: url('fonts/NeueHaasDisplayMedium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
body {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  box-sizing: border-box;
}

body {
  color: #ffffff;
  font-family: 'Helvetica', Arial, sans-serif;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

html {
  height: 100%;
  margin: 0;
  padding: 0
}

.centered {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin: 0 auto;
  max-width: 1200px;
  padding: 0 20px;
}

.site-title {
  width: 100%;
  text-align: center;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.artisanal {
  font-weight: 900;
  font-size: clamp(3rem, 10vw, 6rem);
  letter-spacing: -4px;
  color: #ffdaaf;
}

.audio {
  font-weight: 100;
  font-size: clamp(3rem, 10vw, 6rem);
  letter-spacing: -4px;
  color: #ffdaaf;
}

.site-email {
  display: block;
  width: 100%;
  text-align: center;
  margin-bottom: 3rem;
  font-family: 'NeueHaasDisplayMedium', Arial, sans-serif;
  font-size: 1.7rem;
  font-weight: 100;
  letter-spacing: 0.3px;
  color: #ffdaaf;
  opacity: 0.8;
  text-decoration: none;
  transition: text-decoration 0.2s;
}

.site-email:hover {
  text-decoration: underline;
}

.blurb {
  max-width: 600px;
  margin-top: rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.3;
  letter-spacing: -0px;
  font-family: 'NeueHaasDisplayRoman', 'Helvetica', Arial, sans-serif;
  font-size: 1.3rem;
  color: #ffdaaf;
  opacity: 0.85;
  text-align: center;
  width: 100%;
}

.blurb2 {
  max-width: 600px;
  margin-top: 3rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.3;
  letter-spacing: -0.2px;
  font-family: 'NeueHaasDisplayRoman', 'Helvetica', Arial, sans-serif;
  font-size: 1.3rem;
  color: #ffdaaf;
  opacity: 0.85;
  text-align: center;
  width: 100%;
}

.blurb3 {
  max-width: 600px;
  margin-top: 1rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.30;
  letter-spacing: -0.2px;
  font-family: 'Helvetica', Arial, sans-serif;
  font-size: 1rem;
  color: #ffdaaf;
  opacity: 0.85;
  text-align: center;
  width: 100%;
}


.social-icons {
  display: flex;
  gap: 2rem;
  margin-top: 2.5rem;
  justify-content: center;
}

.social-icons a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #001817;
  transition: background 0.2s, transform 0.2s;
  text-decoration: none;
}

.social-icons a:hover {
  background: #ffdaaf;
  transform: scale(1.08);
}

.social-icons svg {
  width: 28px;
  height: 28px;
  fill: #ffdaaf;
  transition: fill 0.2s;
}

.social-icons a:hover svg {
  fill: #011d1b;
}

.links-row {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin-top: 3rem;
}

.home-link,
.pricing-link,
.clients-link {
  display: inline-block;
  color: #ffdaaf;
  font-family: 'Helvetica', Arial, sans-serif;
  font-size: 2rem;
  text-decoration: none;
  letter-spacing: -0.5px;
  font-weight: 300;
  opacity: 0.85;
  transition: text-decoration 0.2s;
  text-align: center;
  padding: 0 16px;
  margin: 0;
}

.home-link:hover,
.clients-link:hover {
  text-decoration: underline;
}

.pricing-list {
  max-width: 500px;
  margin-top: 2.5rem;
  font-family: 'Helvetica', Arial, sans-serif;
  font-size: 1.1rem;
  color: #ffdaaf;
  opacity: 0.85;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}
.pricing-row {
  display: flex;
  font-size: 1.3rem;
  justify-content: space-between;
  align-items: baseline;
  width: 100%;
}
.pricing-label {
  text-align: left;
  flex: 1 1 auto;
  letter-spacing: -0.5px;
  margin-bottom: -0.7rem;
}
.pricing-value {

  font-size: 1rem;
  font-weight: 300;
  opacity: 0.90;
  margin-bottom: 0.7rem;
  line-height: 1.5;
  flex: 0 0 auto;
  letter-spacing: -0.5px;
}

.home-link:hover {
  text-decoration: underline;
}

.swiper {
  width: 100%;
  max-width: 1200px;
  height: 220px;
  position: relative;
  margin-top: 2.5rem;
  opacity: 0;
  transition: opacity 0.4s ease;
}

.swiper.loaded {
  opacity: 1;
}
.swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
}

.carousel-img-container {
  width: 220px;
  aspect-ratio: 1 / 1;
  position: relative;
  overflow: hidden;
  background: #222;
  border-radius: 8px;
}

.carousel-img-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.carousel-img-container img.loaded {
  opacity: 1;
}

.carousel-desc {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s cubic-bezier(0.4,0,0.2,1);
  position: absolute;
  inset: 0;
  background: rgba(34, 34, 34, 0.95);
  color: #ffdaaf;
  padding: 12px 14px;
  font-size: 1rem;
  font-family: 'Helvetica', Arial, sans-serif;
  font-weight: 400;
  letter-spacing: 0.01em;
  border-radius: 8px;
  line-height: 1.5;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  z-index: 2;
}

.carousel-img-container:hover .carousel-desc {
  opacity: 1;
  pointer-events: auto;
}

@media (max-width: 1200px) {
  .swiper { max-width: 900px; }
  .carousel-img-container { width: 260px; }
}
@media (max-width: 900px) {
  .swiper { max-width: 600px; }
  .carousel-img-container { width: 220px; }
}
@media (max-width: 600px) {
  .blurb {
    font-size: 1rem;
    padding-left: 1.2rem;
    padding-right: 1.2rem;
    box-sizing: border-box;
  }
  .swiper {
    height: auto;
    margin-top: 1.5rem;
    max-width: 100vw !important;
    width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .centered {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .swiper-slide {
    width: px !important;
    margin: 0 2px !important;
    padding: 0 !important;
  }
  .carousel-img-container {
    width: 168px;
    aspect-ratio: 1 / 1;
    max-width: 100%;
    border-radius: 4px;
    overflow: hidden;
  }
.carousel-img-container img {
  width: 100%;           
  height: auto;         
  aspect-ratio: 1 / 1;   
  object-fit: cover;
  display: block;
  max-width: 100%;     
}
  .carousel-desc {
    font-size: 0.9rem; 
    padding: 8px 6px;
  }
  .artisanal {
    font-size: clamp(2.8rem, 14vw, 5rem);
  }

    .audio {
    font-size: clamp(2.8rem, 14vw, 5rem);
  }
  .site-email {
    font-size: 1.1rem;
  }

    .pricing-list {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
    box-sizing: border-box;
  }
.pricing-link,
.clients-link,
.home-link {
    font-size: 1.5rem;
  }
    #main-content {
    margin-top: 2.5rem;
  }
}

.container {
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
}

.bg {
    background: linear-gradient(-45deg, #011d1b, #04302b, #011b1d, #031f1d);
    background-size: 400% 400%;
    animation: gradient 9s ease infinite;
    height: 100vh;
}

@keyframes gradient {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

.rolling-banner {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 38px;
  background: #011d1b;
  color: #ffdaaf;
  display: flex;
  align-items: center;
  overflow: hidden;
  z-index: 1000;
  border-bottom: 1px solid #0a4b4b;
  font-family: 'Helvetica', Arial, sans-serif;
}

.rolling-banner-text {
  display: inline-block;
    font-family: 'Helvetica', Arial, sans-serif;
  white-space: nowrap;
  letter-spacing: -0.3px;
  font-size: 1rem;
  font-weight: 500;
  animation: rolling-banner-marquee 20s linear infinite;
  
}

@keyframes rolling-banner-marquee {
  0% {
    transform: translateX(70vw);
  }
  100% {
    transform: translateX(-100%);
  }
}

.rolling-banner-link {
  color: inherit;
  text-decoration: none;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  cursor: pointer;
}

.rolling-banner-link:hover,
.rolling-banner-link:focus {
  text-decoration: underline;
  color: #ffdaaf;
}

.rolling-banner-link:hover .rolling-banner-text,
.rolling-banner-link:focus .rolling-banner-text {
  animation-play-state: paused;
}

.page-fade {
  display: flex;
  flex: 1 0 auto;
  align-items: center;
  justify-content: center;
  width: 100%;
  opacity: 0;
  transition: opacity 0.3s;
}
.page-fade.fade-in {
  opacity: 1;
}
.page-fade.fade-out {
  opacity: 0;
}

.carousel-fade {
  opacity: 0;
  transition: opacity 0.3s ease;
}
.carousel-fade.loaded {
  opacity: 1;
}

.site-footer {
  left: 0;
  bottom: 0;
  width: 100%;
  text-align: center;
  margin-top: 3rem;
  margin-bottom: 1rem;
  font-size: 0.75rem;
  color: #ffdaaf;
  opacity: 0.7;
  letter-spacing: 1px;
  font-family: 'Helvetica', Arial, sans-serif;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: -1px;
}
.site-footer .artisanal {
  font-weight: bold;
  color: #ffdaaf;
  font-size: 1em;
  letter-spacing: -0.5px;
}

.site-footer .audio {
  font-size: 1em;
  margin-left: -0.05em;
  letter-spacing: -0.9px;
}

.site-footer .footer-meta {
  font-size: 0.8em;
  color: #ffdaaf;
  margin-left: -0.1rem;
  vertical-align: super;
  font-family: 'Helvetica', Arial, sans-serif;
  letter-spacing: 0px;
}

.carousel-link {
  display: block;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
}

.carousel-link:hover .carousel-img-container img:not(.swiper.is-dragging *) {
  filter: brightness(1.1);
  transition: filter 0.2s ease;
}

.swiper {
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

.swiper.is-dragging .carousel-img-container img {
  filter: brightness(0.95);
  transition: none;
}

.swiper.is-dragging .carousel-link {
  pointer-events: none;
}


