@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Playfair+Display:wght@500;600;700&display=swap";
/* [project]/src/app/globals.css [app-client] (css) */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
      --tw-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-tracking: initial;
      --tw-duration: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
    }
  }
}

.visible {
  visibility: visible;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.sticky {
  position: sticky;
}

.top-1\/2 {
  top: 50%;
}

.z-10 {
  z-index: 10;
}

.z-50 {
  z-index: 50;
}

.mx-auto {
  margin-inline: auto;
}

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

.block {
  display: block;
}

.flex {
  display: flex;
}

.grid {
  display: grid;
}

.hidden {
  display: none;
}

.inline-block {
  display: inline-block;
}

.inline-flex {
  display: inline-flex;
}

.h-\[75vh\] {
  height: 75vh;
}

.h-\[90px\] {
  height: 90px;
}

.h-\[350px\] {
  height: 350px;
}

.h-\[calc\(100vh-64px\)\] {
  height: calc(100vh - 64px);
}

.h-full {
  height: 100%;
}

.min-h-\[520px\] {
  min-height: 520px;
}

.min-h-screen {
  min-height: 100vh;
}

.w-\[34\%\] {
  width: 34%;
}

.w-\[66\%\] {
  width: 66%;
}

.w-\[140px\] {
  width: 140px;
}

.w-\[420px\] {
  width: 420px;
}

.w-full {
  width: 100%;
}

.max-w-\[1200px\] {
  max-width: 1200px;
}

.max-w-\[1400px\] {
  max-width: 1400px;
}

.flex-1 {
  flex: 1;
}

.flex-shrink-0 {
  flex-shrink: 0;
}

.-translate-y-1\/2 {
  --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
  translate: var(--tw-translate-x) var(--tw-translate-y);
}

.scale-125 {
  --tw-scale-x: 125%;
  --tw-scale-y: 125%;
  --tw-scale-z: 125%;
  scale: var(--tw-scale-x) var(--tw-scale-y);
}

.cursor-pointer {
  cursor: pointer;
}

.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.flex-col {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.items-baseline {
  align-items: baseline;
}

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

.items-end {
  align-items: flex-end;
}

.items-start {
  align-items: flex-start;
}

.justify-between {
  justify-content: space-between;
}

.justify-center {
  justify-content: center;
}

.justify-start {
  justify-content: flex-start;
}

.truncate {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.overflow-hidden {
  overflow: hidden;
}

.overflow-x-auto {
  overflow-x: auto;
}

.overflow-y-auto {
  overflow-y: auto;
}

.rounded-full {
  border-radius: 3.40282e38px;
}

.border {
  border-style: var(--tw-border-style);
  border-width: 1px;
}

.border-0 {
  border-style: var(--tw-border-style);
  border-width: 0;
}

.border-2 {
  border-style: var(--tw-border-style);
  border-width: 2px;
}

.border-r {
  border-right-style: var(--tw-border-style);
  border-right-width: 1px;
}

.border-b {
  border-bottom-style: var(--tw-border-style);
  border-bottom-width: 1px;
}

.border-b-2 {
  border-bottom-style: var(--tw-border-style);
  border-bottom-width: 2px;
}

.border-accent {
  border-color: var(--color-accent);
}

.border-border {
  border-color: var(--color-border);
}

.border-border\/50 {
  border-color: #f0f0f080;
}

@supports (color: color-mix(in lab, red, red)) {
  .border-border\/50 {
    border-color: color-mix(in oklab, var(--color-border) 50%, transparent);
  }
}

.border-primary {
  border-color: var(--color-primary);
}

.border-t-transparent {
  border-top-color: #0000;
}

.bg-accent {
  background-color: var(--color-accent);
}

.bg-accent-bg {
  background-color: var(--color-accent-bg);
}

.bg-accent\/10 {
  background-color: #8b1a1a1a;
}

@supports (color: color-mix(in lab, red, red)) {
  .bg-accent\/10 {
    background-color: color-mix(in oklab, var(--color-accent) 10%, transparent);
  }
}

.bg-bg {
  background-color: var(--color-bg);
}

.bg-gold {
  background-color: var(--color-gold);
}

.bg-primary {
  background-color: var(--color-primary);
}

.bg-primary\/5 {
  background-color: #1a1a2e0d;
}

@supports (color: color-mix(in lab, red, red)) {
  .bg-primary\/5 {
    background-color: color-mix(in oklab, var(--color-primary) 5%, transparent);
  }
}

.bg-transparent {
  background-color: #0000;
}

.bg-gradient-to-b {
  --tw-gradient-position: to bottom in oklab;
  background-image: linear-gradient(var(--tw-gradient-stops));
}

.bg-gradient-to-r {
  --tw-gradient-position: to right in oklab;
  background-image: linear-gradient(var(--tw-gradient-stops));
}

.bg-gradient-to-t {
  --tw-gradient-position: to top in oklab;
  background-image: linear-gradient(var(--tw-gradient-stops));
}

.to-transparent {
  --tw-gradient-to: transparent;
  --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
}

.object-cover {
  object-fit: cover;
}

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

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

.font-heading {
  font-family: var(--font-heading);
}

.text-\[9px\] {
  font-size: 9px;
}

.text-\[10px\] {
  font-size: 10px;
}

.text-\[13px\] {
  font-size: 13px;
}

.leading-\[1\.1\] {
  --tw-leading: 1.1;
  line-height: 1.1;
}

.tracking-\[0\.2em\] {
  --tw-tracking: .2em;
  letter-spacing: .2em;
}

.text-accent {
  color: var(--color-accent);
}

.text-blue {
  color: var(--color-blue);
}

.text-gold {
  color: var(--color-gold);
}

.text-primary {
  color: var(--color-primary);
}

.text-primary\/40 {
  color: #1a1a2e66;
}

@supports (color: color-mix(in lab, red, red)) {
  .text-primary\/40 {
    color: color-mix(in oklab, var(--color-primary) 40%, transparent);
  }
}

.text-text-light {
  color: var(--color-text-light);
}

.text-text-light\/30 {
  color: #6b72804d;
}

@supports (color: color-mix(in lab, red, red)) {
  .text-text-light\/30 {
    color: color-mix(in oklab, var(--color-text-light) 30%, transparent);
  }
}

.text-text-light\/40 {
  color: #6b728066;
}

@supports (color: color-mix(in lab, red, red)) {
  .text-text-light\/40 {
    color: color-mix(in oklab, var(--color-text-light) 40%, transparent);
  }
}

.capitalize {
  text-transform: capitalize;
}

.uppercase {
  text-transform: uppercase;
}

.antialiased {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.transition-all {
  transition-property: all;
  transition-timing-function: var(--tw-ease, ease);
  transition-duration: var(--tw-duration, 0s);
}

.transition-colors {
  transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
  transition-timing-function: var(--tw-ease, ease);
  transition-duration: var(--tw-duration, 0s);
}

.transition-transform {
  transition-property: transform, translate, scale, rotate;
  transition-timing-function: var(--tw-ease, ease);
  transition-duration: var(--tw-duration, 0s);
}

.duration-200 {
  --tw-duration: .2s;
  transition-duration: .2s;
}

.duration-300 {
  --tw-duration: .3s;
  transition-duration: .3s;
}

@media (hover: hover) {
  .group-hover\:scale-105:is(:where(.group):hover *) {
    --tw-scale-x: 105%;
    --tw-scale-y: 105%;
    --tw-scale-z: 105%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }
}

.focus-within\:border-accent\/30:focus-within {
  border-color: #8b1a1a4d;
}

@supports (color: color-mix(in lab, red, red)) {
  .focus-within\:border-accent\/30:focus-within {
    border-color: color-mix(in oklab, var(--color-accent) 30%, transparent);
  }
}

.focus-within\:border-primary\/40:focus-within {
  border-color: #1a1a2e66;
}

@supports (color: color-mix(in lab, red, red)) {
  .focus-within\:border-primary\/40:focus-within {
    border-color: color-mix(in oklab, var(--color-primary) 40%, transparent);
  }
}

.focus-within\:shadow-accent\/5:focus-within {
  --tw-shadow-color: #8b1a1a0d;
}

@supports (color: color-mix(in lab, red, red)) {
  .focus-within\:shadow-accent\/5:focus-within {
    --tw-shadow-color: color-mix(in oklab, color-mix(in oklab, var(--color-accent) 5%, transparent) var(--tw-shadow-alpha), transparent);
  }
}

@media (hover: hover) {
  .hover\:bg-accent-light:hover {
    background-color: var(--color-accent-light);
  }
}

@media (hover: hover) {
  .hover\:bg-primary:hover {
    background-color: var(--color-primary);
  }
}

@media (hover: hover) {
  .hover\:bg-primary-light:hover {
    background-color: var(--color-primary-light);
  }
}

@media (hover: hover) {
  .hover\:text-accent:hover {
    color: var(--color-accent);
  }
}

@media (hover: hover) {
  .hover\:text-primary:hover {
    color: var(--color-primary);
  }
}

@media (hover: hover) {
  .hover\:text-primary\/70:hover {
    color: #1a1a2eb3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .hover\:text-primary\/70:hover {
      color: color-mix(in oklab, var(--color-primary) 70%, transparent);
    }
  }
}

@media (hover: hover) {
  .hover\:underline:hover {
    text-decoration-line: underline;
  }
}

.focus\:border-accent:focus {
  border-color: var(--color-accent);
}

.focus\:ring-2:focus {
  --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

.focus\:ring-accent\/50:focus {
  --tw-ring-color: #8b1a1a80;
}

@supports (color: color-mix(in lab, red, red)) {
  .focus\:ring-accent\/50:focus {
    --tw-ring-color: color-mix(in oklab, var(--color-accent) 50%, transparent);
  }
}

.focus\:outline-none:focus {
  --tw-outline-style: none;
  outline-style: none;
}

.disabled\:opacity-50:disabled {
  opacity: .5;
}

:root, :host {
  --color-primary: #1a1a2e;
  --color-primary-light: #2d2d44;
  --color-accent: #8b1a1a;
  --color-accent-light: brown;
  --color-accent-bg: #fdf2f2;
  --color-green: #1a6b3c;
  --color-blue: #1a56db;
  --color-gold: #b8860b;
  --color-bg: #f8f8f8;
  --color-text: #1a1a2e;
  --color-text-light: #6b7280;
  --color-border: #f0f0f0;
  --font-heading: "Playfair Display", Georgia, serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, .font-heading {
  font-family: var(--font-heading);
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-fade-in-up {
  animation: .5s ease-out forwards fadeInUp;
}

.animate-delay-1 {
  opacity: 0;
  animation-delay: .1s;
}

.animate-delay-2 {
  opacity: 0;
  animation-delay: .2s;
}

.animate-delay-3 {
  opacity: 0;
  animation-delay: .3s;
}

.animate-delay-4 {
  opacity: 0;
  animation-delay: .4s;
}

.card-luxury {
  border-radius: 16px;
  transition: transform .3s cubic-bezier(.25, .46, .45, .94), box-shadow .3s;
}

.card-luxury:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px #0000001a;
}

.img-smooth {
  transition: transform .5s cubic-bezier(.25, .46, .45, .94);
}

.img-smooth:hover {
  transform: scale(1.06);
}

.btn-pulse {
  transition: transform .2s, box-shadow .2s, background-color .2s;
}

.btn-pulse:hover {
  transform: scale(1.03);
  box-shadow: 0 8px 24px #8b1a1a4d;
}

.btn-pulse:active {
  transform: scale(.97);
}

.glass {
  -webkit-backdrop-filter: blur(20px);
  background: #ffffff1f;
  border: 1px solid #ffffff26;
}

.btn-pill {
  border-radius: 50px;
  transition: all .25s cubic-bezier(.25, .46, .45, .94);
}

.btn-pill:hover {
  transform: scale(1.04);
}

.tab-pill {
  border-radius: 12px;
  transition: all .25s cubic-bezier(.25, .46, .45, .94);
}

.input-smooth {
  transition: box-shadow .2s, border-color .2s;
}

.input-smooth:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px #8b1a1a1a;
}

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

::-webkit-scrollbar-track {
  background: none;
}

::-webkit-scrollbar-thumb {
  background: #d1d5db;
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: #9ca3af;
}

.badge-premium {
  background: var(--color-green);
  color: #fff;
  letter-spacing: .05em;
  text-transform: uppercase;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 600;
}

.accent-line {
  background: linear-gradient(90deg, var(--color-accent), var(--color-gold));
  border-radius: 2px;
  height: 3px;
}

.rounded-xl {
  border-radius: 16px;
}

.rounded-2xl {
  border-radius: 20px;
}

.rounded-3xl {
  border-radius: 24px;
}

@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-gradient-position {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-stops {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}

@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}

@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-leading {
  syntax: "*";
  inherits: false
}

@property --tw-tracking {
  syntax: "*";
  inherits: false
}

@property --tw-duration {
  syntax: "*";
  inherits: false
}

@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-ring-inset {
  syntax: "*";
  inherits: false
}

@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0;
}

@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}

@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

/*# sourceMappingURL=src_app_globals_0p2ml0n.css.map*/