:root { --bg: #f4efe7; --paper: #fffaf2; --paper-2: #efe4d4; --ink: #1d1712; --muted: #6d6258; --line: #d8c8b4; --accent: #a5462d; --accent-dark: #71301f; --green: #485b39; --gold: #c1995a; --charcoal: #171513; --shadow: 0 24px 70px rgb(34 24 16 / 16%); --shadow-soft: 0 18px 55px rgb(34 24 16 / 10%); } * { box-sizing: border-box; } html { scroll-behavior: smooth; } body { margin: 0; color: var(--ink); background: var(--bg); font-family: "Manrope", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; line-height: 1.55; } a { color: inherit; text-decoration: none; } img { display: block; max-width: 100%; } .site-header { position: fixed; z-index: 20; top: 0; left: 0; right: 0; display: grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items: center; min-height: 76px; padding: 14px clamp(18px, 4vw, 56px); color: white; background: linear-gradient(180deg, rgb(0 0 0 / 58%), rgb(0 0 0 / 0%)); transition: background 180ms ease, box-shadow 180ms ease, min-height 180ms ease, backdrop-filter 180ms ease; } .site-header.is-scrolled { min-height: 66px; background: rgb(23 21 19 / 92%); box-shadow: 0 14px 38px rgb(0 0 0 / 22%); backdrop-filter: blur(14px); } .brand, .nav-links, .header-call, .button, .text-link { font-weight: 800; } .brand { display: inline-flex; gap: 11px; align-items: center; min-width: 0; } .brand-mark { display: grid; width: 40px; height: 40px; place-items: center; color: var(--paper); background: var(--accent); border: 1px solid rgb(255 255 255 / 26%); } .nav-links { display: flex; justify-content: center; gap: clamp(16px, 3vw, 34px); font-size: 0.92rem; } .header-call { padding: 12px 18px; color: white; background: var(--accent); border: 1px solid rgb(255 255 255 / 22%); box-shadow: 0 14px 34px rgb(0 0 0 / 20%); } .hero, .page-hero { position: relative; overflow: hidden; color: white; background: var(--charcoal); } .hero, .page-hero { min-height: 70svh; } .hero-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; } .hero-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgb(9 7 5 / 84%) 0%, rgb(9 7 5 / 60%) 45%, rgb(9 7 5 / 30%) 100%), linear-gradient(0deg, rgb(29 23 18 / 62%) 0%, rgb(29 23 18 / 0%) 36%); } .hero-content, .page-hero-content { position: relative; z-index: 1; display: grid; align-content: center; width: min(860px, calc(100% - 36px)); margin-left: clamp(18px, 8vw, 104px); } .hero-content { min-height: 70svh; padding: 104px 0 58px; } .page-hero-content { min-height: 70svh; padding: 116px 0 72px; } .eyebrow { margin: 0 0 14px; color: var(--accent); font-size: 0.75rem; font-weight: 900; letter-spacing: 0.11em; text-transform: uppercase; } .hero .eyebrow, .page-hero .eyebrow { color: #f3c39d; } h1, h2, h3, p { margin-top: 0; } h1 { max-width: 680px; margin-bottom: 22px; font-family: "Lora", Georgia, serif; font-weight: 700; font-size: clamp(2.25rem, 4.1vw, 4.35rem); line-height: 1.02; letter-spacing: 0; } h2 { margin-bottom: 0; font-family: "Lora", Georgia, serif; font-weight: 700; font-size: clamp(2.05rem, 4vw, 4rem); line-height: 1.06; letter-spacing: 0; } h3 { margin-bottom: 10px; font-size: 1.28rem; line-height: 1.15; } .hero-copy, .page-copy { max-width: 590px; margin-bottom: 32px; color: rgb(255 255 255 / 86%); font-size: clamp(1.02rem, 2vw, 1.24rem); } .hero-actions { display: flex; flex-wrap: wrap; gap: 12px; } .button { display: inline-flex; justify-content: center; align-items: center; min-height: 50px; padding: 14px 22px; border: 0; cursor: pointer; font: inherit; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; } .button:hover, .text-link:hover { transform: translateY(-1px); } .button-primary { color: white; background: var(--accent); } .button-primary:hover { background: var(--accent-dark); } .button-secondary { color: var(--ink); background: var(--paper); } .quick-info { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; width: min(1120px, calc(100% - 36px)); margin: -34px auto 0; overflow: hidden; background: var(--line); box-shadow: var(--shadow); } .quick-info div, .feature-card, .price-card, .review-card, .booking-form, .info-card { background: var(--paper); } .quick-info div { padding: 25px 28px; } .quick-info strong, .quick-info span { display: block; } .quick-info strong { margin-bottom: 5px; font-size: 1.08rem; } .quick-info span, .text-block, .feature-card p, .booking-copy p, .section-note, .price-card p, .price-card span, .review-card p, .site-footer, .info-card p, .map-copy p, .lead-text { color: var(--muted); } .section { width: min(1120px, calc(100% - 36px)); padding: clamp(42px, 5.2vw, 76px) 0; margin: 0 auto; position: relative; } .section + .section { padding-top: clamp(22px, 3.2vw, 44px); } .surface-band { position: relative; margin-top: clamp(18px, 3.5vw, 42px); background: linear-gradient(120deg, rgb(255 250 242 / 88%), rgb(239 228 212 / 96%)), var(--paper-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); } .about-band, .occasion-band { position: relative; margin-top: clamp(20px, 3.8vw, 46px); background: var(--paper-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); } .surface-band::before, .about-band::before, .occasion-band::before { content: ""; position: absolute; top: 0; left: 50%; width: min(1120px, calc(100% - 36px)); height: 1px; background: linear-gradient(90deg, rgb(165 70 45 / 0%), rgb(165 70 45 / 55%), rgb(72 91 57 / 48%), rgb(165 70 45 / 0%)); transform: translateX(-50%); } .surface-band::after, .about-band::after, .occasion-band::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(circle at 12% 14%, rgb(193 153 90 / 10%), transparent 28%), linear-gradient(90deg, rgb(72 91 57 / 5%) 0 1px, transparent 1px 100%); background-size: auto, 84px 84px; } .surface-band > *, .about-band > *, .occasion-band > * { position: relative; z-index: 1; } .about-card { position: relative; width: min(1120px, calc(100% - 36px)); padding: clamp(38px, 5vw, 64px); background: linear-gradient(135deg, rgb(255 250 242 / 98%), rgb(255 250 242 / 88%)), var(--paper); border: 1px solid rgb(216 200 180 / 76%); box-shadow: var(--shadow-soft); } .about-card::after { content: ""; position: absolute; right: clamp(20px, 6vw, 70px); bottom: 0; width: min(260px, 32vw); height: 4px; background: var(--accent); } .split, .booking-section, .map-section, .image-text, .content-grid { display: grid; grid-template-columns: minmax(260px, 0.88fr) minmax(300px, 1.12fr); gap: clamp(28px, 4.8vw, 62px); align-items: start; } .text-block, .rich-text { display: grid; gap: 16px; font-size: 1.08rem; } .text-block p, .feature-card p, .booking-copy p, .price-card p, .review-card p, .info-card p, .map-copy p, .lead-text { margin-bottom: 0; } .section-heading { display: grid; gap: 10px; max-width: 780px; margin-bottom: 28px; position: relative; } .section-heading::after { content: ""; width: 72px; height: 2px; margin-top: 10px; background: linear-gradient(90deg, var(--accent), rgb(165 70 45 / 0%)); } .section-note { max-width: 720px; margin: 8px 0 0; } .feature-grid, .price-cards, .review-grid, .info-grid, .occasion-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; } .feature-card, .price-card, .review-card, .info-card { min-height: 196px; padding: 28px; border: 1px solid var(--line); } .feature-card, .price-card, .review-card { box-shadow: 0 14px 34px rgb(40 27 17 / 7%); } .icon { display: grid; width: 46px; height: 46px; place-items: center; margin-bottom: 24px; color: white; background: var(--green); font-size: 0.82rem; font-weight: 900; } .price-card.featured { color: white; background: var(--charcoal); border-color: var(--charcoal); } .price-card.featured p, .price-card.featured span { color: rgb(255 255 255 / 78%); } .price { color: var(--accent); font-size: 1.7rem; font-weight: 900; } .featured .price { color: #f3c39d; } .occasion-band { padding: clamp(2px, 1.5vw, 12px) 0; } .occasion-grid { gap: 1px; margin-top: 24px; background: var(--line); border: 1px solid var(--line); } .occasion-grid article { min-height: 196px; padding: 28px; background: var(--paper); } .occasion-grid span { display: inline-grid; width: 42px; height: 42px; place-items: center; margin-bottom: 28px; color: white; background: var(--accent); font-weight: 900; } .occasion-grid p { margin: 0; color: var(--muted); } .image-text { align-items: center; } .image-text img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border: 1px solid var(--line); box-shadow: var(--shadow); } .text-link { display: inline-flex; align-items: center; width: fit-content; margin-top: 22px; color: var(--accent); transition: transform 160ms ease; } .text-link::after { content: "→"; margin-left: 8px; } .gallery-grid { display: grid; grid-template-columns: 1.2fr 0.8fr 0.8fr; grid-auto-rows: 240px; gap: 14px; margin-bottom: 20px; } .gallery-grid img, .photo-grid img { width: 100%; height: 100%; object-fit: cover; border: 1px solid var(--line); background: var(--paper); } .gallery-grid img:first-child { grid-row: span 2; } .photo-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 320px; gap: 16px; } .photo-grid img:first-child, .photo-grid img:nth-child(4) { grid-column: span 2; } .reviews { padding-top: clamp(42px, 5.2vw, 76px); padding-bottom: clamp(42px, 5.2vw, 76px); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); } .reviews .section-heading { max-width: 820px; } .reviews .section-heading .button { justify-self: start; width: fit-content; margin-top: 10px; } .review-slider { position: relative; } .review-track { display: grid; grid-auto-flow: column; grid-auto-columns: calc((100% - 36px) / 3); gap: 18px; overflow-x: auto; padding: 2px 2px 18px; scroll-behavior: smooth; scroll-snap-type: x mandatory; scrollbar-width: none; } .review-track::-webkit-scrollbar { display: none; } .review-track .review-card { scroll-snap-align: start; } .review-card p { font-size: 1.02rem; } .review-rating { display: inline-flex; align-items: center; gap: 8px; width: fit-content; margin-bottom: 22px; padding: 8px 10px; color: white; background: var(--accent); font-weight: 900; } .review-rating span:first-child::before { content: "★"; margin-right: 5px; color: #ffd89a; } .review-rating span:last-child { color: rgb(255 255 255 / 78%); font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; } .review-card strong { display: block; margin-top: 24px; } .review-card small { display: block; margin-top: 4px; color: var(--muted); font-weight: 800; } .slider-controls { display: flex; justify-content: flex-end; gap: 10px; margin-top: 12px; } .slider-button { display: inline-grid; width: 48px; height: 48px; place-items: center; border: 1px solid var(--line); color: var(--ink); background: var(--paper); cursor: pointer; transition: background 160ms ease, transform 160ms ease; } .slider-button:hover { transform: translateY(-1px); background: var(--paper-2); } .slider-button svg { width: 20px; height: 20px; stroke-width: 1.9; } .map-section { align-items: stretch; } .map-copy { display: grid; align-content: center; justify-items: start; gap: 18px; } .map-frame { min-height: 360px; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow-soft); } .map-frame iframe { display: block; width: 100%; height: 100%; min-height: 360px; border: 0; } .booking-copy { position: sticky; top: 104px; } .contact-cta .booking-copy { display: grid; align-content: start; gap: 18px; padding-top: 8px; } .contact-cta .booking-copy h2 { max-width: 520px; } .contact-cta .booking-copy p { max-width: 560px; font-size: 1.06rem; } .booking-form { display: grid; gap: 18px; padding: clamp(24px, 4vw, 40px); border: 1px solid var(--line); box-shadow: var(--shadow); } .booking-form label { display: grid; gap: 8px; font-weight: 850; } input, textarea { width: 100%; min-height: 48px; padding: 12px 13px; border: 1px solid #cbbba7; color: var(--ink); background: white; font: inherit; } textarea { resize: vertical; } input:focus, textarea:focus { outline: 3px solid rgb(165 70 45 / 20%); border-color: var(--accent); } .hidden { display: none; } .contact-panel { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; } .contact-option { display: grid; gap: 10px; min-height: 138px; align-content: end; padding: 24px; background: var(--paper); border: 1px solid var(--line); box-shadow: 0 14px 34px rgb(40 27 17 / 7%); transition: transform 160ms ease, background 160ms ease; } .contact-detail-list { display: grid; gap: 12px; margin-top: 22px; } .contact-detail-list a, .contact-detail-list span { display: inline-flex; align-items: center; gap: 10px; color: var(--ink); font-weight: 800; } .contact-detail-list svg { width: 19px; height: 19px; color: var(--accent); stroke-width: 1.9; flex: 0 0 auto; } .instagram-icon { display: inline-block; width: 1.15em; height: 1.15em; flex: 0 0 auto; background: currentColor; -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20d='M7%202h10a5%205%200%200%201%205%205v10a5%205%200%200%201-5%205H7a5%205%200%200%201-5-5V7a5%205%200%200%201%205-5Zm0%202a3%203%200%200%200-3%203v10a3%203%200%200%200%203%203h10a3%203%200%200%200%203-3V7a3%203%200%200%200-3-3H7Zm5%203.5A4.5%204.5%200%201%201%2012%2016.5%204.5%204.5%200%200%201%2012%207.5Zm0%202A2.5%202.5%200%201%200%2012%2014.5%202.5%202.5%200%200%200%2012%209.5Zm5.25-2.1a1.15%201.15%200%201%201-2.3%200%201.15%201.15%200%200%201%202.3%200Z'/%3E%3C/svg%3E") center / contain no-repeat; mask: url("data:image/svg+xml,%3Csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20d='M7%202h10a5%205%200%200%201%205%205v10a5%205%200%200%201-5%205H7a5%205%200%200%201-5-5V7a5%205%200%200%201%205-5Zm0%202a3%203%200%200%200-3%203v10a3%203%200%200%200%203%203h10a3%203%200%200%200%203-3V7a3%203%200%200%200-3-3H7Zm5%203.5A4.5%204.5%200%201%201%2012%2016.5%204.5%204.5%200%200%201%2012%207.5Zm0%202A2.5%202.5%200%201%200%2012%2014.5%202.5%202.5%200%200%200%2012%209.5Zm5.25-2.1a1.15%201.15%200%201%201-2.3%200%201.15%201.15%200%200%201%202.3%200Z'/%3E%3C/svg%3E") center / contain no-repeat; } .contact-detail-list .instagram-icon { width: 19px; height: 19px; color: var(--accent); } .contact-support .content-card { min-height: 100%; box-shadow: var(--shadow-soft); } .contact-option svg { width: 28px; height: 28px; color: var(--accent); stroke-width: 1.8; } .contact-option .instagram-icon { width: 28px; height: 28px; color: var(--accent); } .contact-option.primary svg { color: #f3c39d; } .contact-option:hover { transform: translateY(-2px); } .contact-option span { color: var(--accent); font-size: 0.78rem; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; } .contact-option strong { color: var(--ink); font-size: 1.18rem; line-height: 1.15; } .contact-option.primary { color: white; background: var(--charcoal); border-color: var(--charcoal); } .contact-option.primary span { color: #f3c39d; } .contact-option.primary strong { color: white; } .action-grid { display: flex; flex-wrap: wrap; gap: 10px; } .compact-actions { margin-top: 4px; } .site-footer { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(28px, 6vw, 82px); padding: clamp(46px, 6vw, 78px) clamp(18px, 6vw, 72px); color: rgb(255 255 255 / 72%); background: linear-gradient(135deg, rgb(23 21 19 / 96%), rgb(23 21 19 / 90%)), var(--charcoal); border-top: 4px solid var(--accent); } .footer-brand { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 14px; color: white; font-size: 1.45rem; font-weight: 900; } .footer-brand .brand-mark { width: 38px; height: 38px; } .site-footer nav, .footer-contacts { display: grid; gap: 12px; align-content: start; } .site-footer a { display: inline-flex; align-items: center; gap: 10px; color: white; } .site-footer svg { width: 18px; height: 18px; color: #f3c39d; stroke-width: 1.8; } .site-footer .instagram-icon { width: 18px; height: 18px; color: #f3c39d; } .page-intro { padding-top: 52px; } .content-card { padding: 34px; background: var(--paper); border: 1px solid var(--line); box-shadow: 0 14px 34px rgb(40 27 17 / 6%); } .content-card h3 { margin-top: 0; } .content-card ul { padding-left: 20px; margin-bottom: 0; color: var(--muted); } .nearby-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; } .nearby-card { display: grid; grid-template-columns: minmax(180px, 0.45fr) minmax(0, 0.55fr); min-height: 260px; overflow: hidden; background: var(--paper); border: 1px solid var(--line); box-shadow: 0 14px 34px rgb(40 27 17 / 7%); } .nearby-card img { width: 100%; height: 100%; min-height: 260px; object-fit: cover; } .nearby-card > div { display: grid; align-content: start; gap: 10px; padding: 26px; } .nearby-card span { color: var(--accent); font-size: 0.74rem; font-weight: 900; letter-spacing: 0.09em; text-transform: uppercase; } .nearby-card p { margin: 0; color: var(--muted); } .nearby-card .text-link { margin-top: 6px; } @media (max-width: 900px) { .site-header { grid-template-columns: 1fr auto; } .nav-links { display: none; } .hero, .page-hero, .hero-content, .page-hero-content { min-height: 74svh; } .hero-content, .page-hero-content { margin-left: 18px; } .quick-info, .feature-grid, .price-cards, .info-grid, .occasion-grid, .split, .booking-section, .map-section, .image-text, .content-grid, .site-footer, .gallery-grid, .photo-grid, .contact-panel, .nearby-grid, .nearby-card { grid-template-columns: 1fr; } .nearby-card img { aspect-ratio: 16 / 9; min-height: 0; } .booking-copy { position: static; } .review-track { grid-auto-columns: minmax(260px, 82%); } .gallery-grid, .photo-grid { grid-auto-rows: 280px; } .gallery-grid img:first-child, .photo-grid img:first-child, .photo-grid img:nth-child(4) { grid-column: span 1; grid-row: span 1; } } @media (max-width: 560px) { .site-header { min-height: 64px; padding: 12px 14px; } .brand span:last-child { display: none; } .header-call { padding: 9px 12px; } .hero-content { width: calc(100% - 28px); padding: 88px 0 54px; } h1 { font-size: clamp(2.24rem, 12.5vw, 3.45rem); } h2 { font-size: clamp(1.9rem, 10vw, 2.65rem); } .hero-actions .button { width: 100%; } .quick-info, .section { width: calc(100% - 28px); } .section { padding-top: 48px; padding-bottom: 48px; } .section + .section { padding-top: 26px; } .quick-info { margin-top: -28px; } .feature-card, .price-card, .review-card, .info-card, .content-card, .occasion-grid article { padding: 24px; } .about-card { padding: 30px 24px; } }