/*!************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[3]!./src/app/(frontend)/globals.css ***!
  \************************************************************************************************************************************************************************************************************************************************************************************/
/* App-level styles for the public storefront.
   Design tokens + base reset are imported from @lucy/ui in layout.tsx. */

main {
  display: block;
  min-height: 100dvh;
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[3]!../../packages/ui/src/components/Button.module.css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************/
.Button_button__nNuJ_ {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2xs);
  font-family: var(--font-body);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wide);
  line-height: 1;
  text-align: center;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  transition:
    transform var(--transition-fast),
    background-color var(--transition),
    color var(--transition),
    border-color var(--transition),
    box-shadow var(--transition);
  white-space: nowrap;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.Button_button__nNuJ_:hover {
  transform: translateY(-1px);
}

.Button_button__nNuJ_:active {
  transform: translateY(0);
}

.Button_button__nNuJ_:disabled,
.Button_button__nNuJ_[aria-disabled='true'] {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
}

/* Sizes */
.Button_sm__dwCI0 {
  font-size: var(--text-sm);
  padding: 0.55rem 1.1rem;
}

.Button_md__AsJLv {
  font-size: var(--text-base);
  padding: 0.8rem 1.6rem;
}

.Button_lg__fhIuL {
  font-size: var(--text-md);
  padding: 1rem 2.1rem;
}

.Button_block__vzT_n {
  display: flex;
  width: 100%;
}

/* Variants */
.Button_primary__GCtQm {
  background-color: var(--color-accent);
  color: var(--lucy-white);
  box-shadow: var(--shadow-accent);
}

.Button_primary__GCtQm:hover {
  background-color: var(--color-accent-strong);
}

.Button_secondary__1AVfZ {
  background-color: transparent;
  color: var(--color-text);
  border-color: var(--color-detail);
}

.Button_secondary__1AVfZ:hover {
  background-color: var(--color-detail);
  color: var(--lucy-white);
}

.Button_ghost__OC11f {
  background-color: transparent;
  color: var(--color-text);
  border-color: var(--color-line-strong);
}

.Button_ghost__OC11f:hover {
  border-color: var(--color-text);
}

/* On dark surfaces (e.g. the hero), the secondary/ghost buttons invert. */
.lucy-on-dark .Button_secondary__1AVfZ {
  color: var(--color-text-on-dark);
  border-color: var(--color-detail-bright);
}

.lucy-on-dark .Button_secondary__1AVfZ:hover {
  background-color: var(--color-detail-bright);
  color: var(--lucy-espresso);
}

.lucy-on-dark .Button_ghost__OC11f {
  color: var(--color-text-on-dark);
  border-color: var(--color-line-on-dark);
}

.lucy-on-dark .Button_ghost__OC11f:hover {
  border-color: var(--color-text-on-dark);
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[3]!../../packages/ui/src/components/Container.module.css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************/
.Container_container__zdBMd {
  width: 100%;
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

.Container_default__mJK7O {
  max-width: var(--container-max);
}

.Container_narrow__Lotbr {
  max-width: var(--container-narrow);
}

.Container_wide__g6PZm {
  max-width: var(--container-wide);
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[3]!./src/components/CookieConsent.module.css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************/
.CookieConsent_overlay__UizkJ {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal, 1000);
  display: grid;
  place-items: center;
  padding: var(--space-md);
  /* dimmed, but the site stays visible behind */
  background: rgba(28, 22, 20, 0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  animation: CookieConsent_cookieFade__El25j var(--transition) var(--ease-soft);
}

.CookieConsent_card__cq0og {
  width: min(30rem, 100%);
  background: var(--color-surface);
  color: var(--color-text);
  border-radius: var(--radius-lg);
  border-top: 3px solid var(--color-detail);
  padding: clamp(1.5rem, 4vw, 2.5rem);
  box-shadow: 0 2rem 4rem -1rem rgba(0, 0, 0, 0.45);
  outline: none;
  animation: CookieConsent_cookieRise__fOnWO var(--transition-slow) var(--ease-soft);
}

.CookieConsent_eyebrow__7KyVA {
  margin: 0 0 var(--space-2xs);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-detail);
}

.CookieConsent_title__QCVhx {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-heading);
  font-weight: var(--weight-semibold);
  font-size: var(--text-2xl);
  line-height: var(--leading-tight);
  color: var(--color-text);
}

.CookieConsent_text__I9mfq {
  margin: 0 0 var(--space-lg);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--color-text-muted);
}

.CookieConsent_link__HAZb9 {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.CookieConsent_actions__qKujs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.CookieConsent_actions__qKujs > * {
  flex: 1 1 auto;
}

@keyframes CookieConsent_cookieFade__El25j {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes CookieConsent_cookieRise__fOnWO {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .CookieConsent_overlay__UizkJ,
  .CookieConsent_card__cq0og {
    animation: none;
  }
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[3]!./src/components/site/Footer.module.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************/
.Footer_footer__K91Sq {
  margin-top: var(--section-y);
  padding-top: var(--space-2xl);
  padding-bottom: var(--space-xl);
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
}

.Footer_inner__f63vB {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 2.4fr);
  grid-gap: var(--space-2xl);
  gap: var(--space-2xl);
  padding-bottom: var(--space-2xl);
  border-bottom: 1px solid var(--color-line-on-dark);
}

.Footer_columns__mSp87 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: var(--space-lg);
  gap: var(--space-lg);
}

.Footer_brand__W8Mkt {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tight);
}

.Footer_tagline__grDRl {
  margin-top: var(--space-2xs);
  max-width: 32ch;
  color: var(--color-text-on-dark-muted);
}

.Footer_social__2W2f8 {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-md);
}

.Footer_hashtag__hYwGz {
  margin-top: var(--space-md);
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-wide);
  color: var(--color-detail-bright);
}

.Footer_colTitle__9ZdZP {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  color: var(--color-detail-bright);
  margin-bottom: var(--space-sm);
}

.Footer_col__g4h4I ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
}

.Footer_link__HPVE9 {
  color: var(--color-text-on-dark-muted);
  font-size: var(--text-sm);
  transition: color var(--transition);
}

.Footer_link__HPVE9:hover {
  color: var(--color-text-on-dark);
}

.Footer_draftNote__dzMH2 {
  margin-top: var(--space-md);
  font-size: var(--text-xs);
  font-style: italic;
  color: var(--color-text-on-dark-muted);
}

.Footer_bottom__x_Zjq {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-2xs);
  padding-top: var(--space-lg);
  font-size: var(--text-xs);
  color: var(--color-text-on-dark-muted);
}

.Footer_note__q3Hv0 {
  text-align: right;
}

@media (max-width: 768px) {
  .Footer_inner__f63vB {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .Footer_columns__mSp87 {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg) var(--space-md);
  }

  .Footer_bottom__x_Zjq {
    flex-direction: column;
  }

  .Footer_note__q3Hv0 {
    text-align: left;
  }
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[3]!./src/components/site/Header.module.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************/
.Header_header__DOgjV {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: color-mix(in srgb, var(--color-bg) 86%, transparent);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-line);
}

.Header_inner__NumeB {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  min-height: 4.5rem;
}

.Header_brand__iPD97 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
  white-space: nowrap;
}

/* Nav styles (desktop + mobile hamburger) live in HeaderNav.module.css. */

/*!********************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[5].use[3]!./src/components/site/HeaderNav.module.css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************/
.HeaderNav_desktopNav__EiWEX {
  display: flex;
  align-items: center;
  gap: clamp(0.85rem, 2.2vw, 2rem);
}

.HeaderNav_link__edki6 {
  position: relative;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  color: var(--color-text-muted);
  transition: color var(--transition);
}

.HeaderNav_link__edki6::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -0.35rem;
  width: 0;
  height: 1px;
  background: var(--color-detail);
  transition: width var(--transition);
}

.HeaderNav_link__edki6:hover {
  color: var(--color-text);
}

.HeaderNav_link__edki6:hover::after {
  width: 100%;
}

.HeaderNav_cart__pp7zc {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  color: var(--color-text);
}

.HeaderNav_count__UhhSg {
  display: inline-grid;
  place-items: center;
  min-width: 1.4rem;
  height: 1.4rem;
  padding: 0 0.35rem;
  border-radius: var(--radius-pill);
  background: var(--color-accent);
  color: var(--lucy-white);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
}

/* --- Hamburger (mobile only) --------------------------------------------- */
.HeaderNav_burger__8KyYp {
  display: none;
  position: relative;
  z-index: calc(var(--z-header) + 2);
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border: 0;
  background: none;
  cursor: pointer;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

.HeaderNav_burgerBar__ImmeE {
  display: block;
  width: 1.5rem;
  height: 2px;
  border-radius: 2px;
  background: var(--color-text);
  transition:
    transform var(--transition),
    opacity var(--transition);
}

.HeaderNav_barTop__REpQo {
  transform: translateY(7px) rotate(45deg);
}

.HeaderNav_barMid__nPJcS {
  opacity: 0;
}

.HeaderNav_barBot__If_86 {
  transform: translateY(-7px) rotate(-45deg);
}

.HeaderNav_scrim__YVlXa {
  position: fixed;
  inset: 0;
  z-index: calc(var(--z-header) - 1);
  border: 0;
  background: color-mix(in srgb, var(--lucy-ink) 32%, transparent);
  cursor: default;
}

.HeaderNav_mobilePanel__3umjF {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: calc(var(--z-header) + 1);
  flex-direction: column;
  gap: var(--space-md);
  padding: var(--space-lg) var(--container-pad) var(--space-xl);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-line);
  box-shadow: var(--shadow-md);
}

.HeaderNav_mobileOpen__19Evf {
  display: flex;
  animation: HeaderNav_navDrop__N5gIf var(--transition) var(--ease-soft);
}

.HeaderNav_mobilePanel__3umjF .HeaderNav_link__edki6,
.HeaderNav_mobilePanel__3umjF .HeaderNav_cart__pp7zc {
  font-size: var(--text-md);
}

@keyframes HeaderNav_navDrop__N5gIf {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 768px) {
  .HeaderNav_desktopNav__EiWEX {
    display: none;
  }

  .HeaderNav_burger__8KyYp {
    display: inline-flex;
  }
}

@media (prefers-reduced-motion: reduce) {
  .HeaderNav_mobileOpen__19Evf {
    animation: none;
  }
}

/*!*******************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[3]!../../packages/ui/src/tokens/tokens.css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************/
/* =============================================================================
   Lucy Eleazar — Design tokens
   "Premium contemporary fiction": deep warm base, blush/rouge as ACCENT ONLY,
   bronze/gold details, generous whitespace, expressive serif + clean sans.
   (CLAUDE.md → "Design direction". No kitschy pink, no clichéd stock-couple feel.)
   ============================================================================= */

:root {
  /* --- Raw palette --------------------------------------------------------- */
  /* Deep warm base */
  --lucy-ink: #1c1614; /* deep warm near-black — primary text on light */
  --lucy-espresso: #241a16;
  --lucy-bordeaux: #4a1c28; /* deep warm wine */
  --lucy-bordeaux-deep: #2a0f17;

  /* Warm light surfaces */
  --lucy-ivory: #fbf7f2; /* page background */
  --lucy-white: #ffffff;
  --lucy-sand: #f3eae0; /* alt surface */
  --lucy-cream: #f7efe6; /* text/surface on dark */

  /* Accent — blush / rouge (use sparingly) */
  --lucy-rouge: #b23a48; /* muted, premium — never bubblegum pink */
  --lucy-rouge-bright: #c84e5b;
  --lucy-blush: #e7c9c4;

  /* Details — bronze / gold */
  --lucy-bronze: #a9824f;
  --lucy-gold: #c6a15b;
  --lucy-gold-soft: #d8be8c;

  /* Warm neutrals */
  --lucy-muted: #6e5f54;
  --lucy-muted-soft: #9a8b7e;

  /* Feedback */
  --lucy-success: #4f7a52;
  --lucy-danger: #a83232;

  /* --- Semantic colors ----------------------------------------------------- */
  --color-bg: var(--lucy-ivory);
  --color-surface: var(--lucy-white);
  --color-surface-alt: var(--lucy-sand);

  --color-text: var(--lucy-ink);
  --color-text-muted: var(--lucy-muted);
  --color-text-soft: var(--lucy-muted-soft);
  --color-text-on-dark: var(--lucy-cream);
  --color-text-on-dark-muted: rgba(247, 239, 230, 0.72);

  --color-accent: var(--lucy-rouge);
  --color-accent-strong: var(--lucy-rouge-bright);
  --color-accent-soft: var(--lucy-blush);

  --color-detail: var(--lucy-bronze);
  --color-detail-bright: var(--lucy-gold);

  --color-line: rgba(28, 22, 20, 0.12);
  --color-line-strong: rgba(28, 22, 20, 0.22);
  --color-line-on-dark: rgba(247, 239, 230, 0.18);

  --color-focus: var(--lucy-gold);

  /* Surfaces for dark sections (e.g. the hero) */
  --color-bg-dark: var(--lucy-bordeaux-deep);
  --gradient-hero: radial-gradient(
      120% 120% at 78% 12%,
      rgba(169, 130, 79, 0.22) 0%,
      rgba(169, 130, 79, 0) 46%
    ),
    linear-gradient(155deg, var(--lucy-bordeaux) 0%, var(--lucy-bordeaux-deep) 58%, var(--lucy-espresso) 100%);

  /* --- Typography ---------------------------------------------------------- */
  /* The next/font loader injects --font-serif / --font-sans on <html>; we add
     robust fallbacks here so type renders well before/without the web fonts. */
  --font-heading: var(--font-serif), "Playfair Display", "Iowan Old Style", "Apple Garamond",
    Georgia, "Times New Roman", serif;
  --font-body: var(--font-sans), -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica,
    Arial, sans-serif;

  /* Fluid type scale (mobile-first; clamps grow with viewport) */
  --text-xs: 0.78rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-md: 1.0625rem;
  --text-lg: clamp(1.125rem, 0.4vw + 1.05rem, 1.3rem);
  --text-xl: clamp(1.3rem, 1vw + 1.05rem, 1.6rem);
  --text-2xl: clamp(1.6rem, 2vw + 1.1rem, 2.2rem);
  --text-3xl: clamp(2rem, 3vw + 1.1rem, 3rem);
  --text-display: clamp(2.75rem, 5.5vw + 1rem, 5rem);
  --text-display-lg: clamp(3rem, 7vw + 0.5rem, 6.5rem);

  --leading-none: 1;
  --leading-tight: 1.08;
  --leading-snug: 1.22;
  --leading-normal: 1.6;
  --leading-relaxed: 1.78;

  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;
  --tracking-eyebrow: 0.22em; /* uppercase kickers */

  --weight-regular: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;

  /* --- Spacing (generous whitespace) -------------------------------------- */
  --space-3xs: 0.25rem;
  --space-2xs: 0.5rem;
  --space-xs: 0.75rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2rem;
  --space-xl: 3rem;
  --space-2xl: 4rem;
  --space-3xl: 6rem;
  --space-4xl: 8rem;
  --section-y: clamp(3.5rem, 8vw, 8rem); /* vertical rhythm between sections */

  /* --- Radii --------------------------------------------------------------- */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 14px;
  --radius-xl: 24px;
  --radius-pill: 999px;

  /* --- Elevation (soft, warm shadows) ------------------------------------- */
  --shadow-sm: 0 1px 2px rgba(28, 22, 20, 0.06);
  --shadow-md: 0 8px 24px -8px rgba(28, 22, 20, 0.18);
  --shadow-lg: 0 24px 60px -20px rgba(28, 22, 20, 0.3);
  --shadow-accent: 0 18px 40px -18px rgba(178, 58, 72, 0.5);

  /* --- Layout -------------------------------------------------------------- */
  --container-max: 1200px;
  --container-wide: 1360px;
  --container-narrow: 760px;
  --container-pad: clamp(1.25rem, 5vw, 4rem);

  /* --- Motion -------------------------------------------------------------- */
  --ease-soft: cubic-bezier(0.22, 0.61, 0.36, 1);
  --transition-fast: 140ms var(--ease-soft);
  --transition: 240ms var(--ease-soft);
  --transition-slow: 420ms var(--ease-soft);

  /* --- Z-index ------------------------------------------------------------- */
  --z-base: 1;
  --z-header: 100;
  --z-overlay: 1000;
  --z-modal: 1100;
  --z-toast: 1200;
}

@media (prefers-reduced-motion: reduce) {
  :root {
    --transition-fast: 0ms;
    --transition: 0ms;
    --transition-slow: 0ms;
  }
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[3]!../../packages/ui/src/styles/base.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************/
/* =============================================================================
   Base / reset — applies the design tokens to bare HTML.
   Import AFTER tokens.css. Kept minimal so critical CSS stays small.
   ============================================================================= */

*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
}

html {
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  -moz-tab-size: 4;
       tab-size: 4;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

body {
  min-height: 100dvh;
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--text-md);
  line-height: var(--leading-normal);
  font-weight: var(--weight-regular);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-heading);
  font-weight: var(--weight-semibold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
  text-wrap: balance;
}

p {
  text-wrap: pretty;
}

a {
  color: inherit;
  text-decoration: none;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}

button {
  cursor: pointer;
  background: none;
  border: none;
}

ul[role='list'],
ol[role='list'] {
  list-style: none;
  padding: 0;
}

::selection {
  background-color: var(--color-accent);
  color: var(--lucy-white);
}

:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* Accessible visually-hidden helper */
.lucy-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!../../node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!../../node_modules/next/font/google/target.css?{"path":"src/lib/fonts.ts","import":"Playfair_Display","arguments":[{"subsets":["latin","cyrillic"],"variable":"--font-serif","display":"swap","weight":["400","500","600","700"]}],"variableName":"serif"} ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/47f136985ef5b5cb-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/4ead58c4dcc3f285-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/28a2004cf8372660-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/eaead17c7dbfcd5d-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/47f136985ef5b5cb-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/4ead58c4dcc3f285-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/28a2004cf8372660-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/eaead17c7dbfcd5d-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/47f136985ef5b5cb-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/4ead58c4dcc3f285-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/28a2004cf8372660-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/eaead17c7dbfcd5d-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/47f136985ef5b5cb-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/4ead58c4dcc3f285-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/28a2004cf8372660-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/eaead17c7dbfcd5d-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Playfair Display Fallback';src: local("Times New Roman");ascent-override: 97.25%;descent-override: 22.56%;line-gap-override: 0.00%;size-adjust: 111.26%
}.__className_4ad96d {font-family: 'Playfair Display', 'Playfair Display Fallback';font-style: normal
}.__variable_4ad96d {--font-serif: 'Playfair Display', 'Playfair Display Fallback'
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!../../node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!../../node_modules/next/font/google/target.css?{"path":"src/lib/fonts.ts","import":"Inter","arguments":[{"subsets":["latin","cyrillic"],"variable":"--font-sans","display":"swap"}],"variableName":"sans"} ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/ba9851c3c22cd980-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/21350d82a1f187e9-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/df0a9ae256c0569c-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/8e9860b6e62d6359-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Inter Fallback';src: local("Arial");ascent-override: 90.44%;descent-override: 22.52%;line-gap-override: 0.00%;size-adjust: 107.12%
}.__className_fcbcbf {font-family: 'Inter', 'Inter Fallback';font-style: normal
}.__variable_fcbcbf {--font-sans: 'Inter', 'Inter Fallback'
}

