/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
      "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-red-400: oklch(70.4% 0.191 22.216);
    --color-slate-900: oklch(20.8% 0.042 265.755);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-500: oklch(55.1% 0.027 264.364);
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-2xl: 42rem;
    --container-4xl: 56rem;
    --container-6xl: 72rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --font-weight-medium: 500;
    --blur-md: 12px;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .collapse {
    visibility: collapse;
  }
  .visible {
    visibility: visible;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .start {
    inset-inline-start: var(--spacing);
  }
  .end {
    inset-inline-end: var(--spacing);
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .table {
    display: table;
  }
  .h-14 {
    height: calc(var(--spacing) * 14);
  }
  .h-16 {
    height: calc(var(--spacing) * 16);
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .max-w-4xl {
    max-width: var(--container-4xl);
  }
  .max-w-6xl {
    max-width: var(--container-6xl);
  }
  .flex-1 {
    flex: 1;
  }
  .border-collapse {
    border-collapse: collapse;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .resize {
    resize: both;
  }
  .grid-cols-\[240px_1fr\] {
    grid-template-columns: 240px 1fr;
  }
  .items-center {
    align-items: center;
  }
  .justify-between {
    justify-content: space-between;
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-l-4 {
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
  }
  .border-\[var\(--color-brand\)\] {
    border-color: var(--color-brand);
  }
  .border-red-400 {
    border-color: var(--color-red-400);
  }
  .border-white\/20 {
    border-color: color-mix(in srgb, #fff 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-white) 20%, transparent);
    }
  }
  .bg-slate-900 {
    background-color: var(--color-slate-900);
  }
  .bg-white\/5 {
    background-color: color-mix(in srgb, #fff 5%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
    }
  }
  .bg-white\/10 {
    background-color: color-mix(in srgb, #fff 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }
  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }
  .text-center {
    text-align: center;
  }
  .text-right {
    text-align: right;
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .text-gray-400 {
    color: var(--color-gray-400);
  }
  .text-gray-500 {
    color: var(--color-gray-500);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .backdrop-blur-md {
    --tw-backdrop-blur: blur(var(--blur-md));
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-\[transform\,opacity\] {
    transition-property: transform,opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .\[hostname\:port\] {
    hostname: port;
  }
  .focus\:ring-2 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-\[var\(--color-brand\)\] {
    &:focus {
      --tw-ring-color: var(--color-brand);
    }
  }
}
:root {
  --bg: #F7F6F3;
  --fg: #1A1A1A;
  --card: #FFFFFF;
  --muted: #4A4A4A;
  --muted-light: #8A8A8A;
  --primary: #1B2A4A;
  --primary-fg: #ffffff;
  --accent: #C9A96E;
  --accent-fg: #1B2A4A;
  --accent-light: #D4BA88;
  --warm-gold: #C9A96E;
  --dark-wood: #0F1A2E;
  --dark-wood-fg: #ffffff;
  --navy: #1B2A4A;
  --navy-dark: #0F1A2E;
  --cream: #F0EDE6;
  --border: #E0DDD8;
  --border-light: #ECEAE5;
  --radius: 0.25rem;
  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body: 'Inter', 'Segoe UI', sans-serif;
  --available: #2D6A4F;
  --pending: #1B2A4A;
  --booked: #C1292E;
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
}
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  20%, 60% {
    transform: translateX(-6px);
  }
  40%, 80% {
    transform: translateX(6px);
  }
}
@keyframes missionPop {
  0% {
    opacity: 0;
    transform: scale(0.12);
  }
  60% {
    opacity: 1;
    transform: scale(1.2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.mission-content {
  opacity: 0;
  will-change: transform, opacity;
}
.mission-content.mission-pop {
  animation: missionPop 1.6s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}
* {
  box-sizing: border-box;
}
body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--fg);
  line-height: 1.6;
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
}
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}
.max-w-2xl {
  max-width: 42rem;
}
.max-w-3xl {
  max-width: 48rem;
}
.max-w-4xl {
  max-width: 56rem;
}
.max-w-5xl {
  max-width: 64rem;
}
.max-w-6xl {
  max-width: 72rem;
}
.site-header {
  background: var(--navy);
  color: var(--dark-wood-fg);
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  transition: background 0.3s ease, box-shadow 0.3s ease;
}
.site-header--over-hero {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: transparent;
  border-bottom: none;
}
.site-header--over-hero.scrolled {
  background: var(--navy);
  box-shadow: 0 2px 20px rgba(0,0,0,0.3);
}
.site-header--over-hero .logo-main {
  color: var(--dark-wood-fg);
}
.site-header--over-hero .nav-desktop a, .site-header--over-hero .nav-dropdown-btn {
  color: rgba(255,255,255,0.85);
}
.site-header--over-hero .nav-desktop a:hover, .site-header--over-hero .nav-dropdown-btn:hover, .site-header--over-hero .nav-desktop a.active, .site-header--over-hero .nav-dropdown-btn.active {
  color: var(--warm-gold);
}
.site-header--over-hero .nav-mobile a, .site-header--over-hero .nav-mobile-toggle {
  color: rgba(255,255,255,0.9);
}
.site-header--over-hero .nav-mobile a:hover, .site-header--over-hero .nav-mobile-toggle:hover {
  color: var(--warm-gold);
}
.site-header--over-hero.nav-open {
  background: var(--navy);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 3.75rem;
  max-width: 1440px;
  margin: 0 auto;
}
.logo {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
}
.logo-main {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.125rem;
  letter-spacing: 0.18em;
  color: #fff;
}
.nav-desktop {
  display: none;
  align-items: center;
  gap: 2rem;
}
.nav-desktop a, .nav-dropdown-btn {
  padding: 0.5rem 0;
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 400;
  border: none;
  background: none;
  cursor: pointer;
  font-family: var(--font-body);
  transition: color 0.2s ease;
}
.nav-desktop a:hover, .nav-dropdown-btn:hover {
  color: var(--warm-gold);
}
.nav-desktop a.active, .nav-dropdown-btn.active {
  color: #fff;
  font-weight: 500;
}
.nav-dropdown {
  position: relative;
}
.nav-dropdown-content {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 12rem;
  background: var(--navy-dark);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius);
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
  padding: 0.25rem;
  transform: translateY(4px);
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.nav-dropdown:hover .nav-dropdown-content {
  display: block;
  opacity: 1;
  transform: translateY(0);
}
.nav-dropdown-content a {
  display: block;
  padding: 0.6rem 1rem;
  color: rgba(255,255,255,0.8);
  text-decoration: none;
  font-size: 0.875rem;
  border-radius: var(--radius);
  transition: background 0.15s ease, color 0.15s ease;
}
.nav-dropdown-content a:hover {
  background: rgba(255,255,255,0.08);
  color: var(--warm-gold);
}
.nav-right {
  display: none;
  align-items: center;
  gap: 1.25rem;
}
.nav-phone {
  color: var(--accent-light);
  font-size: 0.875rem;
  text-decoration: none;
  transition: color 0.2s ease;
}
.nav-phone:hover {
  color: #fff;
}
.nav-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.625rem 1.5rem;
  background: var(--accent);
  color: var(--navy);
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius);
  text-decoration: none;
  transition: background 0.2s ease, transform 0.15s ease;
}
.nav-cta:hover {
  background: var(--accent-light);
  transform: translateY(-1px);
}
.nav-mobile-toggle {
  display: block;
  background: none;
  border: none;
  color: rgba(255,255,255,0.85);
  cursor: pointer;
  padding: 0.25rem;
  line-height: 0;
}
.nav-mobile-toggle:hover {
  color: var(--warm-gold);
}
.nav-mobile-toggle svg {
  width: 1.5rem;
  height: 1.5rem;
  fill: currentColor;
}
.nav-mobile {
  flex-direction: column;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  padding: 0 3.75rem;
  border-top: 1px solid rgba(255,255,255,0.08);
  transition: max-height 0.35s ease, opacity 0.25s ease, padding 0.3s ease;
}
.nav-mobile a {
  padding: 0.85rem 0;
  color: rgba(255,255,255,0.8);
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  display: block;
  font-size: 0.9375rem;
}
.nav-mobile a:hover {
  color: var(--warm-gold);
}
.nav-mobile a:last-child {
  border-bottom: none;
}
.nav-mobile.open {
  max-height: 600px;
  opacity: 1;
  padding: 0.5rem 3.75rem 1.5rem;
}
.nav-mobile .nav-mobile-cta {
  display: inline-flex;
  margin-top: 0.75rem;
  padding: 0.75rem 1.5rem;
  background: var(--accent);
  color: var(--navy);
  font-weight: 600;
  border-radius: var(--radius);
  text-align: center;
}
.site-header.nav-open {
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
}
@media (min-width: 1024px) {
  .nav-desktop {
    display: flex;
  }
  .nav-right {
    display: flex;
  }
  .nav-mobile-toggle {
    display: none;
  }
}
@media (max-width: 1023px) {
  .header-inner {
    padding: 0.75rem 1.25rem;
  }
  .nav-mobile {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
  .nav-mobile.open {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}
.main-content {
  min-height: calc(100vh - 200px);
}
.hero {
  position: relative;
  min-height: 700px;
  height: 100vh;
  max-height: 900px;
  display: flex;
  align-items: center;
  background: var(--navy-dark);
  overflow: hidden;
}
.hero--with-image {
  background: var(--navy-dark);
}
.hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0.3;
  will-change: transform;
  animation: heroKenBurns 30s var(--ease-out-expo) infinite alternate;
  filter: brightness(0.9);
}
@keyframes heroKenBurns {
  0% {
    transform: scale(1) translate(0, 0);
  }
  100% {
    transform: scale(1.06) translate(1%, -0.5%);
  }
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(15,26,46,0.7) 0%, rgba(15,26,46,0.3) 50%, rgba(15,26,46,0.5) 100%);
}
.hero-content {
  position: relative;
  z-index: 1;
  text-align: left;
  padding: 0 7.5rem;
  max-width: 1440px;
  width: 100%;
}
.hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 4.5vw, 3.5rem);
  font-weight: 700;
  color: #fff;
  margin: 0 0 1.5rem;
  line-height: 1.15;
  opacity: 0;
  animation: heroFadeUp 0.8s 0.2s var(--ease-out-expo) forwards;
}
.hero-subtitle {
  font-size: 1.125rem;
  color: rgba(255,255,255,0.85);
  margin: 0 0 2rem;
  max-width: 40rem;
  line-height: 1.6;
  opacity: 0;
  animation: heroFadeUp 0.8s 0.4s var(--ease-out-expo) forwards;
}
.hero-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  opacity: 0;
  animation: heroFadeUp 0.8s 0.6s var(--ease-out-expo) forwards;
}
.hero-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 2rem;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  border-radius: var(--radius);
  text-decoration: none;
  cursor: pointer;
  transition: all 0.25s ease;
}
.hero-btn-primary {
  background: var(--accent);
  color: var(--navy-dark);
  border: 2px solid var(--accent);
}
.hero-btn-primary:hover {
  background: var(--accent-light);
  border-color: var(--accent-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(201,169,110,0.3);
}
.hero-btn-outline {
  background: transparent;
  color: #fff;
  border: 2px solid #fff;
}
.hero-btn-outline:hover {
  background: rgba(255,255,255,0.1);
  transform: translateY(-2px);
}
@keyframes heroFadeUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 768px) {
  .hero-content {
    padding: 0 1.5rem;
  }
  .hero {
    min-height: 500px;
  }
}
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s var(--ease-out-expo), transform 0.7s var(--ease-out-expo);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-left {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 0.7s var(--ease-out-expo), transform 0.7s var(--ease-out-expo);
}
.reveal-left.visible {
  opacity: 1;
  transform: translateX(0);
}
.reveal-right {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.7s var(--ease-out-expo), transform 0.7s var(--ease-out-expo);
}
.reveal-right.visible {
  opacity: 1;
  transform: translateX(0);
}
.stagger-1 {
  transition-delay: 0s;
}
.stagger-2 {
  transition-delay: 0.12s;
}
.stagger-3 {
  transition-delay: 0.24s;
}
.practice-section {
  background: transparent;
  padding: 0 7.5rem 5rem;
  position: relative;
  margin-top: -60px;
  z-index: 10;
}
.practice-inner {
  max-width: 1440px;
  margin: 0 auto;
  text-align: center;
}
.practice-title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--fg);
  margin: 0 0 3rem;
  display: none;
}
.practice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(17rem, 20.1875rem));
  justify-content: center;
  gap: 1.5rem;
}
.practice-section .practice-card {
  background: #ffffff;
  border: 1px solid #c2a67a;
  border-radius: 0;
  padding: 2.5rem;
  text-align: left;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
  transition: box-shadow 0.35s ease, transform 0.35s ease;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}
.practice-section .practice-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.09);
}
.practice-section .practice-card-icon {
  width: 2.5rem;
  height: 2.5rem;
  color: #c2a67a;
  margin-bottom: 1.75rem;
  flex-shrink: 0;
}
.practice-section .practice-card-title {
  font-family: var(--font-heading);
  font-size: 1.375rem;
  font-weight: 700;
  color: #000000;
  margin: 0 0 1.25rem;
}
.practice-section .practice-card-desc {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  color: #4a4a4a;
  line-height: 1.7;
  margin: 0 0 0.75rem;
}
.practice-section .practice-card-link {
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 600;
  color: #c2a67a;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: gap 0.2s ease;
}
.practice-section .practice-card-link:hover {
  gap: 0.5rem;
}
.practice-card-link {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: gap 0.2s ease;
}
.practice-card-link:hover {
  gap: 0.5rem;
}
@media (max-width: 768px) {
  .practice-section {
    padding: 0 1.5rem 3rem;
    margin-top: -45px;
  }
  .practice-grid {
    grid-template-columns: 1fr;
    justify-items: stretch;
  }
}
.intro-section {
  background: var(--card);
  padding: 5rem 12.5rem;
  text-align: center;
}
.intro-inner {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}
.intro-accent {
  width: 3.75rem;
  height: 3px;
  background: var(--accent);
  border-radius: 2px;
}
.intro-title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--fg);
  line-height: 1.2;
  margin: 0;
}
.intro-body {
  font-size: 1.0625rem;
  color: var(--muted);
  line-height: 1.75;
  margin: 0;
}
@media (max-width: 768px) {
  .intro-section {
    padding: 3rem 1.5rem;
  }
  .intro-title {
    font-size: 1.75rem;
  }
}
.attorney-section {
  background: var(--card);
  padding: 5rem 7.5rem;
}
.attorney-inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 3.75rem;
}
.attorney-photo {
  flex-shrink: 0;
  width: 26.25rem;
  height: 31.25rem;
  border-radius: var(--radius);
  overflow: hidden;
}
.attorney-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--ease-out-expo);
}
.attorney-photo:hover img {
  transform: scale(1.03);
}
.attorney-bio {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.attorney-accent {
  width: 3.75rem;
  height: 3px;
  background: var(--accent);
  border-radius: 2px;
}
.attorney-name {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--fg);
  margin: 0;
}
.attorney-title {
  font-size: 1rem;
  font-weight: 500;
  color: var(--accent);
  letter-spacing: 0.06em;
  margin: 0;
}
.attorney-text {
  font-size: 1rem;
  color: var(--muted);
  line-height: 1.75;
  margin: 0;
}
@media (max-width: 900px) {
  .attorney-section {
    padding: 3rem 1.5rem;
  }
  .attorney-inner {
    flex-direction: column;
  }
  .attorney-photo {
    width: 100%;
    max-width: 400px;
    height: 350px;
  }
}
.testimonials-section {
  background: var(--navy-dark);
  padding: 5rem 7.5rem;
}
.testimonials-inner {
  max-width: 1440px;
  margin: 0 auto;
  text-align: center;
}
.testimonials-title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 3rem;
}
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  text-align: left;
}
.testimonial-card {
  background: var(--navy);
  border-radius: var(--radius);
  padding: 2rem;
  border: 1px solid rgba(255,255,255,0.08);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  transition: transform 0.3s ease, border-color 0.3s ease;
}
.testimonial-card:hover {
  transform: translateY(-4px);
  border-color: rgba(255,255,255,0.15);
}
.testimonial-quote {
  font-size: 0.9375rem;
  font-style: italic;
  color: rgba(255,255,255,0.9);
  line-height: 1.7;
  margin: 0;
}
.testimonial-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--accent-light);
  margin: 0;
}
.testimonial-case {
  font-size: 0.8125rem;
  color: var(--muted-light);
  margin: 0;
}
@media (max-width: 768px) {
  .testimonials-section {
    padding: 3rem 1.5rem;
  }
  .testimonials-grid {
    grid-template-columns: 1fr;
  }
}
.cta-section {
  background: var(--accent);
  padding: 4.5rem 7.5rem;
  text-align: center;
}
.cta-inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}
.cta-title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--navy-dark);
  margin: 0;
}
.cta-sub {
  font-size: 1.0625rem;
  color: var(--navy);
  line-height: 1.6;
  margin: 0;
  max-width: 37.5rem;
}
.cta-buttons {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
}
.cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 2rem;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  border-radius: var(--radius);
  text-decoration: none;
  cursor: pointer;
  transition: all 0.25s ease;
}
.cta-btn-dark {
  background: var(--navy-dark);
  color: #fff;
  border: 2px solid var(--navy-dark);
}
.cta-btn-dark:hover {
  background: var(--navy);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(15,26,46,0.3);
}
.cta-btn-outline {
  background: transparent;
  color: var(--navy-dark);
  border: 2px solid var(--navy-dark);
}
.cta-btn-outline:hover {
  background: rgba(15,26,46,0.08);
  transform: translateY(-2px);
}
@media (max-width: 768px) {
  .cta-section {
    padding: 3rem 1.5rem;
  }
  .cta-title {
    font-size: 1.75rem;
  }
}
.news-section {
  background: var(--bg);
  padding: 5rem 7.5rem;
}
.news-section-inner {
  max-width: 1440px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .news-section {
    padding: 3rem 1.5rem;
  }
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1rem;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: var(--radius);
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 0.2s;
}
.btn-primary {
  background: var(--accent);
  color: var(--accent-fg);
}
.btn-primary:hover {
  background: hsl(8, 45%, 38%);
}
.btn-outline {
  background: transparent;
  border-color: var(--border);
  color: var(--fg);
}
.btn-outline:hover {
  background: var(--card);
}
.btn-outline-light {
  background: transparent;
  border-color: rgba(255,255,255,0.6);
  color: var(--dark-wood-fg);
}
.btn-outline-light:hover {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.8);
}
.btn-ghost {
  background: transparent;
  color: var(--accent);
}
.btn-ghost:hover {
  background: rgba(0,0,0,0.05);
}
.btn-gold {
  background: var(--warm-gold);
  color: var(--fg);
}
.btn-gold:hover {
  background: hsl(38, 70%, 50%);
}
.btn-danger {
  background: hsl(0, 84%, 60%);
  color: white;
  border: none;
}
.btn-danger:hover {
  background: hsl(0, 84%, 55%);
}
.btn-block {
  width: 100%;
}
.btn-sm {
  padding: 0.25rem 0.5rem;
  font-size: 0.8125rem;
}
.btn-icon {
  padding: 0.5rem;
}
.section {
  padding: 3rem 0;
}
.section-card {
  background: var(--card);
}
.section-primary {
  background: var(--primary);
  color: var(--primary-fg);
}
.section-title {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 1.5rem 0 0.5rem;
}
.section-title-light {
  color: var(--primary-fg);
  margin-top: 0;
}
.section-text {
  color: var(--muted);
  margin: 0;
}
.section-text-light {
  color: rgba(255,255,255,0.9);
  margin-bottom: 1.5rem;
}
.section-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 0;
}
.section-divider::before, .section-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}
.text-center {
  text-align: center;
}
.text-muted {
  color: var(--muted);
}
.text-right {
  text-align: right;
}
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
}
.card-narrow {
  max-width: 28rem;
  margin: 0 auto;
}
.card-title {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0 0 0.25rem;
}
.card-title-sm {
  font-size: 1.125rem;
  margin: 0 0 0.25rem;
}
.card-desc {
  color: var(--muted);
  font-size: 0.875rem;
  margin: 0 0 1rem;
}
.page-title {
  font-size: 1.875rem;
  font-weight: 700;
  margin: 0 0 0.5rem;
}
.page-center {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.mb-4 {
  margin-bottom: 1rem;
}
.mb-6 {
  margin-bottom: 1.5rem;
}
.mb-10 {
  margin-bottom: 2.5rem;
}
.mt-4 {
  margin-top: 1rem;
}
.mt-8 {
  margin-top: 2rem;
}
.news-section-title {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 3.25rem);
  letter-spacing: -0.01em;
  line-height: 1.1;
  margin: 0 0 0.75rem;
  color: var(--fg);
}
.news-section-sub {
  font-size: 0.9375rem;
  font-weight: 300;
  color: var(--muted);
  letter-spacing: 0.02em;
  margin: 0;
}
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
@media (max-width: 900px) {
  .news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 580px) {
  .news-grid {
    grid-template-columns: 1fr;
  }
}
.news-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 4px 32px rgba(60,40,10,0.08);
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), box-shadow 0.35s ease, border-color 0.35s ease;
}
.news-card.visible {
  opacity: 1;
  transform: translateY(0);
}
.news-card:nth-child(1) {
  transition-delay: 0s;
}
.news-card:nth-child(2) {
  transition-delay: 0.07s;
}
.news-card:nth-child(3) {
  transition-delay: 0.14s;
}
.news-card:nth-child(4) {
  transition-delay: 0.21s;
}
.news-card:nth-child(5) {
  transition-delay: 0.28s;
}
.news-card:nth-child(6) {
  transition-delay: 0.35s;
}
.news-card:nth-child(7) {
  transition-delay: 0.42s;
}
.news-card:nth-child(8) {
  transition-delay: 0.49s;
}
.news-card:nth-child(9) {
  transition-delay: 0.56s;
}
.news-card:hover {
  box-shadow: 0 12px 48px rgba(60,40,10,0.16);
  border-color: rgba(176,125,58,0.3);
  transform: translateY(-4px);
}
.news-card-thumb {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
}
.news-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.92) saturate(0.9);
  transition: transform 0.7s cubic-bezier(0.22,1,0.36,1), filter 0.4s ease;
}
.news-card:hover .news-card-thumb img {
  transform: scale(1.06);
  filter: brightness(1) saturate(1.05);
}
.news-card-thumb-empty {
  width: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, hsl(35,20%,86%) 0%, hsl(35,18%,80%) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.news-card-thumb-empty::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(45deg, transparent, transparent 12px, rgba(176,125,58,0.04) 12px, rgba(176,125,58,0.04) 13px);
}
.news-card-thumb-empty svg {
  width: 2rem;
  height: 2rem;
  opacity: 0.22;
  z-index: 1;
  color: var(--primary);
}
.news-card-body {
  padding: 1.5rem 1.625rem 1.75rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.news-date {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--warm-gold);
  margin-bottom: 0.75rem;
}
.news-card-title {
  font-family: var(--font-heading);
  font-size: clamp(1.125rem, 2vw, 1.375rem);
  font-weight: 600;
  line-height: 1.3;
  color: var(--fg);
  margin: 0 0 0.75rem;
  transition: color 0.25s ease;
}
.news-card:hover .news-card-title {
  color: var(--primary);
}
.news-card-intro {
  font-size: 0.875rem;
  line-height: 1.75;
  color: var(--muted);
  flex: 1;
  margin: 0 0 1.25rem;
}
.news-card-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--warm-gold);
  text-decoration: none;
  margin-top: auto;
  transition: gap 0.25s ease;
}
.news-card:hover .news-card-link {
  gap: 13px;
}
.news-card-link-arrow {
  display: inline-block;
  transition: transform 0.25s ease;
}
.news-card:hover .news-card-link-arrow {
  transform: translateX(3px);
}
.news-card-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--warm-gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1);
}
.news-card:hover .news-card-bar {
  transform: scaleX(1);
}
.news-view-all-wrap {
  text-align: center;
  margin-top: 3rem;
}
.news-view-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--warm-gold);
  text-decoration: none;
  border-bottom: 1px solid rgba(176,125,58,0.3);
  padding-bottom: 3px;
  transition: gap 0.2s ease, border-color 0.2s ease;
}
.news-view-all:hover {
  gap: 14px;
  border-color: var(--warm-gold);
}
.news-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.75rem;
  margin-top: 5rem;
  padding-top: 3rem;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
.pagination-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0.85rem 2.25rem;
  border: 2px solid var(--border);
  border-radius: var(--radius);
  background: var(--card);
  color: var(--fg);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
  box-shadow: 0 2px 6px rgba(0,0,0,0.07);
}
.pagination-btn:not(.pagination-btn--disabled):hover {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--primary-fg);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(60,35,10,0.18);
}
.pagination-btn--disabled {
  opacity: 0.32;
  cursor: default;
  pointer-events: none;
  box-shadow: none;
}
.pagination-info {
  font-size: 1rem;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: 0.06em;
  white-space: nowrap;
  padding: 0.5rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg);
}
.news-list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.news-article {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
}
.news-article-title {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0.5rem 0 0.75rem;
}
.news-article-title-large {
  font-size: 1.875rem;
}
.news-body {
  margin-bottom: 1rem;
}
.news-body img {
  max-width: 100%;
  height: auto;
}
.news-thumbnail {
  display: block;
  width: 100%;
  max-height: 340px;
  object-fit: cover;
  border-radius: var(--radius);
  margin: 1rem 0;
}
.news-images {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
  margin: 1rem 0;
}
.news-gallery-link {
  display: block;
  border-radius: var(--radius);
  overflow: hidden;
}
.news-gallery-link img {
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.news-gallery-link:hover img {
  transform: scale(1.02);
  box-shadow: 0 10px 24px rgba(0,0,0,0.25);
}
.news-video {
  margin: 1rem 0;
  aspect-ratio: 16/9;
}
.news-video iframe {
  width: 100%;
  height: 100%;
  border-radius: var(--radius);
  border: 1px solid var(--border);
}
.post-page {
  padding: 1.5rem 0 5rem;
}
.post-breadcrumb {
  padding: 0.5rem 0 1.75rem;
}
.post-breadcrumb a {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--primary);
  text-decoration: none;
  transition: color 0.2s ease;
}
.post-breadcrumb a:hover {
  color: var(--warm-gold);
}
.post-breadcrumb svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.post-header {
  border-top: 3px solid var(--fg);
  border-bottom: 1px solid var(--border);
  padding: 2.5rem 0 2rem;
  margin-bottom: 2.5rem;
  animation: fadeUp 0.6s ease both;
}
.post-header::before {
  content: '';
  display: block;
  width: 48px;
  height: 2px;
  background: var(--warm-gold);
  margin-bottom: 1.5rem;
}
.post-meta {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}
.post-meta-date {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--primary);
}
.post-tag {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  background: var(--fg);
  color: var(--bg);
  padding: 0.25rem 0.75rem;
  border-radius: 2px;
}
.post-title {
  font-family: var(--font-heading);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--fg);
  letter-spacing: -0.01em;
  margin: 0;
}
.post-layout {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 3rem;
  align-items: start;
  animation: fadeUp 0.6s 0.15s ease both;
}
@media (max-width: 768px) {
  .post-layout {
    grid-template-columns: 1fr;
  }
}
.post-text {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--fg);
  margin-bottom: 2rem;
}
.post-text p {
  margin-bottom: 1.5rem;
}
.post-text img {
  max-width: 100%;
  height: auto;
}
.post-text h2 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 600;
  margin: 2rem 0 0.75rem;
}
.post-text h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  margin: 1.5rem 0 0.5rem;
}
.post-text a {
  color: var(--accent);
}
.post-text ul, .post-text ol {
  padding-left: 1.5rem;
  margin-bottom: 1.5rem;
}
.post-text li {
  margin-bottom: 0.4rem;
}
.post-gallery {
  margin-top: 2.5rem;
  margin-bottom: 2.5rem;
}
.post-gallery-label {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}
.post-gallery-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}
@media (max-width: 480px) {
  .post-gallery-grid {
    grid-template-columns: 1fr;
  }
}
.post-gallery-item {
  aspect-ratio: 3/2;
  overflow: hidden;
  border: 1px solid var(--border);
  cursor: pointer;
  position: relative;
  display: block;
}
.post-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: sepia(8%) saturate(0.92);
  transition: transform 0.4s ease, filter 0.3s ease;
}
.post-gallery-item:hover img {
  transform: scale(1.04);
  filter: sepia(0%) saturate(1);
}
.post-gallery-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s ease;
}
.post-gallery-item:hover .post-gallery-overlay {
  background: rgba(26,20,16,0.25);
}
.post-gallery-zoom {
  width: 32px;
  height: 32px;
  background: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: scale(0.7);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.post-gallery-item:hover .post-gallery-zoom {
  opacity: 1;
  transform: scale(1);
}
.post-sidebar {
  position: sticky;
  top: 80px;
}
.post-sidebar-card {
  background: var(--card);
  border: 1px solid var(--border);
  padding: 1.5rem;
  margin-bottom: 1.25rem;
}
.post-sidebar-label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}
.post-sidebar-text {
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}
.post-pdf-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem;
  background: var(--fg);
  color: var(--bg);
  text-decoration: none;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  transition: background 0.2s ease;
}
.post-pdf-link:hover {
  background: var(--dark-wood);
  color: var(--dark-wood-fg);
}
.post-pdf-icon {
  width: 32px;
  height: 40px;
  background: var(--warm-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--fg);
}
.post-footer {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.post-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg);
  text-decoration: none;
  border-bottom: 2px solid var(--warm-gold);
  padding-bottom: 2px;
  transition: color 0.2s ease;
}
.post-back-link:hover {
  color: var(--primary);
}
.post-footer-org {
  font-size: 0.72rem;
  color: var(--muted);
  letter-spacing: 0.05em;
}
.glightbox-clean .gbtn, .glightbox-clean .gclose, .glightbox-clean .gnext, .glightbox-clean .gprev {
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 9999;
}
.form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.form-group label {
  font-weight: 500;
  font-size: 0.875rem;
}
.form-group input, .form-group select, .form-group textarea {
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-family: inherit;
  font-size: 1rem;
}
.form-hint {
  font-size: 0.75rem;
  color: var(--muted);
  margin: 0.25rem 0 0;
}
.flex {
  display: flex;
}
.flex-wrap {
  flex-wrap: wrap;
}
.gap-3 {
  gap: 0.75rem;
}
.justify-between {
  justify-content: space-between;
}
.items-center {
  align-items: center;
}
.self-center {
  align-self: center;
}
.flex-1 {
  flex: 1;
}
.alert {
  padding: 0.75rem 1rem;
  border-radius: var(--radius);
  margin: 0;
}
.alert-error {
  background: hsl(0, 84%, 95%);
  color: hsl(0, 84%, 30%);
  border: 1px solid hsl(0, 84%, 85%);
}
.alert-success {
  background: hsl(140, 50%, 95%);
  color: hsl(140, 50%, 25%);
  border: 1px solid hsl(140, 50%, 85%);
}
.hidden {
  display: none !important;
}
.table-wrap {
  overflow-x: auto;
}
.table {
  width: 100%;
  border-collapse: collapse;
}
.table th, .table td {
  padding: 0.75rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.table th {
  font-weight: 600;
  font-size: 0.875rem;
}
.table .font-medium {
  font-weight: 500;
}
.table .text-sm {
  font-size: 0.875rem;
}
.badge {
  display: inline-flex;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  background: rgba(25,55,30,0.15);
  color: var(--primary);
}
.content-prose {
  max-width: 48rem;
}
.content-prose p {
  margin: 0 0 1rem;
}
.content-h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 2rem 0 0.5rem;
}
.board-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.5rem;
}
.board-card {
  text-align: center;
}
.board-avatar {
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background: var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1rem;
  font-size: 1.75rem;
}
.board-name {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 0.25rem;
}
.board-position {
  font-size: 0.75rem;
  color: var(--warm-gold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 0.5rem;
}
.board-bio {
  font-size: 0.875rem;
  color: var(--muted);
  margin: 0;
}
.minutes-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.minutes-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.minutes-icon {
  width: 2.5rem;
  height: 2.5rem;
  background: var(--border);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.minutes-content {
  flex: 1;
  min-width: 0;
}
.minutes-title {
  font-size: 0.875rem;
  font-weight: 600;
  margin: 0;
}
.minutes-date {
  font-size: 0.75rem;
  color: var(--muted);
  margin: 0.25rem 0 0;
}
.minutes-download {
  font-size: 0.75rem;
  color: var(--accent);
}
.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}
.legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  font-size: 0.875rem;
}
.legend-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.legend-item::before {
  content: '';
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 50%;
}
.legend-item.available::before {
  background: var(--available);
}
.legend-item.pending::before {
  background: var(--pending);
}
.legend-item.booked::before {
  background: var(--booked);
}
.calendar-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
}
.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.calendar-title {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0;
}
.calendar-days-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.calendar-day-name {
  text-align: center;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted);
  padding: 0.5rem;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.5rem;
}
.calendar-empty {
  aspect-ratio: 1;
}
.calendar-day {
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius);
  border: 2px solid;
  position: relative;
}
.calendar-day.state-available {
  background: hsl(140, 45%, 95%);
  border-color: hsl(140, 45%, 80%);
  color: hsl(140, 45%, 30%);
}
.calendar-day.state-pending {
  background: var(--pending);
  border-color: hsl(220, 10%, 45%);
  color: white;
}
.calendar-day.state-booked {
  background: var(--booked);
  border-color: hsl(0, 60%, 40%);
  color: white;
}
.calendar-day.today {
  box-shadow: 0 0 0 2px var(--primary);
}
.calendar-day.clickable {
  cursor: pointer;
}
.calendar-day.clickable:hover {
  opacity: 0.9;
}
.calendar-day-num {
  font-size: 1rem;
  font-weight: 500;
}
.calendar-day-dot {
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.6;
}
.modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.modal.modal-open {
  display: flex;
}
.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
}
.modal-content {
  position: relative;
  background: var(--bg);
  border-radius: var(--radius);
  padding: 1.5rem;
  max-width: 28rem;
  width: 100%;
  box-shadow: 0 20px 40px rgba(0,0,0,0.2);
}
.modal-content h3 {
  margin: 0 0 1rem;
}
.modal-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
  margin-top: 1rem;
}
.form-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
  margin-top: 1.5rem;
}
.existing-file {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.image-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.5rem;
}
.image-preview-item {
  position: relative;
}
.image-preview-item img {
  width: 5rem;
  height: 5rem;
  object-fit: cover;
  border-radius: var(--radius);
  border: 1px solid var(--border);
}
.btn-remove-image {
  position: absolute;
  top: 0;
  right: 0;
  width: 1.25rem;
  height: 1.25rem;
  border: none;
  background: var(--booked);
  color: white;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  padding: 0;
}
.site-footer {
  background: var(--navy-dark);
  color: rgba(255,255,255,0.8);
  padding: 3.75rem 7.5rem 1.875rem;
}
.footer-inner {
  max-width: 1440px;
  margin: 0 auto;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 3rem;
}
.footer-brand-name {
  font-family: var(--font-heading);
  font-size: 1.125rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.125em;
  margin: 0 0 1rem;
}
.footer-address {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.6;
  margin: 0;
  font-style: normal;
}
.footer-heading {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 1rem;
}
.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.footer-links a {
  color: rgba(255,255,255,0.8);
  text-decoration: none;
  font-size: 0.875rem;
  transition: color 0.2s ease;
}
.footer-links a:hover {
  color: var(--warm-gold);
}
.footer-text {
  font-size: 0.875rem;
  margin: 0 0 0.75rem;
  line-height: 1.5;
  color: rgba(255,255,255,0.8);
}
.footer-divider {
  height: 1px;
  background: rgba(224,221,216,0.15);
  margin: 3rem 0 1.5rem;
}
.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.footer-bottom p {
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.5);
  margin: 0;
}
.footer-bottom-links {
  display: flex;
  gap: 1.5rem;
}
.footer-bottom-links a {
  font-size: 0.8125rem;
  color: var(--accent-light);
  text-decoration: none;
  transition: color 0.2s ease;
}
.footer-bottom-links a:hover {
  color: #fff;
}
@media (max-width: 768px) {
  .site-footer {
    padding: 2.5rem 1.5rem 1.5rem;
  }
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
}
@media (max-width: 480px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }
  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }
}
.error-code {
  font-size: 4rem;
  font-weight: 700;
  margin: 0 0 1rem;
}
.cms-fab {
  position: fixed;
  bottom: 1.75rem;
  right: 1.75rem;
  z-index: 900;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.125rem;
  background: var(--navy);
  color: #fff;
  border: none;
  border-radius: 2rem;
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.cms-fab:hover {
  background: var(--accent);
  color: var(--navy-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.cms-fab svg {
  width: 1rem;
  height: 1rem;
}
.cms-fab.hidden {
  display: none;
}
.cms-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 901;
  background: var(--navy-dark);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.875rem 2rem;
  transform: translateY(100%);
  transition: transform 0.3s var(--ease-out-expo);
  box-shadow: 0 -4px 24px rgba(0,0,0,0.35);
}
.cms-bar.open {
  transform: translateY(0);
}
.cms-bar-label {
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.cms-bar-label::before {
  content: '';
  width: 0.5rem;
  height: 0.5rem;
  background: var(--accent);
  border-radius: 50%;
  animation: cmsPulse 1.5s ease infinite;
}
@keyframes cmsPulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.35;
  }
}
.cms-bar-actions {
  display: flex;
  gap: 0.75rem;
}
.cms-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 600;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all 0.2s ease;
}
.cms-btn-save {
  background: var(--accent);
  color: var(--navy-dark);
}
.cms-btn-save:hover {
  background: var(--accent-light);
}
.cms-btn-save:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.cms-btn-cancel {
  background: transparent;
  color: rgba(255,255,255,0.75);
  border-color: rgba(255,255,255,0.2);
}
.cms-btn-cancel:hover {
  color: #fff;
  border-color: rgba(255,255,255,0.5);
}
.cms-toast {
  position: fixed;
  bottom: 5rem;
  right: 1.75rem;
  z-index: 902;
  padding: 0.75rem 1.25rem;
  border-radius: var(--radius);
  font-size: 0.875rem;
  font-weight: 500;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
}
.cms-toast.visible {
  opacity: 1;
  transform: translateY(0);
}
.cms-toast-success {
  background: var(--available);
  color: #fff;
}
.cms-toast-error {
  background: #C1292E;
  color: #fff;
}
.hero--navy {
  background: var(--navy);
  color: #fff;
  padding: 0 7.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 350px;
  text-align: center;
}
.hero-label {
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 1rem;
}
.hero.hero--contact {
  min-height: 0;
  height: auto;
  max-height: none;
  align-items: flex-start;
  background: var(--navy);
  color: #fff;
  padding: 6.5rem 7.5rem 4.5rem;
  overflow: visible;
}
.contact-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1440px;
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}
.contact-hero-aside {
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.contact-hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 3.5vw, 2.75rem);
  font-weight: 700;
  color: #fff;
  margin: 0 0 0.5rem;
  line-height: 1.15;
}
.contact-hero-kicker {
  font-family: var(--font-heading);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 1.25rem 0 0;
}
.contact-hero-section-title {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
  margin: 1.75rem 0 0.25rem;
}
.contact-hero-lead, .contact-hero-body {
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.88);
  margin: 0;
  max-width: 36rem;
}
.contact-hero-address {
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.92);
  margin: 0.25rem 0 0;
  font-weight: 500;
}
.contact-hero-phone-line {
  font-size: 1rem;
  margin: 0.15rem 0 0;
  color: rgba(255, 255, 255, 0.88);
}
.contact-hero-phone-line a {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.2s ease;
}
.contact-hero-phone-line a:hover {
  color: var(--accent-light);
}
.contact-hero-form-card {
  background: #fff;
  color: var(--fg);
  border-radius: var(--radius);
  padding: clamp(1.75rem, 3vw, 2.5rem);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.28);
}
.contact-form-title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--fg);
  margin: 0 0 0.5rem;
}
.contact-hero-form-card .contact-form-desc {
  margin: 0 0 1.25rem;
}
.contact-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
@media (max-width: 640px) {
  .contact-form-grid {
    grid-template-columns: 1fr;
  }
}
.contact-prefs {
  border: none;
  padding: 0;
  margin: 0;
}
.contact-prefs legend {
  font-weight: 500;
  font-size: 0.875rem;
  color: var(--fg);
  margin-bottom: 0.5rem;
  padding: 0;
}
.contact-prefs-options {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem 1.75rem;
}
.contact-prefs-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  cursor: pointer;
}
.contact-prefs-label input {
  width: auto;
  accent-color: var(--accent);
}
.contact-form-submit {
  width: 100%;
  margin-top: 0.25rem;
}
.contact-form-errors {
  margin: 0;
  padding-left: 1.25rem;
}
.contact-form-errors li {
  margin: 0.25em 0;
}
.contact-honeypot {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.contact-captcha-prompt {
  margin: 0 0 0.5rem;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--fg);
}
.contact-captcha-hint {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.8125rem;
  color: var(--muted);
}
@media (max-width: 900px) {
  .hero.hero--contact {
    padding: 5.5rem 1.5rem 3rem;
  }
  .contact-hero-inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
}
.contact-main {
  max-width: 1440px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.75rem;
  padding: 5rem 7.5rem;
  background: white;
}
@media (max-width: 768px) {
  .contact-main {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding: 2.5rem 1.5rem;
  }
}
.contact-form-wrapper, .contact-info-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.contact-form-wrapper h2, .contact-info-wrapper h2 {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--fg);
  margin: 0;
}
.contact-form-desc {
  font-size: 0.9375rem;
  color: var(--muted);
  line-height: 1.7;
  margin: 0;
}
.form-group label .required {
  color: var(--booked);
}
.form-group input, .form-group select, .form-group textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-family: inherit;
  font-size: 1rem;
  background: white;
  transition: border-color 0.2s ease;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline: none;
  border-color: var(--accent);
}
.contact-info-item {
  display: flex;
  gap: 1rem;
}
.contact-info-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--accent);
}
.contact-info-item h3 {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--fg);
  margin: 0 0 0.25rem;
}
.contact-info-item p {
  font-size: 0.9375rem;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}
.contact-info-item a {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.2s ease;
}
.contact-info-item a:hover {
  color: var(--primary);
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 2.5rem;
  border: none;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
}
.btn-gold {
  background: var(--accent);
  color: var(--navy);
}
.btn-gold:hover {
  background: var(--accent-light);
}
.hero--practice-areas {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 160px;
  height: 160px;
  position: relative;
  background: var(--navy);
  color: white;
  text-align: center;
  padding: 0 7.5rem;
}
.hero--practice-areas .hero-bg {
  display: none;
}
.hero--practice-areas .hero-overlay {
  display: none;
}
.hero--practice-areas .hero-content {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
}
.hero--practice-areas .hero-label {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.25em;
  color: var(--accent);
  text-transform: uppercase;
  margin: 0;
}
.hero--practice-areas .hero-title {
  font-family: var(--font-heading);
  font-size: 3.25rem;
  font-weight: 700;
  color: white;
  margin: 0;
  line-height: 1.1;
}
.hero--practice-areas .hero-subtitle {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--accent-light);
  margin: 0;
  max-width: 600px;
  line-height: 1.4;
}
@media (max-width: 768px) {
  .hero--practice-areas {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    min-height: 140px;
    height: auto;
    padding-top: 1.75rem;
    padding-bottom: 1.75rem;
  }
  .hero--practice-areas .hero-title {
    font-size: clamp(1.85rem, 9vw, 2.5rem);
  }
  .hero--practice-areas .hero-subtitle {
    font-size: 0.9375rem;
  }
}
.practice-areas-section {
  background: var(--card);
  padding: 5rem 7.5rem;
}
.practice-areas-section .practice-areas-grid {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}
.practice-areas-section .practice-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.practice-areas-section .practice-card--reversed {
  direction: rtl;
}
.practice-areas-section .practice-card--reversed > * {
  direction: ltr;
}
@media (max-width: 1024px) {
  .practice-areas-section {
    padding: 3rem 1.5rem;
  }
  .practice-areas-section .practice-card {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .practice-areas-section .practice-card--reversed {
    direction: ltr;
  }
}
.practice-areas-section .practice-card-image {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  display: block;
  text-decoration: none;
}
.practice-areas-section .practice-card-image img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 500 / 380;
  transition: transform 0.3s ease;
}
.practice-areas-section .practice-card-image:hover img {
  transform: scale(1.05);
}
.practice-areas-section .practice-card-content {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.practice-areas-section .practice-label {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  color: var(--accent);
  text-transform: uppercase;
  margin: 0;
}
.practice-areas-section .practice-title {
  display: block;
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 0.5rem;
}
.practice-areas-section .practice-accent {
  width: 60px;
  height: 3px;
  background: var(--accent);
  margin: 0.5rem 0;
}
.practice-areas-section .practice-description {
  font-size: 1rem;
  color: var(--muted);
  line-height: 1.8;
  margin: 0;
}
.practice-areas-section .practice-btn {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  padding: 0.875rem 2rem;
  background: var(--navy);
  color: white;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 4px;
  transition: all 0.2s ease;
  cursor: pointer;
  border: none;
}
.practice-areas-section .practice-btn:hover {
  background: var(--navy-dark);
  transform: translateY(-2px);
}
.cta-section--practice {
  background: var(--accent);
  color: var(--navy);
}
.role-badge-super-admin {
  background: rgba(27, 42, 74, 0.2);
  color: var(--navy);
  font-weight: 600;
}
.role-badge-admin {
  background: rgba(45, 106, 79, 0.2);
  color: var(--available);
  font-weight: 600;
}
.role-badge-editor {
  background: rgba(193, 41, 46, 0.2);
  color: var(--booked);
  font-weight: 600;
}
body.cms-edit-mode [data-ed-key] {
  outline: 2px dashed rgba(201,169,110,0.5);
  outline-offset: 3px;
  cursor: text;
  border-radius: 2px;
  transition: outline-color 0.2s ease, background 0.2s ease;
}
body.cms-edit-mode [data-ed-key]:hover {
  outline-color: var(--accent);
  background: rgba(201,169,110,0.07);
}
body.cms-edit-mode [data-ed-key]:focus {
  outline-color: var(--accent);
  outline-style: solid;
  background: rgba(201,169,110,0.1);
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-border-style: solid;
      --tw-font-weight: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
    }
  }
}
