:root {
  --bg-1: #180a07;
  --bg-2: #1c0e08;
  --bg-3: #241009;
  --text-main: #f6eee7;
  --text-soft: #d7c2ae;
  --text-muted: #a78b75;
  --accent-1: #fff8f1;
  --accent-2: #e8d6c3;
  --accent-3: #e5b27f;
  --accent-4: #b16f3d;
  --accent-5: #6e4121;
}

body {
  min-height: 100vh;
  overflow-x: hidden;
  color: var(--text-main);
  font-family: "Playfair Display", serif;
  background: radial-gradient(circle at 20% 18%, rgba(88, 50, 24, 0.16), transparent 24%), radial-gradient(circle at 72% 38%, rgba(173, 112, 58, 0.12), transparent 26%), radial-gradient(circle at 78% 72%, rgba(56, 31, 16, 0.34), transparent 30%), radial-gradient(circle at 50% 50%, rgba(255, 224, 186, 0.025), transparent 42%), linear-gradient(135deg, #080403 0%, #120906 26%, #1a0e08 58%, #24120b 100%);
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

/* =========================
   HERO
========================= */
.hero {
  padding: clamp(16px, 2vw, 28px);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.hero__inner {
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: center;
  position: relative;
  padding-top: 0.5rem;
}

.hero__eyebrow {
  font-style: italic;
  font-size: 1rem;
  letter-spacing: 0.18em;
  color: var(--text-muted);
  text-transform: uppercase;
}

.hero__stage {
  width: 100%;
  display: grid;
  justify-items: center;
}

.hero__title {
  z-index: 4;
  margin: 0;
  font-family: "Iosevka Charon Mono", monospace;
  font-size: 7rem;
  line-height: 0.92;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  white-space: normal;
  word-break: break-word;
  pointer-events: none;
  background: linear-gradient(180deg, var(--accent-1) 0%, var(--accent-2) 28%, var(--accent-3) 58%, var(--accent-4) 82%, var(--accent-5) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 20px rgba(239, 192, 143, 0.08), 0 8px 24px rgba(0, 0, 0, 0.14);
  max-width: none;
}

.hero__bg-word {
  position: absolute;
  inset-inline: 0;
  top: 50%;
  z-index: 1;
  pointer-events: none;
  user-select: none;
}

.hero__bg-track {
  display: flex;
  width: max-content;
  animation: coffeeInfinite 36s linear infinite;
  animation-duration: 60s;
}

.hero__bg-row {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}
.hero__bg-row span {
  flex: 0 0 auto;
  white-space: nowrap;
  font-size: 10rem;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.07);
  opacity: 0.75;
  filter: blur(1.5px);
}

.hero__visual {
  position: relative;
  z-index: 3;
  width: min(100%, 24rem);
  display: grid;
  place-items: center;
}

.hero__glow {
  position: absolute;
  inset: 50% auto auto 50%;
  width: clamp(180px, 34vw, 400px);
  height: clamp(180px, 34vw, 400px);
  transform: translate(-50%, -50%);
  border-radius: 50%;
  filter: blur(clamp(28px, 4vw, 60px));
  background: radial-gradient(circle, rgba(214, 151, 91, 0.42) 0%, rgba(154, 95, 49, 0.23) 42%, transparent 76%);
  animation: glowPulse 6s ease-in-out infinite;
}

.hero__shadow {
  position: absolute;
  left: 50%;
  bottom: 0.6rem;
  width: 210px;
  height: 54px;
  z-index: 1;
  transform: translateX(-50%);
  border-radius: 999px;
  background: radial-gradient(ellipse at center, rgba(18, 10, 6, 0.72) 0%, rgba(214, 200, 193, 0.393) 42%, rgba(0, 0, 0, 0.36) 72%, transparent 100%);
  filter: blur(14px);
  animation: shadowFloat 6s ease-in-out infinite;
}

.hero__image {
  z-index: 3;
  transform-origin: center;
  filter: drop-shadow(0 26px 46px rgba(0, 0, 0, 0.28)) drop-shadow(0 10px 18px rgba(199, 147, 95, 0.08));
  animation: floatDrinkMobile 6s ease-in-out infinite;
  width: min(34vw, 27rem);
  transform: rotate(-8deg);
  animation-name: floatDrinkDesktop;
}

.hero__info {
  width: 100%;
  justify-items: center;
}

.hero__text {
  margin: 0;
  font-style: italic;
  font-size: 2rem;
  line-height: 1.35;
  color: var(--text-soft);
  background: transparent;
}

.hero__status {
  position: relative;
  display: inline-flex;
  justify-content: center;
  padding-bottom: 7px;
  pointer-events: none;
}
.hero__status::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: min(100%, 28rem);
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent 0%, rgba(239, 192, 143, 0.14) 15%, rgba(255, 243, 232, 0.94) 50%, rgba(239, 192, 143, 0.14) 85%, transparent 100%);
  animation: statusLineBreath 2.8s ease-in-out infinite;
}

.hero__status-dot {
  display: none;
}

.hero__status-text {
  z-index: 2;
  max-width: 100%;
  margin: 0;
  text-align: center;
  font-family: "Iosevka Charon Mono", monospace;
  font-size: 3rem;
  line-height: 1.05;
  letter-spacing: clamp(0.06em, 0.7vw, 0.16em);
  text-transform: uppercase;
  white-space: normal;
  word-break: break-word;
  margin-top: 2rem;
  color: transparent;
  background: linear-gradient(90deg, rgba(246, 238, 231, 0.56) 0%, rgb(255, 248, 241) 22%, rgb(239, 192, 143) 50%, rgb(255, 248, 241) 78%, rgba(246, 238, 231, 0.56) 100%);
  background-size: 220% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 14px rgba(239, 192, 143, 0.1);
}

/* =========================
   ANIMATIONS
========================= */
@keyframes floatDrinkDesktop {
  0%, 100% {
    transform: rotate(-8deg) translateY(0);
  }
  50% {
    transform: rotate(-8deg) translateY(-18px);
  }
}
@keyframes floatDrinkMobile {
  0%, 100% {
    transform: rotate(-4deg) translateY(0);
  }
  50% {
    transform: rotate(-4deg) translateY(-12px);
  }
}
@keyframes shadowFloat {
  0%, 100% {
    transform: translateX(-50%) scaleX(1);
    opacity: 0.32;
  }
  50% {
    transform: translateX(-50%) scaleX(0.86);
    opacity: 0.18;
  }
}
@keyframes glowPulse {
  0%, 100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.94;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.06);
    opacity: 1;
  }
}
@keyframes coffeeInfinite {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes statusLineBreath {
  0%, 100% {
    transform: translateX(-50%) scaleX(0.76);
    opacity: 0.46;
  }
  50% {
    transform: translateX(-50%) scaleX(1);
    opacity: 1;
  }
}
.liquid-title {
  position: relative;
  display: inline-block;
  padding-bottom: 28px;
  isolation: isolate;
  overflow: visible;
}

.liquid-title::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(180deg, #fff8f1 0%, #f4dfcb 22%, #e5b27f 52%, #a66335 78%, #5b3319 100%);
  background-size: 100% 180%;
  background-position: 50% 0%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  filter: url(#coffee-distort);
  opacity: 0.95;
  animation: coffeeSurface 6s ease-in-out infinite, coffeeShine 9s linear infinite;
}

@keyframes coffeeSurface {
  0%, 100% {
    transform: translateY(0px) skewX(0deg);
  }
  25% {
    transform: translateY(1px) skewX(-0.4deg);
  }
  50% {
    transform: translateY(3px) skewX(0.5deg);
  }
  75% {
    transform: translateY(1px) skewX(-0.3deg);
  }
}
@keyframes coffeeShine {
  0% {
    background-position: 50% 0%;
  }
  50% {
    background-position: 50% 100%;
  }
  100% {
    background-position: 50% 0%;
  }
}
.coffee-drip {
  position: absolute;
  top: 82%;
  left: var(--x);
  z-index: 2;
  width: 14px;
  height: var(--h);
  transform: translateX(-50%) scaleY(0.15);
  transform-origin: top center;
  border-radius: 0 0 999px 999px;
  opacity: 0;
  background: linear-gradient(180deg, rgba(236, 193, 145, 0.95) 0%, rgba(161, 98, 52, 0.95) 55%, rgba(84, 46, 23, 0.95) 100%);
  filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.18));
  animation: dripMove var(--dur) ease-in-out var(--delay) infinite;
}

.coffee-drip::before {
  content: "";
  position: absolute;
  top: -8px;
  left: 50%;
  width: 18px;
  height: 18px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: inherit;
}

@keyframes dripMove {
  0%, 100% {
    opacity: 0;
    transform: translateX(-50%) translateY(0) scaleY(0.15);
  }
  12% {
    opacity: 1;
  }
  40% {
    opacity: 1;
    transform: translateX(-50%) translateY(4px) scaleY(1);
  }
  72% {
    opacity: 0.95;
    transform: translateX(-50%) translateY(18px) scaleY(0.88);
  }
  100% {
    opacity: 0;
    transform: translateX(-50%) translateY(28px) scaleY(0.15);
  }
}
@media (max-width: 1600px) {
  .hero__title {
    font-size: 5rem;
  }
  .hero__text {
    font-size: 1.7rem;
  }
  .hero__image {
    width: min(28vw, 21rem);
  }
  .hero {
    padding: 0;
  }
}
@media (max-width: 1024px) {
  .hero__bg-row span {
    font-size: 100px;
  }
  .hero__bg-word {
    top: 65%;
  }
  .hero__text {
    font-size: 30px;
    width: 81%;
  }
  .hero__info {
    width: 100%;
    justify-items: center;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
  }
  .hero {
    padding: 1rem 0;
  }
  .hero__title {
    font-size: 72px;
    padding-bottom: 1.4rem;
    width: 70%;
    line-height: 1;
  }
  .hero__eyebrow {
    font-size: 1.2rem;
    padding-bottom: 3rem;
    margin: 0;
  }
  .hero__status-text {
    padding: 1rem;
  }
  .hero__image {
    width: 500px;
    max-width: 48vw;
  }
  .hero__shadow {
    left: 260px;
    bottom: 60px;
    width: 210px;
  }
}
@media (max-width: 640px) {
  .liquid-title {
    padding-bottom: 18px;
  }
  .coffee-drip {
    width: 10px;
  }
  .coffee-drip::before {
    width: 12px;
    height: 12px;
    top: -5px;
  }
  .hero__text {
    font-size: 19px;
    width: 81%;
  }
  .hero {
    padding: 0;
  }
  .hero__title {
    font-size: 55px;
    padding-bottom: 5px;
    width: 90%;
    line-height: 1;
  }
  .hero__shadow {
    left: 226px;
    width: 149px;
    height: 19px;
    bottom: 56px;
  }
  .hero__eyebrow {
    font-size: 0.5rem;
    padding-bottom: 1rem;
  }
  .hero__status-text {
    padding: 1rem;
    font-size: 23px;
  }
  .hero__status {
    padding-top: 2rem;
    display: block;
  }
  .hero__image {
    width: 28rem;
    max-width: 75vw;
  }
}
@media (max-width: 360px) {
  .hero__title {
    font-size: 45px;
  }
  .hero__image {
    max-width: 56vw;
  }
  .hero__eyebrow {
    padding-bottom: 1.5rem;
  }
}/*# sourceMappingURL=style.css.map */