/* === CSS: a-reset.css [root] === */
@font-face {
  font-family: "Varvetica";
  src: url("/fonts/Helvetica-Now-Var.ttf");
}
@font-face {
  font-family: "Lato";
  src: url("/fonts/Lato-Bold.ttf");
}
@font-face {
  font-family: "Chalkduster";
  src: url("/fonts/Chalkduster.ttf");
}

/* css clean up */

/* html, body { overflow-anchor: none; } */

.debug-spacer {
  height: 30rem;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  cursor: default;
}

.inpextra {
  position: fixed;
  left: -500vw;
  right: -500vw;
  opacity: 0;
  pointer-events: none;
}

a * {
  cursor: pointer;
}
a {
  text-decoration: unset;
  color: black;
}

.for-inner {
  position: relative;
  z-index: 0;
}
.for-inner * {
  z-index: 1;
  position: relative;
}

/* === CSS: b-root.css [root] === */
@font-face {
  font-family: "Cormorant Garamond";
  src: url("/fonts/CormorantGaramond-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cormorant Garamond";
  src: url("/fonts/CormorantGaramond-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cormorant Garamond";
  src: url("/fonts/CormorantGaramond-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cormorant Garamond";
  src: url("/fonts/CormorantGaramond-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src: url("/fonts/Montserrat-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src: url("/fonts/Montserrat-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src: url("/fonts/Montserrat-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Montserrat";
  src: url("/fonts/Montserrat-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #efe7dc;
  --bg-soft: #f6f1e9;
  --bg-warm: #e6dac9;
  --panel: rgba(255, 255, 255, 0.62);
  --panel-strong: rgba(255, 255, 255, 0.82);
  --text: #211a15;
  --muted: #5f5448;
  --line: rgba(33, 26, 21, 0.14);
  --accent: #d3b99a;
  --nav-rgb: 255, 255, 255;
  --nav-bg-alpha: 0;
  --nav-border-alpha: 0;
  --nav-blur: 0px;
  --nav-invert: 1;
  --nav-logo-scale: 2;
  --section-gap: 128px;
  --content-width: 1180px;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 108px;
}

body {
  margin: 0;
  background-color: var(--bg);
  color: var(--text);
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  line-height: 1.7;
  overflow-x: hidden;
}

body.menu-open {
  overflow: hidden;
}

* {
  box-sizing: border-box;
}

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

button,
input,
textarea {
  font: inherit;
}

.site-shell {
  position: relative;
  isolation: isolate;
}

.section {
  padding: var(--section-gap) 28px;
}

.section--coffee,
.section--impressions,
.section--contact {
  background-color: var(--bg-soft);
}

.section--events,
.section--about,
.section--events-page,
.section--legal {
  background-color: var(--bg);
}

.section__inner {
  width: min(var(--content-width), 100%);
  margin: 0 auto;
}

.section h2 {
  margin: 0 0 28px;
  font-family: "Cormorant Garamond", serif;
  font-size: 64px;
  font-weight: 600;
  line-height: 0.98;
  letter-spacing: 0.04em;
}

.section__lead {
  max-width: 720px;
  margin: 0 0 44px;
  color: var(--muted);
  font-size: 17px;
}

.subpage-main {
  min-height: 70vh;
}

.subpage-hero {
  padding: 180px 28px 64px;
  background-color: var(--bg-soft);
}

.subpage-back {
  display: inline-flex;
  align-items: center;
  margin: 0 0 22px;
  font-size: 12px;
  text-transform: uppercase;
}

.subpage-back::before {
  content: "←";
  margin-right: 10px;
  font-size: 14px;
  line-height: 1;
}

.subpage-hero h1 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 64px;
  font-weight: 600;
  line-height: 0.98;
  letter-spacing: 0.04em;
}

.section-kicker {
  margin: 0 0 16px;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.legal-copy p {
  margin: 0 0 16px;
}

.legal-copy h2,
.legal-copy h3,
.legal-copy h4 {
  margin: 32px 0 12px;
}

.legal-copy ul {
  margin: 0 0 18px 20px;
  padding: 0;
}

.legal-copy li + li {
  margin-top: 8px;
}

.events-empty {
  margin: 0;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* === CSS: c-sizing.css [root] === */
:root {
  --size-25: 0.25rem;
  --size-50: 0.50rem;
  --size-75: 0.75rem;
  --size-100: 1.00rem;
  --size-125: 1.25rem;
  --size-150: 1.50rem;
  --size-175: 1.75rem;
  --size-200: 2.00rem;
  --size-225: 2.25rem;
  --size-250: 2.50rem;
  --size-275: 2.75rem;
  --size-300: 3.00rem;
  --size-325: 3.25rem;
  --size-350: 3.50rem;
  --size-375: 3.75rem;
  --size-400: 4.00rem;
  --size-425: 4.25rem;
  --size-450: 4.50rem;
  --size-475: 4.75rem;
  --size-500: 5.00rem;
  --size-525: 5.25rem;
  --size-550: 5.50rem;
  --size-575: 5.75rem;
  --size-600: 6.00rem;
  --size-625: 6.25rem;
  --size-650: 6.50rem;
  --size-675: 6.75rem;
  --size-700: 7.00rem;
  --size-725: 7.25rem;
  --size-750: 7.50rem;
  --size-775: 7.75rem;
  --size-800: 8.00rem;
  --size-825: 8.25rem;
  --size-850: 8.50rem;
  --size-875: 8.75rem;
  --size-900: 9.00rem;
  --size-925: 9.25rem;
  --size-950: 9.50rem;
  --size-975: 9.75rem;
  --size-1000: 10.00rem;
}

.marg-25 { margin: var(--size-25); }
.marg-top-25 { margin-top: var(--size-25); }
.marg-bottom-25 { margin-bottom: var(--size-25); }
.marg-left-25 { margin-left: var(--size-25); }
.marg-right-25 { margin-right: var(--size-25); }
.marg-x-25 { margin-left: var(--size-25); margin-right: var(--size-25); }
.marg-y-25 { margin-top: var(--size-25); margin-bottom: var(--size-25); }
.marg-50 { margin: var(--size-50); }
.marg-top-50 { margin-top: var(--size-50); }
.marg-bottom-50 { margin-bottom: var(--size-50); }
.marg-left-50 { margin-left: var(--size-50); }
.marg-right-50 { margin-right: var(--size-50); }
.marg-x-50 { margin-left: var(--size-50); margin-right: var(--size-50); }
.marg-y-50 { margin-top: var(--size-50); margin-bottom: var(--size-50); }
.marg-75 { margin: var(--size-75); }
.marg-top-75 { margin-top: var(--size-75); }
.marg-bottom-75 { margin-bottom: var(--size-75); }
.marg-left-75 { margin-left: var(--size-75); }
.marg-right-75 { margin-right: var(--size-75); }
.marg-x-75 { margin-left: var(--size-75); margin-right: var(--size-75); }
.marg-y-75 { margin-top: var(--size-75); margin-bottom: var(--size-75); }
.marg-100 { margin: var(--size-100); }
.marg-top-100 { margin-top: var(--size-100); }
.marg-bottom-100 { margin-bottom: var(--size-100); }
.marg-left-100 { margin-left: var(--size-100); }
.marg-right-100 { margin-right: var(--size-100); }
.marg-x-100 { margin-left: var(--size-100); margin-right: var(--size-100); }
.marg-y-100 { margin-top: var(--size-100); margin-bottom: var(--size-100); }
.marg-125 { margin: var(--size-125); }
.marg-top-125 { margin-top: var(--size-125); }
.marg-bottom-125 { margin-bottom: var(--size-125); }
.marg-left-125 { margin-left: var(--size-125); }
.marg-right-125 { margin-right: var(--size-125); }
.marg-x-125 { margin-left: var(--size-125); margin-right: var(--size-125); }
.marg-y-125 { margin-top: var(--size-125); margin-bottom: var(--size-125); }
.marg-150 { margin: var(--size-150); }
.marg-top-150 { margin-top: var(--size-150); }
.marg-bottom-150 { margin-bottom: var(--size-150); }
.marg-left-150 { margin-left: var(--size-150); }
.marg-right-150 { margin-right: var(--size-150); }
.marg-x-150 { margin-left: var(--size-150); margin-right: var(--size-150); }
.marg-y-150 { margin-top: var(--size-150); margin-bottom: var(--size-150); }
.marg-175 { margin: var(--size-175); }
.marg-top-175 { margin-top: var(--size-175); }
.marg-bottom-175 { margin-bottom: var(--size-175); }
.marg-left-175 { margin-left: var(--size-175); }
.marg-right-175 { margin-right: var(--size-175); }
.marg-x-175 { margin-left: var(--size-175); margin-right: var(--size-175); }
.marg-y-175 { margin-top: var(--size-175); margin-bottom: var(--size-175); }
.marg-200 { margin: var(--size-200); }
.marg-top-200 { margin-top: var(--size-200); }
.marg-bottom-200 { margin-bottom: var(--size-200); }
.marg-left-200 { margin-left: var(--size-200); }
.marg-right-200 { margin-right: var(--size-200); }
.marg-x-200 { margin-left: var(--size-200); margin-right: var(--size-200); }
.marg-y-200 { margin-top: var(--size-200); margin-bottom: var(--size-200); }
.marg-225 { margin: var(--size-225); }
.marg-top-225 { margin-top: var(--size-225); }
.marg-bottom-225 { margin-bottom: var(--size-225); }
.marg-left-225 { margin-left: var(--size-225); }
.marg-right-225 { margin-right: var(--size-225); }
.marg-x-225 { margin-left: var(--size-225); margin-right: var(--size-225); }
.marg-y-225 { margin-top: var(--size-225); margin-bottom: var(--size-225); }
.marg-250 { margin: var(--size-250); }
.marg-top-250 { margin-top: var(--size-250); }
.marg-bottom-250 { margin-bottom: var(--size-250); }
.marg-left-250 { margin-left: var(--size-250); }
.marg-right-250 { margin-right: var(--size-250); }
.marg-x-250 { margin-left: var(--size-250); margin-right: var(--size-250); }
.marg-y-250 { margin-top: var(--size-250); margin-bottom: var(--size-250); }
.marg-275 { margin: var(--size-275); }
.marg-top-275 { margin-top: var(--size-275); }
.marg-bottom-275 { margin-bottom: var(--size-275); }
.marg-left-275 { margin-left: var(--size-275); }
.marg-right-275 { margin-right: var(--size-275); }
.marg-x-275 { margin-left: var(--size-275); margin-right: var(--size-275); }
.marg-y-275 { margin-top: var(--size-275); margin-bottom: var(--size-275); }
.marg-300 { margin: var(--size-300); }
.marg-top-300 { margin-top: var(--size-300); }
.marg-bottom-300 { margin-bottom: var(--size-300); }
.marg-left-300 { margin-left: var(--size-300); }
.marg-right-300 { margin-right: var(--size-300); }
.marg-x-300 { margin-left: var(--size-300); margin-right: var(--size-300); }
.marg-y-300 { margin-top: var(--size-300); margin-bottom: var(--size-300); }
.marg-325 { margin: var(--size-325); }
.marg-top-325 { margin-top: var(--size-325); }
.marg-bottom-325 { margin-bottom: var(--size-325); }
.marg-left-325 { margin-left: var(--size-325); }
.marg-right-325 { margin-right: var(--size-325); }
.marg-x-325 { margin-left: var(--size-325); margin-right: var(--size-325); }
.marg-y-325 { margin-top: var(--size-325); margin-bottom: var(--size-325); }
.marg-350 { margin: var(--size-350); }
.marg-top-350 { margin-top: var(--size-350); }
.marg-bottom-350 { margin-bottom: var(--size-350); }
.marg-left-350 { margin-left: var(--size-350); }
.marg-right-350 { margin-right: var(--size-350); }
.marg-x-350 { margin-left: var(--size-350); margin-right: var(--size-350); }
.marg-y-350 { margin-top: var(--size-350); margin-bottom: var(--size-350); }
.marg-375 { margin: var(--size-375); }
.marg-top-375 { margin-top: var(--size-375); }
.marg-bottom-375 { margin-bottom: var(--size-375); }
.marg-left-375 { margin-left: var(--size-375); }
.marg-right-375 { margin-right: var(--size-375); }
.marg-x-375 { margin-left: var(--size-375); margin-right: var(--size-375); }
.marg-y-375 { margin-top: var(--size-375); margin-bottom: var(--size-375); }
.marg-400 { margin: var(--size-400); }
.marg-top-400 { margin-top: var(--size-400); }
.marg-bottom-400 { margin-bottom: var(--size-400); }
.marg-left-400 { margin-left: var(--size-400); }
.marg-right-400 { margin-right: var(--size-400); }
.marg-x-400 { margin-left: var(--size-400); margin-right: var(--size-400); }
.marg-y-400 { margin-top: var(--size-400); margin-bottom: var(--size-400); }
.marg-425 { margin: var(--size-425); }
.marg-top-425 { margin-top: var(--size-425); }
.marg-bottom-425 { margin-bottom: var(--size-425); }
.marg-left-425 { margin-left: var(--size-425); }
.marg-right-425 { margin-right: var(--size-425); }
.marg-x-425 { margin-left: var(--size-425); margin-right: var(--size-425); }
.marg-y-425 { margin-top: var(--size-425); margin-bottom: var(--size-425); }
.marg-450 { margin: var(--size-450); }
.marg-top-450 { margin-top: var(--size-450); }
.marg-bottom-450 { margin-bottom: var(--size-450); }
.marg-left-450 { margin-left: var(--size-450); }
.marg-right-450 { margin-right: var(--size-450); }
.marg-x-450 { margin-left: var(--size-450); margin-right: var(--size-450); }
.marg-y-450 { margin-top: var(--size-450); margin-bottom: var(--size-450); }
.marg-475 { margin: var(--size-475); }
.marg-top-475 { margin-top: var(--size-475); }
.marg-bottom-475 { margin-bottom: var(--size-475); }
.marg-left-475 { margin-left: var(--size-475); }
.marg-right-475 { margin-right: var(--size-475); }
.marg-x-475 { margin-left: var(--size-475); margin-right: var(--size-475); }
.marg-y-475 { margin-top: var(--size-475); margin-bottom: var(--size-475); }
.marg-500 { margin: var(--size-500); }
.marg-top-500 { margin-top: var(--size-500); }
.marg-bottom-500 { margin-bottom: var(--size-500); }
.marg-left-500 { margin-left: var(--size-500); }
.marg-right-500 { margin-right: var(--size-500); }
.marg-x-500 { margin-left: var(--size-500); margin-right: var(--size-500); }
.marg-y-500 { margin-top: var(--size-500); margin-bottom: var(--size-500); }
.marg-525 { margin: var(--size-525); }
.marg-top-525 { margin-top: var(--size-525); }
.marg-bottom-525 { margin-bottom: var(--size-525); }
.marg-left-525 { margin-left: var(--size-525); }
.marg-right-525 { margin-right: var(--size-525); }
.marg-x-525 { margin-left: var(--size-525); margin-right: var(--size-525); }
.marg-y-525 { margin-top: var(--size-525); margin-bottom: var(--size-525); }
.marg-550 { margin: var(--size-550); }
.marg-top-550 { margin-top: var(--size-550); }
.marg-bottom-550 { margin-bottom: var(--size-550); }
.marg-left-550 { margin-left: var(--size-550); }
.marg-right-550 { margin-right: var(--size-550); }
.marg-x-550 { margin-left: var(--size-550); margin-right: var(--size-550); }
.marg-y-550 { margin-top: var(--size-550); margin-bottom: var(--size-550); }
.marg-575 { margin: var(--size-575); }
.marg-top-575 { margin-top: var(--size-575); }
.marg-bottom-575 { margin-bottom: var(--size-575); }
.marg-left-575 { margin-left: var(--size-575); }
.marg-right-575 { margin-right: var(--size-575); }
.marg-x-575 { margin-left: var(--size-575); margin-right: var(--size-575); }
.marg-y-575 { margin-top: var(--size-575); margin-bottom: var(--size-575); }
.marg-600 { margin: var(--size-600); }
.marg-top-600 { margin-top: var(--size-600); }
.marg-bottom-600 { margin-bottom: var(--size-600); }
.marg-left-600 { margin-left: var(--size-600); }
.marg-right-600 { margin-right: var(--size-600); }
.marg-x-600 { margin-left: var(--size-600); margin-right: var(--size-600); }
.marg-y-600 { margin-top: var(--size-600); margin-bottom: var(--size-600); }
.marg-625 { margin: var(--size-625); }
.marg-top-625 { margin-top: var(--size-625); }
.marg-bottom-625 { margin-bottom: var(--size-625); }
.marg-left-625 { margin-left: var(--size-625); }
.marg-right-625 { margin-right: var(--size-625); }
.marg-x-625 { margin-left: var(--size-625); margin-right: var(--size-625); }
.marg-y-625 { margin-top: var(--size-625); margin-bottom: var(--size-625); }
.marg-650 { margin: var(--size-650); }
.marg-top-650 { margin-top: var(--size-650); }
.marg-bottom-650 { margin-bottom: var(--size-650); }
.marg-left-650 { margin-left: var(--size-650); }
.marg-right-650 { margin-right: var(--size-650); }
.marg-x-650 { margin-left: var(--size-650); margin-right: var(--size-650); }
.marg-y-650 { margin-top: var(--size-650); margin-bottom: var(--size-650); }
.marg-675 { margin: var(--size-675); }
.marg-top-675 { margin-top: var(--size-675); }
.marg-bottom-675 { margin-bottom: var(--size-675); }
.marg-left-675 { margin-left: var(--size-675); }
.marg-right-675 { margin-right: var(--size-675); }
.marg-x-675 { margin-left: var(--size-675); margin-right: var(--size-675); }
.marg-y-675 { margin-top: var(--size-675); margin-bottom: var(--size-675); }
.marg-700 { margin: var(--size-700); }
.marg-top-700 { margin-top: var(--size-700); }
.marg-bottom-700 { margin-bottom: var(--size-700); }
.marg-left-700 { margin-left: var(--size-700); }
.marg-right-700 { margin-right: var(--size-700); }
.marg-x-700 { margin-left: var(--size-700); margin-right: var(--size-700); }
.marg-y-700 { margin-top: var(--size-700); margin-bottom: var(--size-700); }
.marg-725 { margin: var(--size-725); }
.marg-top-725 { margin-top: var(--size-725); }
.marg-bottom-725 { margin-bottom: var(--size-725); }
.marg-left-725 { margin-left: var(--size-725); }
.marg-right-725 { margin-right: var(--size-725); }
.marg-x-725 { margin-left: var(--size-725); margin-right: var(--size-725); }
.marg-y-725 { margin-top: var(--size-725); margin-bottom: var(--size-725); }
.marg-750 { margin: var(--size-750); }
.marg-top-750 { margin-top: var(--size-750); }
.marg-bottom-750 { margin-bottom: var(--size-750); }
.marg-left-750 { margin-left: var(--size-750); }
.marg-right-750 { margin-right: var(--size-750); }
.marg-x-750 { margin-left: var(--size-750); margin-right: var(--size-750); }
.marg-y-750 { margin-top: var(--size-750); margin-bottom: var(--size-750); }
.marg-775 { margin: var(--size-775); }
.marg-top-775 { margin-top: var(--size-775); }
.marg-bottom-775 { margin-bottom: var(--size-775); }
.marg-left-775 { margin-left: var(--size-775); }
.marg-right-775 { margin-right: var(--size-775); }
.marg-x-775 { margin-left: var(--size-775); margin-right: var(--size-775); }
.marg-y-775 { margin-top: var(--size-775); margin-bottom: var(--size-775); }
.marg-800 { margin: var(--size-800); }
.marg-top-800 { margin-top: var(--size-800); }
.marg-bottom-800 { margin-bottom: var(--size-800); }
.marg-left-800 { margin-left: var(--size-800); }
.marg-right-800 { margin-right: var(--size-800); }
.marg-x-800 { margin-left: var(--size-800); margin-right: var(--size-800); }
.marg-y-800 { margin-top: var(--size-800); margin-bottom: var(--size-800); }
.marg-825 { margin: var(--size-825); }
.marg-top-825 { margin-top: var(--size-825); }
.marg-bottom-825 { margin-bottom: var(--size-825); }
.marg-left-825 { margin-left: var(--size-825); }
.marg-right-825 { margin-right: var(--size-825); }
.marg-x-825 { margin-left: var(--size-825); margin-right: var(--size-825); }
.marg-y-825 { margin-top: var(--size-825); margin-bottom: var(--size-825); }
.marg-850 { margin: var(--size-850); }
.marg-top-850 { margin-top: var(--size-850); }
.marg-bottom-850 { margin-bottom: var(--size-850); }
.marg-left-850 { margin-left: var(--size-850); }
.marg-right-850 { margin-right: var(--size-850); }
.marg-x-850 { margin-left: var(--size-850); margin-right: var(--size-850); }
.marg-y-850 { margin-top: var(--size-850); margin-bottom: var(--size-850); }
.marg-875 { margin: var(--size-875); }
.marg-top-875 { margin-top: var(--size-875); }
.marg-bottom-875 { margin-bottom: var(--size-875); }
.marg-left-875 { margin-left: var(--size-875); }
.marg-right-875 { margin-right: var(--size-875); }
.marg-x-875 { margin-left: var(--size-875); margin-right: var(--size-875); }
.marg-y-875 { margin-top: var(--size-875); margin-bottom: var(--size-875); }
.marg-900 { margin: var(--size-900); }
.marg-top-900 { margin-top: var(--size-900); }
.marg-bottom-900 { margin-bottom: var(--size-900); }
.marg-left-900 { margin-left: var(--size-900); }
.marg-right-900 { margin-right: var(--size-900); }
.marg-x-900 { margin-left: var(--size-900); margin-right: var(--size-900); }
.marg-y-900 { margin-top: var(--size-900); margin-bottom: var(--size-900); }
.marg-925 { margin: var(--size-925); }
.marg-top-925 { margin-top: var(--size-925); }
.marg-bottom-925 { margin-bottom: var(--size-925); }
.marg-left-925 { margin-left: var(--size-925); }
.marg-right-925 { margin-right: var(--size-925); }
.marg-x-925 { margin-left: var(--size-925); margin-right: var(--size-925); }
.marg-y-925 { margin-top: var(--size-925); margin-bottom: var(--size-925); }
.marg-950 { margin: var(--size-950); }
.marg-top-950 { margin-top: var(--size-950); }
.marg-bottom-950 { margin-bottom: var(--size-950); }
.marg-left-950 { margin-left: var(--size-950); }
.marg-right-950 { margin-right: var(--size-950); }
.marg-x-950 { margin-left: var(--size-950); margin-right: var(--size-950); }
.marg-y-950 { margin-top: var(--size-950); margin-bottom: var(--size-950); }
.marg-975 { margin: var(--size-975); }
.marg-top-975 { margin-top: var(--size-975); }
.marg-bottom-975 { margin-bottom: var(--size-975); }
.marg-left-975 { margin-left: var(--size-975); }
.marg-right-975 { margin-right: var(--size-975); }
.marg-x-975 { margin-left: var(--size-975); margin-right: var(--size-975); }
.marg-y-975 { margin-top: var(--size-975); margin-bottom: var(--size-975); }
.marg-1000 { margin: var(--size-1000); }
.marg-top-1000 { margin-top: var(--size-1000); }
.marg-bottom-1000 { margin-bottom: var(--size-1000); }
.marg-left-1000 { margin-left: var(--size-1000); }
.marg-right-1000 { margin-right: var(--size-1000); }
.marg-x-1000 { margin-left: var(--size-1000); margin-right: var(--size-1000); }
.marg-y-1000 { margin-top: var(--size-1000); margin-bottom: var(--size-1000); }
.pad-25 { padding: var(--size-25); }
.pad-top-25 { padding-top: var(--size-25); }
.pad-bottom-25 { padding-bottom: var(--size-25); }
.pad-left-25 { padding-left: var(--size-25); }
.pad-right-25 { padding-right: var(--size-25); }
.pad-x-25 { padding-left: var(--size-25); padding-right: var(--size-25); }
.pad-y-25 { padding-top: var(--size-25); padding-bottom: var(--size-25); }
.pad-50 { padding: var(--size-50); }
.pad-top-50 { padding-top: var(--size-50); }
.pad-bottom-50 { padding-bottom: var(--size-50); }
.pad-left-50 { padding-left: var(--size-50); }
.pad-right-50 { padding-right: var(--size-50); }
.pad-x-50 { padding-left: var(--size-50); padding-right: var(--size-50); }
.pad-y-50 { padding-top: var(--size-50); padding-bottom: var(--size-50); }
.pad-75 { padding: var(--size-75); }
.pad-top-75 { padding-top: var(--size-75); }
.pad-bottom-75 { padding-bottom: var(--size-75); }
.pad-left-75 { padding-left: var(--size-75); }
.pad-right-75 { padding-right: var(--size-75); }
.pad-x-75 { padding-left: var(--size-75); padding-right: var(--size-75); }
.pad-y-75 { padding-top: var(--size-75); padding-bottom: var(--size-75); }
.pad-100 { padding: var(--size-100); }
.pad-top-100 { padding-top: var(--size-100); }
.pad-bottom-100 { padding-bottom: var(--size-100); }
.pad-left-100 { padding-left: var(--size-100); }
.pad-right-100 { padding-right: var(--size-100); }
.pad-x-100 { padding-left: var(--size-100); padding-right: var(--size-100); }
.pad-y-100 { padding-top: var(--size-100); padding-bottom: var(--size-100); }
.pad-125 { padding: var(--size-125); }
.pad-top-125 { padding-top: var(--size-125); }
.pad-bottom-125 { padding-bottom: var(--size-125); }
.pad-left-125 { padding-left: var(--size-125); }
.pad-right-125 { padding-right: var(--size-125); }
.pad-x-125 { padding-left: var(--size-125); padding-right: var(--size-125); }
.pad-y-125 { padding-top: var(--size-125); padding-bottom: var(--size-125); }
.pad-150 { padding: var(--size-150); }
.pad-top-150 { padding-top: var(--size-150); }
.pad-bottom-150 { padding-bottom: var(--size-150); }
.pad-left-150 { padding-left: var(--size-150); }
.pad-right-150 { padding-right: var(--size-150); }
.pad-x-150 { padding-left: var(--size-150); padding-right: var(--size-150); }
.pad-y-150 { padding-top: var(--size-150); padding-bottom: var(--size-150); }
.pad-175 { padding: var(--size-175); }
.pad-top-175 { padding-top: var(--size-175); }
.pad-bottom-175 { padding-bottom: var(--size-175); }
.pad-left-175 { padding-left: var(--size-175); }
.pad-right-175 { padding-right: var(--size-175); }
.pad-x-175 { padding-left: var(--size-175); padding-right: var(--size-175); }
.pad-y-175 { padding-top: var(--size-175); padding-bottom: var(--size-175); }
.pad-200 { padding: var(--size-200); }
.pad-top-200 { padding-top: var(--size-200); }
.pad-bottom-200 { padding-bottom: var(--size-200); }
.pad-left-200 { padding-left: var(--size-200); }
.pad-right-200 { padding-right: var(--size-200); }
.pad-x-200 { padding-left: var(--size-200); padding-right: var(--size-200); }
.pad-y-200 { padding-top: var(--size-200); padding-bottom: var(--size-200); }
.pad-225 { padding: var(--size-225); }
.pad-top-225 { padding-top: var(--size-225); }
.pad-bottom-225 { padding-bottom: var(--size-225); }
.pad-left-225 { padding-left: var(--size-225); }
.pad-right-225 { padding-right: var(--size-225); }
.pad-x-225 { padding-left: var(--size-225); padding-right: var(--size-225); }
.pad-y-225 { padding-top: var(--size-225); padding-bottom: var(--size-225); }
.pad-250 { padding: var(--size-250); }
.pad-top-250 { padding-top: var(--size-250); }
.pad-bottom-250 { padding-bottom: var(--size-250); }
.pad-left-250 { padding-left: var(--size-250); }
.pad-right-250 { padding-right: var(--size-250); }
.pad-x-250 { padding-left: var(--size-250); padding-right: var(--size-250); }
.pad-y-250 { padding-top: var(--size-250); padding-bottom: var(--size-250); }
.pad-275 { padding: var(--size-275); }
.pad-top-275 { padding-top: var(--size-275); }
.pad-bottom-275 { padding-bottom: var(--size-275); }
.pad-left-275 { padding-left: var(--size-275); }
.pad-right-275 { padding-right: var(--size-275); }
.pad-x-275 { padding-left: var(--size-275); padding-right: var(--size-275); }
.pad-y-275 { padding-top: var(--size-275); padding-bottom: var(--size-275); }
.pad-300 { padding: var(--size-300); }
.pad-top-300 { padding-top: var(--size-300); }
.pad-bottom-300 { padding-bottom: var(--size-300); }
.pad-left-300 { padding-left: var(--size-300); }
.pad-right-300 { padding-right: var(--size-300); }
.pad-x-300 { padding-left: var(--size-300); padding-right: var(--size-300); }
.pad-y-300 { padding-top: var(--size-300); padding-bottom: var(--size-300); }
.pad-325 { padding: var(--size-325); }
.pad-top-325 { padding-top: var(--size-325); }
.pad-bottom-325 { padding-bottom: var(--size-325); }
.pad-left-325 { padding-left: var(--size-325); }
.pad-right-325 { padding-right: var(--size-325); }
.pad-x-325 { padding-left: var(--size-325); padding-right: var(--size-325); }
.pad-y-325 { padding-top: var(--size-325); padding-bottom: var(--size-325); }
.pad-350 { padding: var(--size-350); }
.pad-top-350 { padding-top: var(--size-350); }
.pad-bottom-350 { padding-bottom: var(--size-350); }
.pad-left-350 { padding-left: var(--size-350); }
.pad-right-350 { padding-right: var(--size-350); }
.pad-x-350 { padding-left: var(--size-350); padding-right: var(--size-350); }
.pad-y-350 { padding-top: var(--size-350); padding-bottom: var(--size-350); }
.pad-375 { padding: var(--size-375); }
.pad-top-375 { padding-top: var(--size-375); }
.pad-bottom-375 { padding-bottom: var(--size-375); }
.pad-left-375 { padding-left: var(--size-375); }
.pad-right-375 { padding-right: var(--size-375); }
.pad-x-375 { padding-left: var(--size-375); padding-right: var(--size-375); }
.pad-y-375 { padding-top: var(--size-375); padding-bottom: var(--size-375); }
.pad-400 { padding: var(--size-400); }
.pad-top-400 { padding-top: var(--size-400); }
.pad-bottom-400 { padding-bottom: var(--size-400); }
.pad-left-400 { padding-left: var(--size-400); }
.pad-right-400 { padding-right: var(--size-400); }
.pad-x-400 { padding-left: var(--size-400); padding-right: var(--size-400); }
.pad-y-400 { padding-top: var(--size-400); padding-bottom: var(--size-400); }
.pad-425 { padding: var(--size-425); }
.pad-top-425 { padding-top: var(--size-425); }
.pad-bottom-425 { padding-bottom: var(--size-425); }
.pad-left-425 { padding-left: var(--size-425); }
.pad-right-425 { padding-right: var(--size-425); }
.pad-x-425 { padding-left: var(--size-425); padding-right: var(--size-425); }
.pad-y-425 { padding-top: var(--size-425); padding-bottom: var(--size-425); }
.pad-450 { padding: var(--size-450); }
.pad-top-450 { padding-top: var(--size-450); }
.pad-bottom-450 { padding-bottom: var(--size-450); }
.pad-left-450 { padding-left: var(--size-450); }
.pad-right-450 { padding-right: var(--size-450); }
.pad-x-450 { padding-left: var(--size-450); padding-right: var(--size-450); }
.pad-y-450 { padding-top: var(--size-450); padding-bottom: var(--size-450); }
.pad-475 { padding: var(--size-475); }
.pad-top-475 { padding-top: var(--size-475); }
.pad-bottom-475 { padding-bottom: var(--size-475); }
.pad-left-475 { padding-left: var(--size-475); }
.pad-right-475 { padding-right: var(--size-475); }
.pad-x-475 { padding-left: var(--size-475); padding-right: var(--size-475); }
.pad-y-475 { padding-top: var(--size-475); padding-bottom: var(--size-475); }
.pad-500 { padding: var(--size-500); }
.pad-top-500 { padding-top: var(--size-500); }
.pad-bottom-500 { padding-bottom: var(--size-500); }
.pad-left-500 { padding-left: var(--size-500); }
.pad-right-500 { padding-right: var(--size-500); }
.pad-x-500 { padding-left: var(--size-500); padding-right: var(--size-500); }
.pad-y-500 { padding-top: var(--size-500); padding-bottom: var(--size-500); }
.pad-525 { padding: var(--size-525); }
.pad-top-525 { padding-top: var(--size-525); }
.pad-bottom-525 { padding-bottom: var(--size-525); }
.pad-left-525 { padding-left: var(--size-525); }
.pad-right-525 { padding-right: var(--size-525); }
.pad-x-525 { padding-left: var(--size-525); padding-right: var(--size-525); }
.pad-y-525 { padding-top: var(--size-525); padding-bottom: var(--size-525); }
.pad-550 { padding: var(--size-550); }
.pad-top-550 { padding-top: var(--size-550); }
.pad-bottom-550 { padding-bottom: var(--size-550); }
.pad-left-550 { padding-left: var(--size-550); }
.pad-right-550 { padding-right: var(--size-550); }
.pad-x-550 { padding-left: var(--size-550); padding-right: var(--size-550); }
.pad-y-550 { padding-top: var(--size-550); padding-bottom: var(--size-550); }
.pad-575 { padding: var(--size-575); }
.pad-top-575 { padding-top: var(--size-575); }
.pad-bottom-575 { padding-bottom: var(--size-575); }
.pad-left-575 { padding-left: var(--size-575); }
.pad-right-575 { padding-right: var(--size-575); }
.pad-x-575 { padding-left: var(--size-575); padding-right: var(--size-575); }
.pad-y-575 { padding-top: var(--size-575); padding-bottom: var(--size-575); }
.pad-600 { padding: var(--size-600); }
.pad-top-600 { padding-top: var(--size-600); }
.pad-bottom-600 { padding-bottom: var(--size-600); }
.pad-left-600 { padding-left: var(--size-600); }
.pad-right-600 { padding-right: var(--size-600); }
.pad-x-600 { padding-left: var(--size-600); padding-right: var(--size-600); }
.pad-y-600 { padding-top: var(--size-600); padding-bottom: var(--size-600); }
.pad-625 { padding: var(--size-625); }
.pad-top-625 { padding-top: var(--size-625); }
.pad-bottom-625 { padding-bottom: var(--size-625); }
.pad-left-625 { padding-left: var(--size-625); }
.pad-right-625 { padding-right: var(--size-625); }
.pad-x-625 { padding-left: var(--size-625); padding-right: var(--size-625); }
.pad-y-625 { padding-top: var(--size-625); padding-bottom: var(--size-625); }
.pad-650 { padding: var(--size-650); }
.pad-top-650 { padding-top: var(--size-650); }
.pad-bottom-650 { padding-bottom: var(--size-650); }
.pad-left-650 { padding-left: var(--size-650); }
.pad-right-650 { padding-right: var(--size-650); }
.pad-x-650 { padding-left: var(--size-650); padding-right: var(--size-650); }
.pad-y-650 { padding-top: var(--size-650); padding-bottom: var(--size-650); }
.pad-675 { padding: var(--size-675); }
.pad-top-675 { padding-top: var(--size-675); }
.pad-bottom-675 { padding-bottom: var(--size-675); }
.pad-left-675 { padding-left: var(--size-675); }
.pad-right-675 { padding-right: var(--size-675); }
.pad-x-675 { padding-left: var(--size-675); padding-right: var(--size-675); }
.pad-y-675 { padding-top: var(--size-675); padding-bottom: var(--size-675); }
.pad-700 { padding: var(--size-700); }
.pad-top-700 { padding-top: var(--size-700); }
.pad-bottom-700 { padding-bottom: var(--size-700); }
.pad-left-700 { padding-left: var(--size-700); }
.pad-right-700 { padding-right: var(--size-700); }
.pad-x-700 { padding-left: var(--size-700); padding-right: var(--size-700); }
.pad-y-700 { padding-top: var(--size-700); padding-bottom: var(--size-700); }
.pad-725 { padding: var(--size-725); }
.pad-top-725 { padding-top: var(--size-725); }
.pad-bottom-725 { padding-bottom: var(--size-725); }
.pad-left-725 { padding-left: var(--size-725); }
.pad-right-725 { padding-right: var(--size-725); }
.pad-x-725 { padding-left: var(--size-725); padding-right: var(--size-725); }
.pad-y-725 { padding-top: var(--size-725); padding-bottom: var(--size-725); }
.pad-750 { padding: var(--size-750); }
.pad-top-750 { padding-top: var(--size-750); }
.pad-bottom-750 { padding-bottom: var(--size-750); }
.pad-left-750 { padding-left: var(--size-750); }
.pad-right-750 { padding-right: var(--size-750); }
.pad-x-750 { padding-left: var(--size-750); padding-right: var(--size-750); }
.pad-y-750 { padding-top: var(--size-750); padding-bottom: var(--size-750); }
.pad-775 { padding: var(--size-775); }
.pad-top-775 { padding-top: var(--size-775); }
.pad-bottom-775 { padding-bottom: var(--size-775); }
.pad-left-775 { padding-left: var(--size-775); }
.pad-right-775 { padding-right: var(--size-775); }
.pad-x-775 { padding-left: var(--size-775); padding-right: var(--size-775); }
.pad-y-775 { padding-top: var(--size-775); padding-bottom: var(--size-775); }
.pad-800 { padding: var(--size-800); }
.pad-top-800 { padding-top: var(--size-800); }
.pad-bottom-800 { padding-bottom: var(--size-800); }
.pad-left-800 { padding-left: var(--size-800); }
.pad-right-800 { padding-right: var(--size-800); }
.pad-x-800 { padding-left: var(--size-800); padding-right: var(--size-800); }
.pad-y-800 { padding-top: var(--size-800); padding-bottom: var(--size-800); }
.pad-825 { padding: var(--size-825); }
.pad-top-825 { padding-top: var(--size-825); }
.pad-bottom-825 { padding-bottom: var(--size-825); }
.pad-left-825 { padding-left: var(--size-825); }
.pad-right-825 { padding-right: var(--size-825); }
.pad-x-825 { padding-left: var(--size-825); padding-right: var(--size-825); }
.pad-y-825 { padding-top: var(--size-825); padding-bottom: var(--size-825); }
.pad-850 { padding: var(--size-850); }
.pad-top-850 { padding-top: var(--size-850); }
.pad-bottom-850 { padding-bottom: var(--size-850); }
.pad-left-850 { padding-left: var(--size-850); }
.pad-right-850 { padding-right: var(--size-850); }
.pad-x-850 { padding-left: var(--size-850); padding-right: var(--size-850); }
.pad-y-850 { padding-top: var(--size-850); padding-bottom: var(--size-850); }
.pad-875 { padding: var(--size-875); }
.pad-top-875 { padding-top: var(--size-875); }
.pad-bottom-875 { padding-bottom: var(--size-875); }
.pad-left-875 { padding-left: var(--size-875); }
.pad-right-875 { padding-right: var(--size-875); }
.pad-x-875 { padding-left: var(--size-875); padding-right: var(--size-875); }
.pad-y-875 { padding-top: var(--size-875); padding-bottom: var(--size-875); }
.pad-900 { padding: var(--size-900); }
.pad-top-900 { padding-top: var(--size-900); }
.pad-bottom-900 { padding-bottom: var(--size-900); }
.pad-left-900 { padding-left: var(--size-900); }
.pad-right-900 { padding-right: var(--size-900); }
.pad-x-900 { padding-left: var(--size-900); padding-right: var(--size-900); }
.pad-y-900 { padding-top: var(--size-900); padding-bottom: var(--size-900); }
.pad-925 { padding: var(--size-925); }
.pad-top-925 { padding-top: var(--size-925); }
.pad-bottom-925 { padding-bottom: var(--size-925); }
.pad-left-925 { padding-left: var(--size-925); }
.pad-right-925 { padding-right: var(--size-925); }
.pad-x-925 { padding-left: var(--size-925); padding-right: var(--size-925); }
.pad-y-925 { padding-top: var(--size-925); padding-bottom: var(--size-925); }
.pad-950 { padding: var(--size-950); }
.pad-top-950 { padding-top: var(--size-950); }
.pad-bottom-950 { padding-bottom: var(--size-950); }
.pad-left-950 { padding-left: var(--size-950); }
.pad-right-950 { padding-right: var(--size-950); }
.pad-x-950 { padding-left: var(--size-950); padding-right: var(--size-950); }
.pad-y-950 { padding-top: var(--size-950); padding-bottom: var(--size-950); }
.pad-975 { padding: var(--size-975); }
.pad-top-975 { padding-top: var(--size-975); }
.pad-bottom-975 { padding-bottom: var(--size-975); }
.pad-left-975 { padding-left: var(--size-975); }
.pad-right-975 { padding-right: var(--size-975); }
.pad-x-975 { padding-left: var(--size-975); padding-right: var(--size-975); }
.pad-y-975 { padding-top: var(--size-975); padding-bottom: var(--size-975); }
.pad-1000 { padding: var(--size-1000); }
.pad-top-1000 { padding-top: var(--size-1000); }
.pad-bottom-1000 { padding-bottom: var(--size-1000); }
.pad-left-1000 { padding-left: var(--size-1000); }
.pad-right-1000 { padding-right: var(--size-1000); }
.pad-x-1000 { padding-left: var(--size-1000); padding-right: var(--size-1000); }
.pad-y-1000 { padding-top: var(--size-1000); padding-bottom: var(--size-1000); }



.height-300 {
  height: 3rem;
}
.height-500 {
  height: 5rem;
}
/* === CSS: d-buttons.css [root] === */
.site-nav__brand,
.site-nav__link,
.site-nav__toggle,
.hero__more,
.button-primary,
.button-link,
.subpage-back,
.contact-info__link,
.legal-trigger {
  cursor: pointer;
}

.button-primary,
.button-link,
.hero__more,
.subpage-back {
  --button-fill: currentColor;
  --button-hover-text: currentColor;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--button-fill);
  background-color: transparent;
  color: inherit;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  padding: 0 24px;
  min-height: 52px;
  overflow: hidden;
  text-align: center;
  transition: color 260ms ease, border-color 260ms ease;
}

.button-primary::before,
.hero__more::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--button-fill);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 320ms ease;
  z-index: 0;
}

.button-primary span,
.hero__more span {
  position: relative;
  z-index: 1;
}

.button-primary:hover::before,
.button-primary:focus-visible::before,
.hero__more:hover::before,
.hero__more:focus-visible::before {
  transform: scaleX(1);
}

.button-primary:hover,
.button-primary:focus-visible,
.hero__more:hover,
.hero__more:focus-visible {
  color: var(--button-hover-text);
}

.button-primary--light,
.hero__more {
  backdrop-filter: blur(10px);
  --button-fill: #ffffff;
  --button-hover-text: #1e1711;
}

.button-primary--dark {
  backdrop-filter: blur(10px);
  --button-fill: #1e1711;
  --button-hover-text: #f8f4ee;
}

.button-link {
  border: 0;
  padding: 0 0 1px;
  min-height: auto;
  letter-spacing: 0.14em;
}

.subpage-back {
  border: 0;
  padding: 0 0 1px;
  min-height: auto;
  letter-spacing: 0.14em;
}

.button-link::after,
.subpage-back::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 280ms ease, opacity 280ms ease;
}

.button-link:hover::after,
.button-link:focus-visible::after,
.subpage-back:hover::after,
.subpage-back:focus-visible::after {
  transform: scaleX(1);
  opacity: 1;
}

.legal-trigger {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background-color: transparent;
  color: inherit;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  padding: 0 0 1px;
  min-height: auto;
  transition: color 260ms ease;
}

.legal-trigger::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 280ms ease, opacity 280ms ease;
}

.legal-trigger:hover::after,
.legal-trigger:focus-visible::after {
  transform: scaleX(1);
  opacity: 1;
}

.webdesign-by::after {
  height: 2px;
}

.webdesign-by {
  text-align: center;
  text-transform: none;
  font-size: 13px;
  width: fit-content;
  align-self: center;
}

/* === CSS: h-footer.css [root] === */
.site-footer {
  border-top: 1px solid rgba(33, 26, 21, 0.12);
  padding: 28px 28px 12px 28px;
  background-color: #ede4d8;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.site-footer__inner {
  width: min(var(--content-width), 100%);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.site-footer__brand {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 12px;
}

.site-footer__logo {
  width: 56px;
  height: 56px;
  object-fit: contain;
}

.site-footer__links {
  display: flex;
  gap: 22px;
  align-items: center;
}

/* .site-footer__links a:hover {
  opacity: 0.5;
} */

/* === CSS: h-forms.css [root] === */
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 34px;
  align-items: start;
}

.contact-panel,
.contact-info {
  border: 1px solid var(--line);
  background-color: var(--panel);
  padding: 34px;
}

.contact-panel h3,
.contact-info h3 {
  margin: 0 0 22px;
  font-family: "Cormorant Garamond", serif;
  font-size: 40px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.04em;
}

.contact-form {
  position: relative;
  display: grid;
  gap: 16px;
}

#contact-form-wrap {
  position: relative;
}

.contact-form__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.contact-form__row--phone {
  grid-template-columns: 120px minmax(0, 1fr);
}

.field {
  display: grid;
  gap: 8px;
}

.field label {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.field__required {
  color: #8f1f1f;
}

.field input,
.field textarea {
  width: 100%;
  border: 1px solid rgba(33, 26, 21, 0.2);
  background-color: rgba(255, 255, 255, 0.74);
  padding: 14px 16px;
  color: var(--text);
  outline: none;
  transition: border-color 220ms ease, background-color 220ms ease;
  border-radius: 0;
}

.field textarea {
  resize: vertical;
  max-height: 20rem;
  min-height: 5rem;
}

.contact-form__actions {
  margin-top: 6px;
}

.contact-form__submit {
  min-width: 238px;
}

.contact-form.is-sending .field input,
.contact-form.is-sending .field textarea,
.contact-form.is-sending .field select {
  background-color: rgba(120, 120, 120, 0.16);
  color: rgba(35, 29, 24, 0.62);
  border-color: rgba(33, 26, 21, 0.12);
  pointer-events: none;
  box-shadow: none;
  opacity: 1;
}

.contact-form.is-sending .field label {
  opacity: 0.72;
}

.contact-form.is-sending .contact-form__submit {
  pointer-events: none;
}

.contact-form__submit.is-sending::before {
  transform: scaleX(0);
  transform-origin: left center;
  animation: contact-send-progress 2.35s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.contact-form__submit.is-sending span {
  opacity: 0.96;
}

@keyframes contact-send-progress {
  0% {
    transform: scaleX(1);
    transform-origin: right center;
  }
  18% {
    transform: scaleX(0);
    transform-origin: right center;
  }
  19% {
    transform: scaleX(0);
    transform-origin: left center;
  }
  100% {
    transform: scaleX(1);
    transform-origin: left center;
  }
}

.field input:focus,
.field textarea:focus {
  border-color: rgba(33, 26, 21, 0.52);
  background-color: rgba(255, 255, 255, 0.9);
}

.contact-info__stack {
  display: grid;
  gap: 16px;
  margin-bottom: 30px;
}

.contact-info__owner {
  margin: -8px 0 11px;
  font-family: "Cormorant Garamond", serif;
  font-size: 24px;
  line-height: 1;
  letter-spacing: 0.03em;
}

.contact-info__item {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 32px;
}

.contact-info__icon {
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.contact-info__link {
  position: relative;
  display: inline-flex;
  padding-bottom: 1px;
}

.contact-info__link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  /* opacity: 0; */
  transition: transform 280ms ease, opacity 280ms ease;
}

.contact-info__link:hover::after,
.contact-info__link:focus-visible::after {
  transform: scaleX(1);
  opacity: 1;
}

.form-message {
  padding: 16px 18px;
  margin: 0;
  border: 1px solid transparent;
}

.form-message--success {
  background: #ecf8f1;
  color: #1a6b42;
  border-color: rgba(26, 107, 66, 0.18);
}

.form-message--info {
  background: #fff7e5;
  color: #7a5d0a;
  border-color: rgba(122, 93, 10, 0.15);
}

.form-message--error {
  background: #fdeaea;
  color: #a11313;
  border-color: rgba(161, 19, 19, 0.14);
}

.contact-form__feedback {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -4rem;
  transform: translateY(100%);
  pointer-events: none;
  z-index: 2;
}

.contact-form__feedback:empty {
  display: none;
}

.inpextra {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

/* === CSS: h-hero.css [root] === */
.hero {
  position: relative;
  min-height: 100vh;
  background-color: #18120d;
  color: #fff;
  display: grid;
  align-items: stretch;
  overflow: hidden;
}

.hero__media {
  position: absolute;
  inset: 0;
}

.hero__layer {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 900ms ease;
  will-change: opacity;
}

.hero__layer.is-visible {
  opacity: 1;
}

.hero__shade {
  position: absolute;
  inset: 0;
  background-color: rgba(16, 12, 9, 0.6);
}

.hero__content {
  position: relative;
  z-index: 1;
  width: min(1240px, calc(100vw - 56px));
  margin: 0 auto;
  padding: 160px 0 120px;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  min-height: 100vh;
}

.hero__text {
  max-width: 640px;
  align-self: center;
}

.hero h1 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 88px;
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: 0.03em;
}

.hero p {
  margin: 22px 0 0;
  max-width: 540px;
  font-size: 17px;
  color: rgba(255, 255, 255, 0.88);
}

.hero__actions {
  margin-top: 42px;
  display: flex;
  align-items: center;
  gap: 18px;
}

.hero__more-wrap {
  position: absolute;
  width: 100%;
  bottom: 3rem;
  padding-top: 56px;
  display: flex;
  pointer-events: none;
  justify-content: center;
  align-self: end;
}

.hero__more {
  color: #fff;
  pointer-events: all;
  min-width: 148px;
}

/* === CSS: h-nav.css [root] === */
.site-nav {
  position: fixed;
  top: 22px;
  left: 0;
  width: 100%;
  z-index: 40;
  padding: 0 28px;
  pointer-events: none;
}

.site-nav__inner {
  width: min(1240px, calc(100vw - 56px));
  margin: 0 auto;
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 18px;
  background-color: rgba(255, 255, 255, var(--nav-bg-alpha));
  border: 1px solid rgba(33, 26, 21, var(--nav-border-alpha));
  backdrop-filter: blur(var(--nav-blur));
  -webkit-backdrop-filter: blur(var(--nav-blur));
  transition: background-color 260ms ease, border-color 260ms ease, backdrop-filter 260ms ease, -webkit-backdrop-filter 260ms ease;
  pointer-events: auto;
}

body.menu-open .site-nav__inner {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.site-nav__brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  color: rgb(var(--nav-rgb));
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  white-space: nowrap;
}

.site-nav__logo {
  width: 52px;
  height: 52px;
  display: block;
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(var(--nav-invert));
  transform: scale(var(--nav-logo-scale));
  transform-origin: top left;
  transition: filter 260ms ease, transform 260ms ease;
}

.site-nav__menu {
  display: flex;
  align-items: center;
  gap: 0;
}

.site-nav__link {
  color: rgb(var(--nav-rgb));
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 0 18px;
  line-height: 72px;
  position: relative;
  opacity: 1;
  transition: color 260ms ease, opacity 200ms ease;
}

.site-nav__link + .site-nav__link {
  border-left: 1px solid rgba(var(--nav-rgb), 0.35);
  transition: border-color 260ms ease, opacity 200ms ease;
}

.site-nav__link:hover {
  opacity: 0.5;
}

.site-nav__toggle {
  display: none;
  width: 52px;
  height: 52px;
  border: none;
  background-color: transparent;
  position: relative;
  padding: 0;
}

.site-nav__toggle-line {
  position: absolute;
  left: 12px;
  right: 12px;
  height: 1px;
  background-color: rgb(var(--nav-rgb));
  transition: transform 220ms ease, top 220ms ease, opacity 160ms ease, background-color 260ms ease;
}

.site-nav__toggle-line:nth-child(1) {
  top: 18px;
}

.site-nav__toggle-line:nth-child(2) {
  top: 25px;
}

.site-nav__toggle-line:nth-child(3) {
  top: 32px;
}

body.menu-open .site-nav__toggle-line:nth-child(1) {
  top: 25px;
  transform: rotate(45deg);
}

body.menu-open .site-nav__toggle-line:nth-child(2) {
  opacity: 0;
}

body.menu-open .site-nav__toggle-line:nth-child(3) {
  top: 25px;
  transform: rotate(-45deg);
}

.mobile-nav {
  position: fixed;
  inset: 0;
  z-index: 35;
  background-color: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 132px 28px 36px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 280ms ease, visibility 280ms ease;
}

body.menu-open .mobile-nav {
  opacity: 1;
  visibility: visible;
}

.mobile-nav__links {
  display: grid;
  gap: 22px;
  width: 100%;
  max-width: 360px;
}

.mobile-nav__link {
  color: #18120d;
  font-family: "Cormorant Garamond", serif;
  font-size: 42px;
  line-height: 1;
  letter-spacing: 0.04em;
  text-align: left;
  transition: opacity 0.2s ease;
}

.mobile-nav__link:hover {
  opacity: 0.5;
}

/* === CSS: h-sections.css [root] === */
.story-grid {
  display: grid;
  gap: 64px;
}

.story {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 34px;
  align-items: center;
}

.story:nth-child(even) {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}

.story:nth-child(even) .story__media {
  order: 2;
}

.story__media {
  display: block;
  min-height: 420px;
  border: 1px solid var(--line);
  background-size: cover;
  background-position: center;
  background-color: #ddd2c4;
}

.story__body {
  max-width: 580px;
}

.story__label {
  margin: 0 0 16px;
  font-family: "Cormorant Garamond", serif;
  font-size: 42px;
  line-height: 1;
  letter-spacing: 0.03em;
}

.story__body p {
  margin: 0 0 16px;
}

.story__body p:last-child {
  margin-bottom: 0;
}

.story__body p:first-child {
  font-weight: 600;
  letter-spacing: 0.04em;
}

.events-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.event-card {
  border: 1px solid var(--line);
  background-color: var(--panel);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 28px;
  min-height: 360px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.event-card__date {
  display: inline-grid;
  gap: 6px;
  align-content: start;
  width: 96px;
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(33, 26, 21, 0.22);
  padding: 14px;
  margin-bottom: 28px;
  text-transform: uppercase;
}

.event-card__day {
  font-family: "Cormorant Garamond", serif;
  font-size: 48px;
  line-height: 0.9;
  letter-spacing: 0.04em;
}

.event-card__month,
.event-card__meta {
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.event-card h3,
.event-card--page h2 {
  margin: 0 0 14px;
  font-family: "Cormorant Garamond", serif;
  font-size: 34px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.04em;
}

.event-card p,
.event-card--page p {
  margin: 16px 0 12px;
  color: var(--muted);
}

.event-card__address {
  margin: -8px 0 22px;
  color: rgba(33, 26, 21, 0.58);
  font-size: 14px;
  line-height: 1.5;
}

.events-list-page {
  display: grid;
  gap: 24px;
}

.comparison-card {
  border: 1px solid var(--line);
  background-color: #ddd0bf;
  padding: 22px;
  margin-bottom: 48px;
}

.comparison-card h3 {
  margin: 0 0 18px;
  font-family: "Cormorant Garamond", serif;
  font-size: 40px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.04em;
}

.comparison-card p {
  margin: 0 0 24px;
  max-width: 760px;
  color: var(--muted);
}

.comparison-card__frame {
  position: relative;
  border: 1px solid rgba(33, 26, 21, 0.14);
  aspect-ratio: 1328 / 919;
  overflow: hidden;
  background-color: #cbb8a0;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}

.comparison-card__image,
.comparison-card__overlay {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}

.comparison-card__overlay {
  clip-path: inset(0 0 0 0);
  transition: clip-path 220ms ease;
}

.comparison-card__divider {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1px;
  background-color: rgba(255, 255, 255, 0.95);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
  transition: left 220ms ease;
  touch-action: none;
}

.comparison-card__frame.is-live .comparison-card__overlay,
.comparison-card__frame.is-live .comparison-card__divider {
  transition: none;
}

.comparison-card__handle {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 46px;
  height: 46px;
  margin-left: -23px;
  margin-top: -23px;
  border: 1px solid rgba(255, 255, 255, 0.95);
  background-color: rgba(255, 255, 255, 0.16);
  background-image: url("/images/site/handle.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px 18px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: background-color 180ms ease, border-color 180ms ease, transform 180ms ease;
  touch-action: none;
}

.comparison-card__frame.is-dragging .comparison-card__handle,
.comparison-card__handle.is-active,
.comparison-card__handle:active {
  background-color: rgba(255, 255, 255, 0.3);
  border-color: rgba(255, 255, 255, 1);
  transform: scale(1.04);
}

.impression-wall {
  columns: 3 260px;
  column-gap: 18px;
}

.impression-wall__item {
  display: block;
  break-inside: avoid;
  margin: 0 0 18px;
  border: 1px solid var(--line);
  background-color: #d8cab7;
}

.impression-wall__link {
  display: block;
}

.impression-wall__photo {
  width: 100%;
  display: block;
  background-size: cover;
  background-position: center;
}

.impression-wall__item:nth-child(3n + 1) .impression-wall__photo,
.impression-wall__item:nth-child(8) .impression-wall__photo {
  aspect-ratio: 4 / 5.7;
}

.impression-wall__item:nth-child(3n + 2) .impression-wall__photo,
.impression-wall__item:nth-child(5) .impression-wall__photo {
  aspect-ratio: 16 / 11;
}

.impression-wall__item:nth-child(3n) .impression-wall__photo,
.impression-wall__item:nth-child(7) .impression-wall__photo {
  aspect-ratio: 4 / 4.6;
}

.about-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
}

.about__media {
  display: block;
  min-height: 700px;
  border: 1px solid var(--line);
  background-size: cover;
  background-position: center;
  background-color: #d7cab8;
}

.about__body {
  background-color: var(--panel);
  border: 1px solid var(--line);
  padding: 36px;
  max-width: 640px;
}

.about__name {
  margin: 0 0 18px;
  font-family: "Cormorant Garamond", serif;
  font-size: 30px;
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: 0.04em;
}

.about__body p {
  margin: 0 0 18px;
}

.about__body p:last-child {
  margin-bottom: 0;
}

.events-more {
  margin-top: 32px;
}
/* === CSS: y-media-sizes.css [root] === */
@media (max-width: 1200px) {
  :root {
    --section-gap: 112px;
  }

  .hero h1 {
    font-size: 74px;
  }

  .section h2,
  .subpage-hero h1 {
    font-size: 56px;
  }

  .story__label,
  .comparison-card h3,
  .contact-panel h3,
  .contact-info h3,
  .about__name {
    font-size: 36px;
  }

  .about__media {
    min-height: 620px;
  }
}

@media (max-width: 980px) {
  :root {
    --section-gap: 96px;
  }

  .site-nav {
    top: 16px;
    padding: 0 16px;
  }

  .site-nav__inner,
  .hero__content {
    width: min(1240px, calc(100vw - 32px));
  }

  .site-nav__menu {
    display: none;
  }

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

  .hero h1 {
    font-size: 62px;
  }

  .section h2,
  .subpage-hero h1 {
    font-size: 50px;
  }

  .story,
  .story:nth-child(even),
  .about-grid,
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .story:nth-child(even) .story__media {
    order: 0;
  }

  .story__media,
  .about__media {
    background-position: center 34%;
    min-height: 340px;
  }

  .about__body {
    max-width: none;
  }

  .events-grid {
    grid-template-columns: 1fr;
  }

  .event-card {
    min-height: auto;
  }

  .site-footer__inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 640px) {
  :root {
    --section-gap: 76px;
  }

  body {
    font-size: 15px;
  }

  .hero__content {
    padding: 148px 0 96px;
  }

  .hero h1 {
    font-size: 48px;
  }

  .hero p,
  .section__lead {
    font-size: 16px;
  }

  .section,
  .subpage-hero,
  .site-footer {
    padding-left: 16px;
    padding-right: 16px;
  }

  .section h2,
  .subpage-hero h1 {
    font-size: 42px;
    margin-bottom: 22px;
  }

  .story-grid,
  .events-grid,
  .contact-form,
  .mobile-nav__links {
    gap: 18px;
  }

  .story {
    gap: 22px;
  }

  .story__label,
  .comparison-card h3,
  .contact-panel h3,
  .contact-info h3,
  .about__name {
    font-size: 32px;
  }

  .story__media,
  .about__media {
    min-height: 280px;
  }

  .contact-panel,
  .contact-info,
  .about__body,
  .comparison-card,
  .event-card {
    padding: 24px;
  }

  .contact-form__row,
  .contact-form__row--phone {
    grid-template-columns: 1fr;
  }

  .site-footer__links {
    gap: 16px;
  }
}

@media (max-width: 333px) {
  * {
    word-break: break-all;
  }
}

/* === CSS: z-htmx-confirm.css [core] === */
.confirm-modal[hidden]{ display:none; }
  .confirm-modal{ position:fixed; inset:0; z-index:9999; }
  .confirm-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.5); }
  .confirm-modal__panel{
    position:relative; margin:auto; top:30vh; max-width:520px; width:calc(100% - 2rem);
    background:#111; color:#fff; border-radius:12px;
  corner-shape: superellipse(1.5); padding:1.25rem; box-shadow:0 10px 40px rgba(0,0,0,.4);
  }
  .confirm-modal__title{ margin:0 0 .5rem; font-size:1.125rem; }
.confirm-modal__text{ margin:0 0 1rem; opacity:.9; white-space:pre-wrap; }
  .confirm-modal__actions{ display:flex; gap:.5rem; justify-content:flex-end; }
  .btn{ padding:.6rem .9rem; border-radius:.6rem;
  corner-shape: superellipse(1.5); border:0; cursor:pointer; }
  .btn--ghost{ background:transparent; color:#fff; outline:1px solid rgba(255,255,255,.25); }
  .btn--danger{ background:#e5484d; color:#fff; }

/* === CSS: z-nsb-box.css [core] === */
#nsbbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  background: rgba(10, 8, 12, 0.88);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

#nsbbox.open {
  display: flex;
}

#nsbbox .nsb-media {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(92vw, 1280px);
  max-width: 100%;
  max-height: calc(100vh - 8rem);
}

#nsbbox img,
#nsbbox iframe {
  display: block;
  max-width: 100%;
  max-height: calc(100vh - 8rem);
  border: 0;
  border-radius: 1rem;
  corner-shape: superellipse(1.5);
  background: #0b0b0d;
  box-shadow: 0 1.25rem 4rem rgba(0, 0, 0, 0.45);
}

#nsbbox img {
  width: auto;
  height: auto;
  object-fit: contain;
}

#nsbbox iframe {
  width: min(92vw, 1280px);
  height: min(80vh, 820px);
}

#nsbbox .nsb-caption {
  position: absolute;
  left: 50%;
  bottom: 1.35rem;
  transform: translateX(-50%);
  max-width: min(90vw, 900px);
  margin: 0;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  corner-shape: superellipse(1.5);
  background: rgba(9, 9, 12, 0.72);
  color: #fff;
  font-size: 0.95rem;
  line-height: 1.4;
  text-align: center;
}

#nsbbox .nsb-close,
#nsbbox .nsb-prev,
#nsbbox .nsb-next {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(12, 12, 16, 0.82);
  color: #fff;
  cursor: pointer;
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1;
  text-align: center;
  transition: transform 180ms ease, background-color 180ms ease, border-color 180ms ease;
}

#nsbbox .nsb-close:hover,
#nsbbox .nsb-prev:hover,
#nsbbox .nsb-next:hover {
  transform: scale(1.06);
  background: rgba(24, 24, 30, 0.96);
  border-color: rgba(255, 255, 255, 0.36);
}

#nsbbox .nsb-close {
  top: 1.5rem;
  right: 1.5rem;
  font-size: 1.6rem;
  padding-top: 2px;
}

#nsbbox .nsb-prev,
#nsbbox .nsb-next {
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  padding-bottom: 5px;
}

#nsbbox .nsb-prev:hover,
#nsbbox .nsb-next:hover {
  transform: translateY(-50%) scale(1.06);
}

#nsbbox .nsb-prev {
  left: 1.5rem;
  padding-right: 2px;
}

#nsbbox .nsb-next {
  right: 1.5rem;
  padding-left: 4px;
}

#nsbbox.nsbbox--iframe .nsb-prev,
#nsbbox.nsbbox--iframe .nsb-next {
  display: none;
}

#nsbbox.fade-out .nsb-media > * {
  opacity: 0;
  transform: translateX(var(--dir, 0));
}

#nsbbox .nsb-media > * {
  transition: opacity 280ms ease, transform 280ms ease;
}

@media (max-width: 900px) {
  #nsbbox {
    padding: 1rem;
  }

  #nsbbox .nsb-media,
  #nsbbox img,
  #nsbbox iframe {
    max-height: calc(100vh - 6.5rem);
  }

  #nsbbox .nsb-prev,
  #nsbbox .nsb-next {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1.5rem;
  }

  #nsbbox .nsb-prev {
    left: 0.75rem;
  }

  #nsbbox .nsb-next {
    right: 0.75rem;
  }

  #nsbbox .nsb-close {
    top: 0.75rem;
    right: 0.75rem;
  }

  #nsbbox .nsb-caption {
    bottom: 0.85rem;
    font-size: 0.88rem;
    padding: 0.6rem 0.85rem;
  }
}

/* === CSS: zz-anim-preview.css [core] === */
#slow-anim * {
  transition-duration: 2.5s !important;
}

/* === CSS: zz-nsb-box.css [root] === */
#nsbbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  background: rgba(10, 8, 12, 0.88);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

#nsbbox.open {
  display: flex;
}

#nsbbox .nsb-media {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(92vw, 1280px);
  max-width: 100%;
  max-height: calc(100vh - 8rem);
}

#nsbbox img,
#nsbbox iframe {
  display: block;
  max-width: 100%;
  max-height: calc(100vh - 8rem);
  border: 0;
  border-radius: 1rem;
  background: #0b0b0d;
  box-shadow: 0 1.25rem 4rem rgba(0, 0, 0, 0.45);
}

#nsbbox img {
  width: auto;
  height: auto;
  object-fit: contain;
}

#nsbbox iframe {
  width: min(92vw, 1280px);
  height: min(80vh, 820px);
}

#nsbbox .nsb-caption {
  position: absolute;
  left: 50%;
  bottom: 1.35rem;
  transform: translateX(-50%);
  max-width: min(90vw, 900px);
  margin: 0;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  background: rgba(9, 9, 12, 0.72);
  color: #fff;
  font-size: 0.95rem;
  line-height: 1.4;
  text-align: center;
}

#nsbbox .nsb-close,
#nsbbox .nsb-prev,
#nsbbox .nsb-next {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(12, 12, 16, 0.82);
  color: #fff;
  cursor: pointer;
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1;
  text-align: center;
  transition: transform 180ms ease, background-color 180ms ease, border-color 180ms ease;
}

#nsbbox .nsb-close:hover,
#nsbbox .nsb-prev:hover,
#nsbbox .nsb-next:hover {
  transform: scale(1.06);
  background: rgba(24, 24, 30, 0.96);
  border-color: rgba(255, 255, 255, 0.36);
}

#nsbbox .nsb-close {
  top: 1.5rem;
  right: 1.5rem;
  font-size: 1.6rem;
  padding-top: 2px;
}

#nsbbox .nsb-prev,
#nsbbox .nsb-next {
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  padding-bottom: 5px;
}

#nsbbox .nsb-prev:hover,
#nsbbox .nsb-next:hover {
  transform: translateY(-50%) scale(1.06);
}

#nsbbox .nsb-prev {
  left: 1.5rem;
  padding-right: 2px;
}

#nsbbox .nsb-next {
  right: 1.5rem;
  padding-left: 4px;
}

#nsbbox.nsbbox--iframe .nsb-prev,
#nsbbox.nsbbox--iframe .nsb-next {
  display: none;
}

#nsbbox.fade-out .nsb-media > * {
  opacity: 0;
  transform: translateX(var(--dir, 0));
}

#nsbbox .nsb-media > * {
  transition: opacity 280ms ease, transform 280ms ease;
}

@media (max-width: 900px) {
  #nsbbox {
    padding: 1rem;
  }

  #nsbbox .nsb-media,
  #nsbbox img,
  #nsbbox iframe {
    max-height: calc(100vh - 6.5rem);
  }

  #nsbbox .nsb-prev,
  #nsbbox .nsb-next {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1.5rem;
  }

  #nsbbox .nsb-prev {
    left: 0.75rem;
  }

  #nsbbox .nsb-next {
    right: 0.75rem;
  }

  #nsbbox .nsb-close {
    top: 0.75rem;
    right: 0.75rem;
  }

  #nsbbox .nsb-caption {
    bottom: 0.85rem;
    font-size: 0.88rem;
    padding: 0.6rem 0.85rem;
  }
}

/* === CSS: zzz-loader.css [root] === */
.htmx-indicator {
  display: none;
}
.htmx-request {
  /* display: block; */
}
#loader.htmx-indicator {
  display: none;
}
#loader.htmx-request {
  display: block;
  animation: load 12s cubic-bezier(0.45, 0, 0.25, 1) 1;
}
#loader {
  pointer-events: none;
  display: block;
  position: fixed;
  z-index: 99;
  left: 0;
  top: 0;
  margin: 0;
  width: 100%;
  background: var(--loader);
  height: 3px;
  /* opacity: 1;
  animation: load 8s linear 1; */
}
@keyframes load {
  0% {
    width: 0;
  }
  5% {
    width: 0;
  }
  6% {
    width: 10%;
  }
  100% {
    width: 100%;
  }
}

