:root { --primary: #1f3026;
--primary-rgb: 31, 48, 38;
--primary-light: color-mix(in srgb, var(--primary) 12%, white);
--accent: #a37c3f;
--accent-rgb: 163, 124, 63;
--accent-dark: #7d5a27;
--accent-text: #d4b07c; --tertiary: #c9a26b;
--tertiary-rgb: 201, 162, 107; --sage: #b8d099;
--sage-rgb: 184, 208, 153; --dark-bg: #15211a; --bg-page: #1a2a20; --light-bg: #22332a; --surface: #2a3d31;  --parchment: #faf6ed;
--white: #fdfbf3;  --heading: #faf6ed;
--text: #f0e8d2;
--text-muted: rgba(240, 232, 210, 0.72);
--text-soft: rgba(240, 232, 210, 0.55);
--border: rgba(163, 124, 63, 0.18);
--border-gold: rgba(163, 124, 63, 0.42); --shadow-sm:   0 1px 2px rgba(0, 0, 0, 0.18), 0 1px 3px rgba(0, 0, 0, 0.28);
--shadow-md:   0 4px 6px rgba(0, 0, 0, 0.22), 0 10px 22px rgba(0, 0, 0, 0.36);
--shadow-lg:   0 10px 18px rgba(0, 0, 0, 0.28), 0 28px 56px rgba(0, 0, 0, 0.5);
--shadow-glow: 0 0 0 1px rgba(var(--accent-rgb), 0.15), 0 22px 44px rgba(var(--accent-rgb), 0.22); --space-xs:  8px;
--space-sm: 16px;
--space-md: 24px;
--space-lg: 40px;
--space-xl: 72px;
--space-2xl: 112px;
--space-3xl: 160px;
--container-width: 1240px;
--reading-width: 760px; --section-padding: var(--space-2xl) var(--space-md);
--card-padding: var(--space-lg) var(--space-md);
--card-radius: 16px;
--btn-radius: 4px; --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
--text-lg:   clamp(1.125rem, 1rem + 0.5vw, 1.375rem);
--text-xl:   clamp(1.375rem, 1.1rem + 1vw, 1.875rem);
--text-2xl:  clamp(1.875rem, 1.45rem + 1.75vw, 2.75rem);
--text-3xl:  clamp(2.25rem, 1.8rem + 2vw, 3.5rem);
--text-hero: clamp(2.75rem, 2rem + 3vw, 4.5rem);
--transition: 0.35s cubic-bezier(0.22, 1, 0.36, 1); --font-heading: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
--font-body:    'Lora', Georgia, 'Times New Roman', serif;
--font-reading: var(--font-body);
--font-ui:      'Tenor Sans', 'Cormorant Garamond', Georgia, serif;
}
html { overflow-x: hidden; scroll-behavior: smooth; }
html, body { background-color: var(--bg-page) !important; }
body {
font-family: var(--font-body);
font-size: var(--text-base);
line-height: 1.7;
color: var(--text);
background-color: var(--bg-page) !important;
background-image:
radial-gradient(at 12% 18%, rgba(163, 124, 63, 0.07) 0, transparent 40%),
radial-gradient(at 88% 72%, rgba(184, 208, 153, 0.04) 0, transparent 45%),
radial-gradient(at 50% 100%, rgba(125, 90, 39, 0.05) 0, transparent 55%);
background-attachment: fixed;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
} .wp-site-blocks,
.wp-site-blocks > main,
main.wp-block-group,
.wp-block-post-content {
background-color: transparent !important;
}
h1, h2, h3, h4 { font-family: var(--font-heading); color: var(--heading); font-weight: 600; }
h1 { font-size: var(--text-hero); line-height: 1.08; letter-spacing: -0.015em; }
h2 { font-size: var(--text-2xl); line-height: 1.15; letter-spacing: -0.01em; margin-bottom: var(--space-lg); }
h3 { font-size: var(--text-xl); line-height: 1.35; margin-bottom: var(--space-sm); }
a, button, .wp-block-button__link, input[type="submit"] { min-height: 44px; }
p a, li a, .breadcrumbs a, .footer-credits a, .post-author-box a, .dropdown a { min-height: 0; display: inline; }
img { max-width: 100%; height: auto; } .skip-link {
position: absolute; left: -9999px;
background: var(--primary); color: var(--parchment);
padding: 12px 18px; z-index: 999;
font-family: var(--font-ui); font-size: 0.85rem; letter-spacing: 0.18em; text-transform: uppercase;
}
.skip-link:focus { left: 16px; top: 16px; } .dcc-container,
.wp-block-group.dcc-container,
.site-main > .wp-block-post-content,
.site-main > .wp-block-query,
.site-main > article,
.site-main > .page-wrap,
.site-main > .post-wrap,
.site-main > .archive-wrap,
.site-main > .author-wrap,
.site-main > .error-wrap {
max-width: var(--container-width);
margin-inline: auto;
padding-inline: var(--space-md);
}
.entry-content img,
.wp-block-post-content img {
max-width: 100%;
height: auto;
border-radius: var(--card-radius);
}  .single-post .wp-block-post-title,
.page .wp-block-post-title {
font-size: var(--text-3xl);
line-height: 1.1;
letter-spacing: -0.015em;
font-family: var(--font-heading);
font-weight: 600;
color: var(--heading);
margin: var(--space-lg) 0 2rem;
max-width: var(--container-width);
} .section-label, .eyebrow {
font-family: var(--font-ui);
font-size: 0.78rem;
letter-spacing: 0.32em;
text-transform: uppercase;
color: var(--tertiary);
margin: 0 0 var(--space-md);
display: inline-flex;
align-items: center;
gap: var(--space-sm);
}
.section-label::before, .section-label::after,
.eyebrow::before, .eyebrow::after {
content: ""; width: 28px; height: 1px; background: var(--tertiary); opacity: 0.6;
}
.eyebrow.eyebrow--start::before { display: none; }
.section-subtitle {
font-size: var(--text-lg);
color: var(--text-muted);
max-width: 65ch;
margin: 0 auto var(--space-xl);
font-family: var(--font-heading);
font-style: italic;
font-weight: 400;
line-height: 1.55;
text-align: center;
}
.section-header { text-align: center; margin-bottom: var(--space-2xl); max-width: 760px; margin-left: auto; margin-right: auto; }
.section-header .section-subtitle { margin-left: auto; margin-right: auto; } .ornament {
display: flex; align-items: center; justify-content: center; gap: 16px;
margin: var(--space-md) auto var(--space-lg);
color: var(--accent);
}
.ornament .line { width: 64px; height: 1px; background: currentColor; opacity: 0.7; }
.ornament .diamond { width: 6px; height: 6px; background: currentColor; transform: rotate(45deg); }
.section-flourish {
display: flex; align-items: center; justify-content: center; gap: 14px;
margin: var(--space-md) auto var(--space-xl);
color: var(--accent);
}
.section-flourish svg { width: 24px; height: 24px; opacity: 0.85; }
.section-flourish .line { width: 60px; height: 1px; background: currentColor; opacity: 0.5; } .hero {
position: relative;
background-color: var(--primary);
background-image:
linear-gradient(135deg, rgba(21, 33, 26, 0.86), rgba(31, 48, 38, 0.7)),
url(https://images.unsplash.com/photo-1518173946687-a4c8892bbd9f?auto=format&fit=crop&w=1920&q=80);
background-size: cover; background-position: center;
padding: clamp(140px, 16vh, 220px) 0 clamp(96px, 11vh, 160px);
overflow: hidden;
width: 100vw; margin-left: calc(50% - 50vw);
text-align: center;
color: var(--parchment);
border-bottom: 1px solid rgba(163, 124, 63, 0.25);
}
.hero::before {
content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 1;
background:
radial-gradient(at 20% 30%, rgba(163, 124, 63, 0.18) 0, transparent 40%),
radial-gradient(at 78% 65%, rgba(201, 162, 107, 0.10) 0, transparent 45%);
}
.hero-content {
position: relative; z-index: 2;
max-width: 900px; margin: 0 auto; padding: 0 var(--space-md);
}
.hero h1 {
font-size: var(--text-hero);
font-weight: 500;
line-height: 1.08;
letter-spacing: -0.015em;
color: var(--parchment);
margin: 0 0 var(--space-md);
}
.hero h1 em { font-style: italic; color: var(--tertiary); font-weight: 500; }
.hero-subtitle {
font-size: var(--text-lg);
font-family: var(--font-heading);
font-style: italic;
color: rgba(250, 246, 237, 0.88);
margin: 0 auto var(--space-xl);
max-width: 620px;
line-height: 1.55;
}
.hero .eyebrow { color: var(--tertiary); justify-content: center; }
.hero .eyebrow::before, .hero .eyebrow::after { background: var(--tertiary); }
.hero-ctas { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; } .hero-botanical {
position: absolute; width: 240px; height: auto;
opacity: 0.32; pointer-events: none; color: var(--tertiary); z-index: 1;
}
.hero-botanical--left  { top: 20px;    left: -30px;  transform: rotate(-12deg); }
.hero-botanical--right { bottom: 30px; right: -40px; transform: rotate(165deg); }
@media (max-width: 700px) { .hero-botanical { width: 140px; opacity: 0.22; } } .scroll-indicator {
position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%);
color: rgba(250, 246, 237, 0.75);
font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase;
z-index: 2;
animation: dccBounce 2.6s ease-in-out infinite;
display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.scroll-indicator svg { width: 18px; height: 18px; }
@keyframes dccBounce {
0%, 100% { transform: translateX(-50%) translateY(0); }
50%      { transform: translateX(-50%) translateY(10px); }
} .site-header,
header.wp-block-template-part .site-header,
.wp-site-blocks > .site-header {
position: sticky; top: 0; z-index: 100; width: 100%;
background: rgba(250, 246, 237, 0.94);
backdrop-filter: saturate(180%) blur(12px);
-webkit-backdrop-filter: saturate(180%) blur(12px);
border-bottom: 1px solid var(--border);
transition: padding var(--transition), box-shadow var(--transition), background var(--transition);
padding: 0;
}
.site-header::after {
content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 1px;
background: linear-gradient(90deg,
transparent 0%, rgba(163, 124, 63, 0) 8%,
rgba(163, 124, 63, 0.5) 50%,
rgba(163, 124, 63, 0) 92%, transparent 100%);
pointer-events: none;
}
.site-header.scrolled {
box-shadow: 0 4px 24px rgba(31, 48, 38, 0.08);
background: rgba(250, 246, 237, 0.97);
} .site-header-inner,
.site-header > .site-header-inner,
.site-header .site-header-inner > .wp-block-group__inner-container {
display: flex; flex-direction: row;
align-items: center; justify-content: space-between;
gap: var(--space-lg);
max-width: var(--container-width);
margin-inline: auto;
padding: var(--space-sm) var(--space-md);
width: 100%;
transition: padding var(--transition);
}
.site-header.scrolled .site-header-inner { padding-top: 6px; padding-bottom: 6px; }
.site-logo,
.site-header .site-logo { display: inline-flex; align-items: center; flex-shrink: 0; margin: 0; }
.site-logo img { height: 64px; width: auto; display: block; margin: 0; transition: height var(--transition); }
.site-header.scrolled .site-logo img { height: 50px; }
@media (max-width: 600px) {
.site-logo img { height: 50px; }
.site-header.scrolled .site-logo img { height: 44px; }
} .site-header .wp-block-navigation { --wp--style--block-gap: var(--space-md) !important; }
.site-header .wp-block-navigation__container {
display: flex; align-items: center;
gap: var(--space-md) !important; column-gap: var(--space-md) !important; row-gap: 8px !important;
justify-content: flex-end !important;
flex-wrap: wrap;
}
.site-header .wp-block-navigation-item { position: relative; }
.site-header .wp-block-navigation-item a,
.site-header .wp-block-navigation-item button,
.site-header .wp-block-navigation .wp-block-navigation-item__content,
.site-header .wp-block-navigation .wp-block-navigation-submenu__toggle {
color: var(--primary) !important;
font-family: var(--font-ui);
font-weight: 400;
font-size: 0.78rem;
letter-spacing: 0.18em;
text-transform: uppercase;
padding: 12px 6px;
position: relative;
text-decoration: none;
background: transparent;
border: none;
cursor: pointer;
transition: color var(--transition);
}
.site-header .wp-block-navigation-item a:hover,
.site-header .wp-block-navigation-item button:hover,
.site-header .wp-block-navigation .wp-block-navigation-item__content:hover,
.site-header .wp-block-navigation .wp-block-navigation-submenu__toggle:hover {
color: var(--accent-dark) !important;
} .site-header .wp-block-navigation-item a::after {
content: '';
position: absolute; bottom: 4px; left: 50%;
width: 4px; height: 4px; background: var(--accent); border-radius: 50%;
transform: translateX(-50%) scale(0);
transition: transform var(--transition);
}
.site-header .wp-block-navigation-item a:hover::after,
.site-header .wp-block-navigation-item:focus-within > a::after { transform: translateX(-50%) scale(1); } .site-header .wp-block-navigation-item.header-cta a,
.site-header .header-cta > a {
background: var(--primary);
color: var(--parchment) !important;
padding: 12px 26px;
border-radius: var(--btn-radius);
font-family: var(--font-ui);
font-weight: 400;
font-size: 0.76rem;
letter-spacing: 0.22em;
text-transform: uppercase;
border: 1px solid var(--primary);
transition: all var(--transition);
position: relative;
overflow: hidden;
white-space: nowrap;
}
.site-header .wp-block-navigation-item.header-cta a::before,
.site-header .header-cta > a::before {
content: ""; position: absolute; inset: 3px;
border: 1px solid rgba(201, 162, 107, 0.35);
border-radius: 2px; pointer-events: none;
transition: border-color var(--transition);
}
.site-header .wp-block-navigation-item.header-cta a:hover,
.site-header .header-cta > a:hover {
background: var(--accent-dark); border-color: var(--accent-dark);
color: var(--parchment) !important;
transform: translateY(-2px);
box-shadow: 0 8px 20px rgba(125, 90, 39, 0.3);
}
.site-header .wp-block-navigation-item.header-cta a:hover::before,
.site-header .header-cta > a:hover::before { border-color: rgba(250, 246, 237, 0.35); }
.site-header .wp-block-navigation-item.header-cta a::after,
.site-header .header-cta > a::after { display: none; } .site-header .wp-block-navigation .wp-block-navigation__submenu-container {
background: rgba(250, 246, 237, 0.98);
backdrop-filter: saturate(180%) blur(12px);
-webkit-backdrop-filter: saturate(180%) blur(12px);
border: 1px solid var(--border-gold);
border-top: 2px solid var(--accent);
border-radius: 4px;
box-shadow: 0 12px 32px rgba(31, 48, 38, 0.18), 0 4px 12px rgba(31, 48, 38, 0.1);
padding: 14px 10px;
min-width: 280px;
}
.site-header .wp-block-navigation .wp-block-navigation__submenu-container::before {
content: "";
position: absolute; top: -5px; left: 50%;
transform: translateX(-50%) rotate(45deg);
width: 8px; height: 8px; background: var(--accent);
}
.site-header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item a,
.site-header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item button,
.site-header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
padding: 11px 16px;
border-radius: 3px;
font-family: var(--font-body);
font-size: 0.96rem;
letter-spacing: 0;
text-transform: none;
color: var(--primary) !important;
font-weight: 400;
white-space: nowrap;
background: transparent;
border: none;
}
.site-header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item a::after { display: none; }
.site-header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item a:hover,
.site-header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item button:hover,
.site-header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
background: rgba(163, 124, 63, 0.10);
color: var(--accent-dark) !important;
} .trust-bar {
background: var(--light-bg);
background-image:
radial-gradient(ellipse at 50% 50%, rgba(163, 124, 63, 0.05) 0, transparent 60%);
padding: var(--space-xl) var(--space-md);
border-top: 1px solid var(--border-gold);
border-bottom: 1px solid var(--border-gold);
width: 100vw; margin-left: calc(50% - 50vw);
}
.trust-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
gap: var(--space-md);
align-items: center;
text-align: center;
max-width: var(--container-width);
margin: 0 auto;
}
.trust-item {
display: flex; flex-direction: column; align-items: center;
gap: var(--space-xs); padding: var(--space-sm);
}
.trust-item svg { width: 36px; height: 36px; color: var(--tertiary); }
.trust-item span {
font-family: var(--font-ui);
font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
color: var(--heading);
} section { padding: var(--section-padding); position: relative; } .bg-parchment,
.bg-deep,
.bg-dark {
width: 100vw;
margin-left: calc(50% - 50vw);
}
.bg-parchment {
background: var(--bg-page);
background-image:
radial-gradient(ellipse at 22% 18%, rgba(163, 124, 63, 0.08) 0, transparent 55%),
radial-gradient(ellipse at 78% 82%, rgba(125, 90, 39, 0.05) 0, transparent 50%);
border-top: 1px solid rgba(163, 124, 63, 0.12);
}
.bg-deep {
background: var(--light-bg);
background-image:
radial-gradient(ellipse at 70% 22%, rgba(201, 162, 107, 0.07) 0, transparent 55%),
radial-gradient(ellipse at 22% 78%, rgba(184, 208, 153, 0.05) 0, transparent 50%);
border-top: 1px solid rgba(163, 124, 63, 0.12);
}
.bg-dark {
background: var(--dark-bg);
color: var(--parchment);
}
.bg-dark h2, .bg-dark h3 { color: var(--parchment); }
.bg-dark .section-subtitle { color: rgba(250, 246, 237, 0.78); }
.bg-dark .eyebrow, .bg-dark .section-label { color: var(--tertiary); }
.bg-dark .eyebrow::before, .bg-dark .eyebrow::after,
.bg-dark .section-label::before, .bg-dark .section-label::after { background: var(--tertiary); } .section-divider { display: block; width: 100%; height: 60px; margin: 0; color: var(--light-bg); }
.section-divider--dark { color: var(--dark-bg); } .rooms-grid,
.services-grid,
.topic-grid,
.blog-grid,
.testimonials-grid,
.testimonial-grid { padding-top: var(--space-md); }
.rooms-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: var(--space-lg);
}
.room-card {
background: var(--surface);
border: 1px solid var(--border);
border-radius: var(--card-radius);
padding: var(--card-padding);
position: relative;
overflow: hidden;
transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
display: flex; flex-direction: column;
will-change: transform;
}
.room-card::before {
content: ""; position: absolute; top: -1px; left: 50%;
transform: translateX(-50%);
width: 80px; height: 40px;
background: var(--accent);
border-radius: 0 0 80px 80px / 0 0 40px 40px;
opacity: 0.85;
transition: width var(--transition), height var(--transition);
}
.room-card:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-lg);
border-color: var(--border-gold);
}
.room-card:hover::before { width: 100%; height: 5px; border-radius: 0; } .page-wrap,
.post-wrap,
.archive-wrap,
.author-wrap {
padding-bottom: var(--space-2xl) !important;
}
.room-icon {
width: 56px; height: 56px;
margin: var(--space-md) 0 var(--space-md);
color: var(--tertiary);
transition: transform var(--transition), color var(--transition);
}
.room-card:hover .room-icon { transform: scale(1.08) rotate(3deg); color: var(--sage); }
.room-card p { color: var(--text-muted); flex-grow: 1; } .text-link {
font-family: var(--font-ui);
font-size: 0.82rem; letter-spacing: 0.22em; text-transform: uppercase;
color: var(--accent-text);
display: inline-flex; align-items: center; gap: 8px;
text-decoration: none;
transition: gap var(--transition), color var(--transition);
margin-top: var(--space-sm);
}
.text-link:hover { gap: 14px; color: var(--heading); }
.text-link .arrow { transition: transform var(--transition); }
.text-link:hover .arrow { transform: translateX(4px); } .values-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
gap: var(--space-lg);
margin-bottom: var(--space-xl);
}
.value-card {
position: relative;
padding: var(--space-lg) var(--space-md) var(--space-lg) var(--space-lg);
background: var(--surface);
border-radius: 4px;
border-left: 1px solid var(--border-gold);
transition: transform var(--transition), box-shadow var(--transition);
}
.value-card::before {
content: ""; position: absolute; left: -1px; top: 0; bottom: 0;
width: 0; background: var(--accent);
transition: width var(--transition);
}
.value-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.value-card:hover::before { width: 3px; }
.value-icon { width: 32px; height: 32px; color: var(--tertiary); margin-bottom: var(--space-md); }
.value-card h3 { font-size: 1.5rem; font-style: italic; font-weight: 500; color: var(--heading); }
.value-card p { color: var(--text-muted); margin: 0; }
.values-cta { text-align: center; margin-top: var(--space-lg); } .tips-pills {
display: flex; flex-wrap: wrap; gap: var(--space-sm); justify-content: center;
max-width: 880px; margin: 0 auto;
}
.pill {
display: inline-flex; align-items: center; gap: 10px;
padding: 14px 26px;
background: var(--surface);
border: 1px solid var(--border-gold);
border-radius: 999px;
font-family: var(--font-heading);
font-size: 1.15rem;
color: var(--heading);
text-decoration: none;
transition: all var(--transition);
}
.pill svg { width: 16px; height: 16px; color: var(--tertiary); transition: color var(--transition); }
.pill:hover {
background: var(--accent-dark); color: var(--parchment);
border-color: var(--accent); transform: translateY(-3px);
box-shadow: var(--shadow-md);
}
.pill:hover svg { color: var(--tertiary); } .testimonials-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: var(--space-lg);
}
.testimonial-card,
.wp-block-column.testimonial-card {
background: var(--surface);
padding: var(--space-lg) var(--space-md);
border-radius: var(--card-radius);
border: 1px solid var(--border);
position: relative;
transition: transform var(--transition), box-shadow var(--transition);
will-change: transform;
}
.testimonial-card:hover,
.wp-block-column.testimonial-card:hover {
transform: translateY(-4px) rotate(-0.5deg);
box-shadow: var(--shadow-md);
}
.testimonial-quote-icon, .quote-mark {
width: 36px; height: 36px;
color: var(--accent); opacity: 0.55;
margin-bottom: var(--space-sm);
transition: transform var(--transition);
}
.testimonial-card:hover .testimonial-quote-icon,
.testimonial-card:hover .quote-mark { transform: scale(1.15); }
.testimonial-card blockquote {
margin: 0 0 var(--space-md);
font-family: var(--font-heading);
font-style: italic;
font-size: 1.2rem; line-height: 1.5;
color: var(--text);
}
.testimonial-card cite {
font-style: normal;
font-family: var(--font-ui);
font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
color: var(--tertiary);
display: block;
border-top: 1px solid var(--border-gold);
padding-top: var(--space-sm);
}
.testimonial-card cite span {
display: block; margin-top: 4px;
letter-spacing: 0.08em; text-transform: none;
color: var(--text-soft);
font-size: 0.75rem;
} .blog-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: var(--space-lg);
}
.blog-card {
background: var(--surface);
border-radius: var(--card-radius);
border: 1px solid var(--border);
overflow: hidden;
position: relative;
transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
display: flex; flex-direction: column;
will-change: transform;
}
.blog-card::before {
content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
background: linear-gradient(90deg, var(--accent-dark), var(--accent), var(--tertiary));
}
.blog-card:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-lg);
border-color: var(--border-gold);
}
.blog-card-body { padding: var(--space-lg) var(--space-md); display: flex; flex-direction: column; flex-grow: 1; }
.blog-date {
font-family: var(--font-ui);
font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase;
color: var(--tertiary);
margin-bottom: var(--space-sm);
}
.blog-card h3 { margin-bottom: var(--space-sm); color: var(--heading); }
.blog-card p {
color: var(--text-muted); flex-grow: 1;
font-family: var(--font-heading);
font-style: italic;
font-size: 1.1rem; line-height: 1.5;
} .final-cta {
background:
linear-gradient(135deg, rgba(21, 33, 26, 0.95), rgba(31, 48, 38, 0.92)),
var(--dark-bg);
color: var(--parchment);
text-align: center;
padding: var(--space-3xl) var(--space-md);
position: relative;
overflow: hidden;
width: 100vw; margin-left: calc(50% - 50vw);
}
.final-cta::before {
content: ""; position: absolute; inset: 0; pointer-events: none;
background:
radial-gradient(at 25% 50%, rgba(163, 124, 63, 0.16) 0, transparent 45%),
radial-gradient(at 75% 50%, rgba(201, 162, 107, 0.10) 0, transparent 45%);
}
.final-cta .dcc-container { position: relative; z-index: 2; }
.final-cta h2,
.final-cta .wp-block-heading {
color: var(--parchment) !important;
margin-bottom: var(--space-md);
}
.final-cta h2 em,
.final-cta .wp-block-heading em {
color: var(--sage);
font-style: italic;
font-weight: 500;
}
.final-cta p {
color: rgba(250, 246, 237, 0.82);
max-width: 580px; margin: 0 auto var(--space-lg);
font-family: var(--font-heading);
font-style: italic;
font-size: var(--text-lg);
}
.cta-branch {
position: absolute; width: 220px;
opacity: 0.18; color: var(--tertiary); pointer-events: none;
}
.cta-branch--left  { top: 30px;    left: -20px;  transform: rotate(-10deg); }
.cta-branch--right { bottom: 20px; right: -30px; transform: rotate(170deg); }
@media (max-width: 700px) { .cta-branch { width: 130px; opacity: 0.12; } } .wp-block-button .wp-block-button__link.has-primary-background-color,
.wp-block-button .wp-block-button__link.has-accent-background-color,
.wp-block-button .wp-block-button__link.has-tertiary-background-color,
.wp-block-button .wp-block-button__link.has-dark-bg-background-color {
color: #fdfbf3 !important;
font-family: var(--font-ui);
font-weight: 400;
font-size: 0.85rem;
letter-spacing: 0.18em;
text-transform: uppercase;
box-shadow: 0 6px 16px rgba(var(--primary-rgb), 0.22);
transition: background var(--transition), transform var(--transition), box-shadow var(--transition), color var(--transition);
position: relative; overflow: hidden;
border-radius: var(--btn-radius);
} .wp-block-button .wp-block-button__link.has-primary-background-color {
background: linear-gradient(135deg, var(--primary) 0%, color-mix(in srgb, var(--primary) 80%, var(--accent)) 100%) !important;
}
.wp-block-button .wp-block-button__link.has-primary-background-color:hover {
background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 80%, var(--accent)) 0%, var(--accent-dark) 100%) !important;
color: #fdfbf3 !important;
transform: translateY(-3px);
box-shadow: 0 12px 28px rgba(var(--primary-rgb), 0.40);
} .wp-block-button .wp-block-button__link.has-accent-background-color {
background: var(--accent-dark) !important;
}
.wp-block-button .wp-block-button__link.has-accent-background-color:hover {
background: var(--accent) !important;
color: #fdfbf3 !important;
transform: translateY(-3px);
box-shadow: 0 12px 28px rgba(var(--accent-rgb), 0.40);
} .wp-block-button .wp-block-button__link.has-primary-background-color::after,
.wp-block-button .wp-block-button__link.has-accent-background-color::after {
content: '';
position: absolute; top: 0; left: -100%; width: 100%; height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.22), transparent);
transition: left 0.6s ease; pointer-events: none;
}
.wp-block-button .wp-block-button__link.has-primary-background-color:hover::after,
.wp-block-button .wp-block-button__link.has-accent-background-color:hover::after { left: 100%; } .wp-block-button.is-style-outline .wp-block-button__link,
.btn-ghost {
background: transparent !important;
color: var(--parchment) !important;
border: 1px solid rgba(250, 246, 237, 0.4) !important;
font-family: var(--font-ui);
font-weight: 400; font-size: 0.85rem;
letter-spacing: 0.18em; text-transform: uppercase;
border-radius: var(--btn-radius);
transition: all var(--transition);
}
.wp-block-button.is-style-outline .wp-block-button__link:hover,
.btn-ghost:hover {
background: rgba(250, 246, 237, 0.1) !important;
border-color: var(--parchment) !important;
color: var(--parchment) !important;
transform: translateY(-3px);
} .btn-primary {
position: relative; overflow: hidden;
border-radius: var(--btn-radius);
color: var(--parchment);
transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn-primary:hover {
background: var(--accent-dark);
transform: translateY(-3px);
box-shadow: 0 8px 24px rgba(var(--accent-rgb), 0.35);
color: var(--parchment);
} .breadcrumbs {
font-size: 0.875rem;
color: var(--text-muted);
padding: var(--space-md) 0 0;
margin-bottom: var(--space-md);
max-width: var(--container-width);
margin-inline: auto;
padding-inline: var(--space-md);
font-family: var(--font-body);
}
.breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.breadcrumbs li + li::before { content: "·"; margin-right: var(--space-xs); color: var(--accent); }
.breadcrumbs a { color: var(--text-muted); text-decoration: none; min-height: 0; }
.breadcrumbs a:hover { color: var(--accent-text); text-decoration: underline; }
.breadcrumbs [aria-current="page"] { color: var(--heading); font-weight: 500; } .post-top-meta {
max-width: var(--container-width);
margin: 0 0 5rem;
padding: var(--space-sm) 0 0;
}
.reading-time-badge {
display: inline-flex;
align-items: center;
gap: 8px;
background: linear-gradient(135deg, var(--primary), var(--accent));
color: var(--parchment);
padding: 9px 20px 9px 16px;
border-radius: 999px;
font-family: var(--font-ui);
font-weight: 400;
font-size: 0.78rem;
text-transform: uppercase;
letter-spacing: 0.18em;
box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.25);
line-height: 1;
}
.reading-time-badge svg { width: 16px; height: 16px; flex-shrink: 0; color: rgba(255, 255, 255, 0.92); } .single-post .entry-content,
.page .wp-block-post-content,
.single-post .wp-block-post-content,
.entry-content,
body .wp-block-post-content {
font-family: var(--font-reading) !important;
font-size: 1.1875rem;
line-height: 1.85;
color: var(--text);
} .entry-content p,
.entry-content .wp-block-paragraph,
.wp-block-post-content p,
.wp-block-post-content .wp-block-paragraph {
margin-top: 0 !important;
margin-bottom: 1.75em !important;
font-family: var(--font-reading) !important;
}
.entry-content p:last-child,
.wp-block-post-content p:last-child { margin-bottom: 0 !important; } .entry-content h2,
.entry-content h2.wp-block-heading,
.wp-block-post-content h2,
.wp-block-post-content h2.wp-block-heading {
font-size: clamp(1.875rem, 1.5rem + 1.6vw, 2.5rem) !important;
line-height: 1.2 !important;
letter-spacing: -0.01em;
font-family: var(--font-heading) !important;
font-weight: 600 !important;
color: var(--heading) !important;
margin-top: 5rem !important;
margin-bottom: 1.75rem !important;
padding-top: 2.5rem !important;
border-top: 1px solid var(--border) !important;
}
.entry-content h2:first-child,
.entry-content h2.wp-block-heading:first-child,
.entry-content > h2:first-of-type,
.entry-content > h2.wp-block-heading:first-of-type,
.wp-block-post-content h2:first-child,
.wp-block-post-content h2.wp-block-heading:first-child,
.wp-block-post-content > h2:first-of-type,
.wp-block-post-content > h2.wp-block-heading:first-of-type {
margin-top: 2.5rem !important;
padding-top: 0 !important;
border-top: none !important;
} .wp-block-post-content section h2,
.wp-block-post-content section h2.wp-block-heading,
.wp-block-post-content section h3,
.wp-block-post-content section h3.wp-block-heading,
.wp-block-post-content section h4,
.wp-block-post-content section h4.wp-block-heading,
.wp-block-post-content .section-header h2,
.wp-block-post-content .section-header h2.wp-block-heading,
.wp-block-post-content .final-cta h2,
.wp-block-post-content .final-cta h2.wp-block-heading {
margin-top: 0 !important;
padding-top: 0 !important;
border-top: none !important;
}
.wp-block-post-content section h2,
.wp-block-post-content section h2.wp-block-heading {
margin-bottom: var(--space-md) !important;
}
.wp-block-post-content section h3,
.wp-block-post-content section h3.wp-block-heading {
margin-bottom: var(--space-sm) !important;
} .entry-content h3,
.entry-content h3.wp-block-heading,
.wp-block-post-content h3,
.wp-block-post-content h3.wp-block-heading {
font-size: clamp(1.4rem, 1.2rem + 0.7vw, 1.7rem) !important;
line-height: 1.3 !important;
font-family: var(--font-heading) !important;
font-weight: 600 !important;
color: var(--heading) !important;
margin-top: 3.5rem !important;
margin-bottom: 1.25rem !important;
} .entry-content h4,
.entry-content h4.wp-block-heading,
.wp-block-post-content h4,
.wp-block-post-content h4.wp-block-heading {
font-size: 1.25rem !important;
line-height: 1.4 !important;
font-family: var(--font-heading) !important;
font-weight: 600 !important;
color: var(--heading) !important;
margin-top: 2.75rem !important;
margin-bottom: 1rem !important;
}
.entry-content h2 + h3,
.entry-content h2.wp-block-heading + h3.wp-block-heading,
.entry-content h3 + h4,
.wp-block-post-content h2 + h3,
.wp-block-post-content h3 + h4 { margin-top: 1.75rem !important; } .entry-content ul,
.entry-content ol,
.entry-content .wp-block-list,
.wp-block-post-content ul,
.wp-block-post-content ol,
.wp-block-post-content .wp-block-list {
margin-top: 0 !important;
margin-bottom: 2rem !important;
padding-left: 1.5em;
font-family: var(--font-reading) !important;
}
.entry-content li,
.wp-block-post-content li { margin-bottom: 0.85rem !important; line-height: 1.75; }
.entry-content li > p,
.wp-block-post-content li > p { margin-bottom: 0.5rem !important; }
.entry-content li > ul,
.entry-content li > ol,
.wp-block-post-content li > ul,
.wp-block-post-content li > ol { margin-top: 0.5rem !important; margin-bottom: 0.5rem !important; } .entry-content figure,
.entry-content .wp-block-image,
.wp-block-post-content figure,
.wp-block-post-content .wp-block-image {
margin-top: 4rem !important;
margin-bottom: 4rem !important;
margin-left: auto !important;
margin-right: auto !important;
display: block;
}
.entry-content figure img,
.entry-content .wp-block-image img,
.wp-block-post-content figure img,
.wp-block-post-content .wp-block-image img {
border-radius: var(--card-radius);
box-shadow: var(--shadow-sm);
}
.entry-content figcaption,
.wp-block-post-content figcaption {
text-align: center;
color: var(--text-muted);
font-size: 0.95rem;
margin-top: 1rem !important;
font-style: italic;
font-family: var(--font-reading);
} .entry-content blockquote,
.entry-content .wp-block-quote,
.wp-block-post-content blockquote,
.wp-block-post-content .wp-block-quote {
margin-top: 4rem !important;
margin-bottom: 4rem !important;
padding: 2rem 2.5rem !important;
border-left: 4px solid var(--accent) !important;
background: rgba(163, 124, 63, 0.10) !important;
border-radius: 0 var(--card-radius) var(--card-radius) 0 !important;
font-style: italic;
font-size: 1.25rem;
line-height: 1.7;
font-family: var(--font-reading) !important;
color: var(--text);
}
.entry-content blockquote p,
.wp-block-post-content blockquote p { margin-bottom: 0.75rem !important; }
.entry-content blockquote p:last-child,
.wp-block-post-content blockquote p:last-child { margin-bottom: 0 !important; } .entry-content table,
.entry-content .wp-block-table,
.entry-content .wp-block-table table,
.wp-block-post-content table,
.wp-block-post-content .wp-block-table,
.wp-block-post-content .wp-block-table table {
margin-top: 4rem !important;
margin-bottom: 4rem !important;
width: 100%;
border-collapse: collapse;
font-size: 0.975rem;
font-family: var(--font-body) !important;
}
.entry-content .wp-block-table,
.wp-block-post-content .wp-block-table {
background: var(--surface);
border: 1px solid var(--border);
border-radius: var(--card-radius);
overflow: hidden;
box-shadow: var(--shadow-sm);
overflow-x: auto;
-webkit-overflow-scrolling: touch;
}
.entry-content .wp-block-table table,
.wp-block-post-content .wp-block-table table { margin-top: 0 !important; margin-bottom: 0 !important; border: none; box-shadow: none; border-radius: 0; }
.entry-content table th,
.entry-content table td,
.wp-block-post-content table th,
.wp-block-post-content table td {
padding: 18px 22px !important;
text-align: left;
border-bottom: 1px solid var(--border);
vertical-align: top;
line-height: 1.6;
}
.entry-content table th,
.wp-block-post-content table th {
background: var(--surface);
color: var(--heading);
font-family: var(--font-heading) !important;
font-weight: 600;
font-size: 0.95rem;
letter-spacing: 0.02em;
}
.entry-content table tr:last-child td,
.wp-block-post-content table tr:last-child td { border-bottom: none; }
.entry-content table tr:hover td,
.wp-block-post-content table tr:hover td { background: rgba(163, 124, 63, 0.06); } .entry-content pre,
.entry-content .wp-block-code,
.wp-block-post-content pre,
.wp-block-post-content .wp-block-code {
margin-top: 3rem !important;
margin-bottom: 3rem !important;
padding: 1.75rem !important;
background: var(--dark-bg);
color: rgba(255, 255, 255, 0.92);
border-radius: var(--card-radius);
font-family: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace !important;
font-size: 0.95rem;
line-height: 1.65;
overflow-x: auto;
box-shadow: var(--shadow-sm);
}
.entry-content code,
.wp-block-post-content code {
background: rgba(var(--primary-rgb), 0.06);
padding: 2px 7px;
border-radius: 6px;
font-size: 0.9em;
font-family: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace !important;
color: var(--text);
}
.entry-content pre code,
.wp-block-post-content pre code { background: transparent; padding: 0; border-radius: 0; color: inherit; font-size: inherit; } .entry-content hr,
.entry-content .wp-block-separator,
.wp-block-post-content hr,
.wp-block-post-content .wp-block-separator {
margin-top: 5rem !important;
margin-bottom: 5rem !important;
border: none;
height: 1px;
background: var(--border-gold);
max-width: 200px;
margin-left: auto !important;
margin-right: auto !important;
} .entry-content p a,
.entry-content li a,
.entry-content td a,
.wp-block-post-content p a,
.wp-block-post-content li a,
.wp-block-post-content td a {
color: var(--accent-text);
text-decoration: underline;
text-decoration-thickness: 1px;
text-underline-offset: 3px;
transition: color var(--transition);
}
.entry-content p a:hover,
.entry-content li a:hover,
.entry-content td a:hover,
.wp-block-post-content p a:hover,
.wp-block-post-content li a:hover,
.wp-block-post-content td a:hover {
color: var(--parchment);
text-decoration-thickness: 2px;
text-decoration-color: var(--accent);
} .entry-content.is-layout-flow > *,
.wp-block-post-content.is-layout-flow > *,
.single-post .entry-content.is-layout-flow > *,
.page .wp-block-post-content.is-layout-flow > * {
margin-block-start: revert;
margin-block-end: revert;
} .entry-content h2, .entry-content h3 { position: relative; scroll-margin-top: 120px; }
.entry-content h2 .heading-anchor,
.entry-content h3 .heading-anchor {
position: absolute; left: -1.5em; top: 50%; transform: translateY(-50%);
opacity: 0; text-decoration: none; color: var(--accent-text);
font-weight: 400; transition: opacity var(--transition); min-height: 0;
}
.entry-content h2:hover .heading-anchor,
.entry-content h3:hover .heading-anchor,
.entry-content .heading-anchor:focus-visible { opacity: 1; }
@media (max-width: 900px) { .entry-content .heading-anchor { display: none; } } .post-author-box {
background: var(--light-bg);
border: 1px solid var(--border);
border-radius: var(--card-radius);
padding: var(--space-lg);
margin: var(--space-2xl) auto var(--space-lg);
max-width: var(--container-width);
display: grid;
grid-template-columns: 72px 1fr;
gap: var(--space-md);
align-items: center;
box-shadow: var(--shadow-sm);
}
.post-author-box .wp-block-avatar img {
width: 72px; height: 72px; border-radius: 50%;
border: 2px solid var(--surface); box-shadow: var(--shadow-sm);
}
.post-author-box__content { display: flex; flex-direction: column; gap: 4px; }
.post-author-box__label {
text-transform: uppercase; letter-spacing: 0.18em;
font-size: 0.72rem; color: var(--tertiary);
font-family: var(--font-ui); font-weight: 400;
margin: 0;
}
.post-author-box .wp-block-post-author-name {
font-family: var(--font-heading);
font-size: 1.4rem; font-weight: 600;
color: var(--heading); margin: 0;
}
.post-author-box .wp-block-post-author-name a { color: inherit; text-decoration: none; }
.post-author-box .wp-block-post-author-name a:hover { color: var(--tertiary); }
.post-author-box__dates { display: flex; flex-wrap: wrap; gap: var(--space-lg); margin-top: var(--space-sm); }
.post-author-box__field { display: flex; flex-direction: column; gap: 2px; }
.post-author-box__field-label {
text-transform: uppercase; letter-spacing: 0.12em;
font-size: 0.68rem; color: var(--text-muted);
font-family: var(--font-ui); font-weight: 400;
}
.post-author-box__field-value { font-size: 0.9375rem; color: var(--text); font-weight: 500; }
.post-author-box__field-value a { color: var(--accent-text); text-decoration: none; }
.post-author-box__field-value a:hover { text-decoration: underline; }
@media (max-width: 600px) {
.post-author-box { grid-template-columns: 1fr; text-align: center; }
.post-author-box .wp-block-avatar { margin: 0 auto; }
.post-author-box__dates { justify-content: center; }
} .related-posts {
max-width: var(--container-width);
margin: var(--space-2xl) auto var(--space-xl);
padding: 0 var(--space-md);
}
.related-posts h2 {
font-size: var(--text-2xl);
margin-bottom: var(--space-lg);
text-align: center;
line-height: 1.15;
letter-spacing: -0.01em;
}
.related-posts__grid {
display: grid; gap: var(--space-lg);
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.related-posts__card {
background: var(--surface);
border: 1px solid var(--border);
border-radius: var(--card-radius);
padding: var(--space-lg);
text-decoration: none;
color: inherit;
transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
box-shadow: var(--shadow-sm);
display: block; min-height: 0;
}
.related-posts__card:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-lg);
border-color: var(--border-gold);
color: inherit;
}
.related-posts__card h3 {
font-size: 1.4rem; line-height: 1.3;
margin: 0 0 var(--space-sm);
color: var(--heading);
font-family: var(--font-heading);
}
.related-posts__card time {
font-size: 0.78rem;
color: var(--tertiary);
text-transform: uppercase;
letter-spacing: 0.18em;
font-family: var(--font-ui);
} .archive-wrap h1.wp-block-heading,
.archive-wrap .wp-block-query-title {
font-size: var(--text-3xl);
line-height: 1.1;
letter-spacing: -0.015em;
color: var(--heading);
margin: var(--space-lg) 0 var(--space-md);
text-align: center;
}
.archive-wrap .section-subtitle { margin-bottom: var(--space-2xl); }
.archive-wrap .wp-block-post-template {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: var(--space-lg);
list-style: none;
padding: 0;
margin: 0;
}
.archive-wrap .wp-block-post-template > li {
background: var(--surface);
border: 1px solid var(--border);
border-radius: var(--card-radius);
padding: var(--card-padding);
transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.archive-wrap .wp-block-post-template > li:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-lg);
border-color: var(--border-gold);
}
.archive-wrap .wp-block-post-title { font-family: var(--font-heading); font-size: 1.4rem; margin: 0 0 var(--space-sm); }
.archive-wrap .wp-block-post-title a { color: var(--heading); text-decoration: none; }
.archive-wrap .wp-block-post-title a:hover { color: var(--tertiary); }
.archive-wrap .wp-block-post-excerpt {
color: var(--text-muted);
font-family: var(--font-heading); font-style: italic;
font-size: 1.05rem; line-height: 1.55;
margin: 0 0 var(--space-sm);
}
.archive-wrap .wp-block-post-date { font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--tertiary); }
.archive-wrap .wp-block-post-date a { color: inherit; text-decoration: none; }
.archive-wrap .wp-block-query-pagination {
display: flex; justify-content: center; gap: var(--space-md);
margin-top: var(--space-2xl);
font-family: var(--font-ui);
letter-spacing: 0.18em;
text-transform: uppercase;
font-size: 0.78rem;
} .author-hero {
display: flex; align-items: center; gap: var(--space-lg);
margin: var(--space-lg) 0 var(--space-2xl);
}
.author-hero .wp-block-avatar img {
border-radius: 50%;
border: 2px solid var(--surface);
box-shadow: var(--shadow-sm);
}
.author-hero h1 { margin: 0 0 var(--space-sm); }
.author-hero .wp-block-post-author-biography { color: var(--text-muted); font-family: var(--font-heading); font-style: italic; } .error-wrap { text-align: center; padding-top: var(--space-2xl); padding-bottom: var(--space-3xl); }
.error-wrap h1 { margin-bottom: var(--space-md); }
.error-wrap p { color: var(--text-muted); font-family: var(--font-heading); font-style: italic; font-size: var(--text-lg); margin-bottom: var(--space-xl); }
.error-wrap .wp-block-search { max-width: 480px; margin: 0 auto var(--space-xl); }
.error-wrap .wp-block-buttons { justify-content: center; } .wp-block-search .wp-block-search__input {
background: var(--surface);
border: 1px solid var(--border-gold);
color: var(--text);
padding: 12px 16px;
border-radius: var(--btn-radius);
font-family: var(--font-body);
}
.wp-block-search .wp-block-search__input::placeholder { color: var(--text-soft); }
.wp-block-search .wp-block-search__input:focus { outline: 2px solid var(--accent); outline-offset: 1px; }
.wp-block-search .wp-block-search__button {
background: var(--accent-dark);
color: var(--parchment);
border: none;
font-family: var(--font-ui);
font-size: 0.78rem;
letter-spacing: 0.18em;
text-transform: uppercase;
padding: 12px 22px;
border-radius: var(--btn-radius);
cursor: pointer;
transition: background var(--transition);
min-height: 44px;
}
.wp-block-search .wp-block-search__button:hover { background: var(--accent); } .site-footer {
background: var(--dark-bg) !important;
color: rgba(250, 246, 237, 0.82);
padding: var(--space-2xl) 0 0 !important;
margin: 0 !important;
width: 100%;
font-family: var(--font-body);
}
.site-footer h4 {
color: var(--tertiary) !important;
font-family: var(--font-ui);
font-size: 0.82rem;
letter-spacing: 0.22em;
text-transform: uppercase;
font-weight: 400;
margin-bottom: var(--space-md);
padding-bottom: var(--space-sm);
border-bottom: 1px solid rgba(163, 124, 63, 0.35);
}
.footer-grid {
display: grid;
grid-template-columns: 1.4fr 1fr 1fr 1fr;
gap: var(--space-xl);
max-width: var(--container-width);
margin: 0 auto;
padding: 0 var(--space-md) var(--space-xl);
}
.footer-col p {
color: rgba(250, 246, 237, 0.7);
font-family: var(--font-heading);
font-style: italic;
font-size: 1.05rem;
line-height: 1.55;
margin-bottom: var(--space-md);
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: 10px; }
.footer-col li a {
color: rgba(250, 246, 237, 0.82);
font-size: 0.95rem;
text-decoration: none;
transition: color var(--transition), padding-left var(--transition);
display: inline-block; min-height: 0;
}
.footer-col li a:hover { color: var(--tertiary); padding-left: 4px; }
.footer-contact { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.footer-contact a {
color: rgba(250, 246, 237, 0.82); text-decoration: none;
transition: color var(--transition); min-height: 0; display: inline-block;
}
.footer-contact a:hover { color: var(--tertiary); } .newsletter-form { display: flex; flex-direction: column; gap: 10px; }
.newsletter-form input {
background: rgba(250, 246, 237, 0.08);
border: 1px solid rgba(163, 124, 63, 0.35);
padding: 12px 14px;
border-radius: 4px;
color: var(--parchment);
font-family: var(--font-body);
font-size: 0.9rem;
}
.newsletter-form input::placeholder { color: rgba(250, 246, 237, 0.5); }
.newsletter-form input:focus {
outline: none;
border-color: var(--tertiary);
background: rgba(250, 246, 237, 0.12);
}
.newsletter-form button {
padding: 12px;
background: var(--accent-dark);
color: var(--parchment);
border: none;
font-family: var(--font-ui);
font-size: 0.78rem;
letter-spacing: 0.2em;
text-transform: uppercase;
border-radius: 4px;
cursor: pointer;
transition: background var(--transition);
min-height: 44px;
}
.newsletter-form button:hover { background: var(--accent); }
.footer-credits {
border-top: 1px solid rgba(163, 124, 63, 0.25);
padding: var(--space-md);
font-size: 0.85rem;
color: rgba(250, 246, 237, 0.6);
max-width: var(--container-width);
margin: 0 auto;
display: flex; flex-wrap: wrap;
justify-content: space-between;
align-items: center;
gap: var(--space-md);
font-family: var(--font-body);
}
.footer-credits a { color: rgba(250, 246, 237, 0.6); text-decoration: none; }
.footer-credits a:hover { color: var(--tertiary); }
.footer-legal-links { display: flex; gap: var(--space-md); flex-wrap: wrap; } .footer-logo {
display: inline-flex;
align-items: center; justify-content: center;
background: var(--white);
padding: 14px 22px;
border-radius: 14px;
margin-bottom: var(--space-md);
box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
transition: transform var(--transition), box-shadow var(--transition);
min-height: 0;
}
.footer-logo:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0, 0, 0, 0.32); }
.footer-logo img { height: 60px; width: auto; display: block; margin: 0; border-radius: 0; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--space-lg); } }
@media (max-width: 600px) { .footer-grid { grid-template-columns: 1fr; } } .section-cta .wp-block-buttons { margin-top: var(--space-lg) !important; }
.wp-block-group.values-cta { margin-top: var(--space-2xl) !important; }
.wp-block-group > .wp-block-buttons:not(:first-child) { margin-top: var(--space-lg) !important; }
.wp-block-columns.testimonials-grid { gap: var(--space-md); } .fade-in-section {
opacity: 0;
transform: translateY(24px);
transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}
.fade-in-section.is-visible { opacity: 1; transform: translateY(0); }
a:focus-visible, button:focus-visible, .wp-block-button__link:focus-visible,
input:focus-visible, textarea:focus-visible {
outline: 2px solid var(--accent);
outline-offset: 3px;
border-radius: inherit;
}
a:focus:not(:focus-visible), button:focus:not(:focus-visible) { outline: none; }
@media (prefers-reduced-motion: reduce) {
*, *::before, *::after {
animation-duration: 0.01ms !important;
transition-duration: 0.01ms !important;
}
.fade-in-section { opacity: 1 !important; transform: none !important; }
}
@view-transition { navigation: auto; }
::view-transition-old(root),
::view-transition-new(root) { animation-duration: 0.25s; }
@media (prefers-reduced-motion: reduce) {
::view-transition-old(root),
::view-transition-new(root) { animation: none !important; }
}
.section-services, .section-blog, .section-rooms {
content-visibility: auto;
contain-intrinsic-size: auto 600px;
}