:root {
  --ink: #17241e;
  --forest: #17382c;
  --forest-deep: #102a21;
  --moss: #466b55;
  --cream: #f5f0e5;
  --paper: #fffdf8;
  --sand: #e8dcc5;
  --copper: #c86d3f;
  --amber: #e9a85f;
  --muted: #66736c;
  --line: rgba(23, 56, 44, .14);
  --shadow: 0 24px 70px rgba(25, 42, 34, .12);
  --radius: 28px;
  --font-serif: Georgia, 'Times New Roman', serif;
  --font-sans: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--font-sans); line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: inherit; }
img, svg { display: block; max-width: 100%; }
.container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.skip-link { position: fixed; z-index: 999; top: 12px; left: 12px; padding: 10px 16px; background: white; color: var(--forest); transform: translateY(-150%); }
.skip-link:focus { transform: none; }

.site-header { position: absolute; z-index: 50; top: 0; left: 0; width: 100%; color: white; border-bottom: 1px solid rgba(255,255,255,.13); }
.header-inner { min-height: 84px; display: flex; align-items: center; justify-content: space-between; gap: 26px; }
.brand { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; font-family: var(--font-serif); font-size: 21px; letter-spacing: -.02em; white-space: nowrap; }
.brand strong { font-weight: 700; }
.brand-mark { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.28); border-radius: 50%; background: rgba(255,255,255,.08); }
.brand-mark svg { width: 27px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.brand-mark .steam { stroke: var(--amber); }
.site-nav { display: flex; align-items: center; gap: 25px; font-size: 13px; }
.site-nav > a { text-decoration: none; color: rgba(255,255,255,.82); transition: color .2s ease; }
.site-nav > a:hover { color: white; }
.menu-toggle { display: none; width: 44px; height: 44px; padding: 10px; color: white; border: 1px solid rgba(255,255,255,.25); background: transparent; border-radius: 12px; }
.menu-toggle span { display: block; height: 1px; margin: 5px 0; background: currentColor; }

.button { min-height: 50px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 22px; border: 1px solid transparent; border-radius: 999px; font-weight: 700; font-size: 14px; line-height: 1.25; text-decoration: none; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button:hover { transform: translateY(-2px); }
.button-small { min-height: 42px; padding: 10px 18px; font-size: 12px; }
.site-nav .button-light { color: var(--forest); background: var(--cream); }
.button-accent { color: var(--forest-deep); background: var(--amber); box-shadow: 0 12px 28px rgba(233,168,95,.22); }
.button-outline { color: white; border-color: rgba(255,255,255,.35); background: rgba(255,255,255,.04); }
.button-primary { color: white; background: var(--forest); box-shadow: 0 12px 28px rgba(23,56,44,.18); }
.button-ghost { color: var(--forest); border-color: var(--line); background: white; }

.hero { min-height: 760px; position: relative; overflow: hidden; display: grid; align-items: center; padding: 145px 0 90px; color: white; background: var(--forest-deep); }
.hero::before { content: ''; position: absolute; inset: 0; opacity: .07; background-image: repeating-linear-gradient(115deg, transparent 0, transparent 34px, #fff 35px); }
.hero-glow { position: absolute; border-radius: 50%; filter: blur(1px); }
.hero-glow-one { width: 620px; height: 620px; right: -210px; top: -150px; background: radial-gradient(circle, rgba(217,151,85,.26), transparent 68%); }
.hero-glow-two { width: 500px; height: 500px; left: -310px; bottom: -330px; background: rgba(72,119,91,.25); }
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.03fr .97fr; align-items: center; gap: 70px; }
.eyebrow { margin: 0 0 16px; color: var(--copper); font-size: 11px; font-weight: 800; letter-spacing: .19em; text-transform: uppercase; }
.eyebrow.light { color: var(--amber); }
.hero h1 { max-width: 720px; margin: 0; font-family: var(--font-serif); font-size: clamp(58px, 6.2vw, 92px); font-weight: 400; line-height: .98; letter-spacing: -.05em; }
.hero h1 em { color: var(--amber); font-weight: 400; }
.hero-lead { max-width: 630px; margin: 28px 0 0; color: rgba(255,255,255,.72); font-size: 18px; line-height: 1.68; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.mvp-note { display: flex; align-items: center; gap: 10px; margin-top: 30px; color: rgba(255,255,255,.58); font-size: 12px; letter-spacing: .02em; }
.mvp-note span { width: 7px; height: 7px; border-radius: 50%; background: #a4ce9b; box-shadow: 0 0 0 5px rgba(164,206,155,.12); }
.hero-art { min-height: 520px; position: relative; isolation: isolate; }
.hero-art::before { content: ''; position: absolute; z-index: -2; inset: 30px 0 0; border: 1px solid rgba(255,255,255,.12); border-radius: 50% 50% 12px 12px; background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.01)); }
.sun { position: absolute; z-index: -1; right: 78px; top: 90px; width: 118px; height: 118px; border-radius: 50%; background: var(--amber); box-shadow: 0 0 80px rgba(233,168,95,.25); }
.bathhouse { position: absolute; bottom: 18px; left: -8px; width: 100%; }
.bathhouse .ground { fill: #193d30; }.bathhouse .house { fill: #d39a67; }.bathhouse .roof { fill: #8a4c33; }.bathhouse .door { fill: #71452f; }.bathhouse .window { fill: #f2c881; }.bathhouse .line,.bathhouse .fence { fill: none; stroke: #102a21; stroke-width: 5; }.bathhouse .chimney { fill: #76513c; }
.steam-lines { position: absolute; z-index: 3; top: 30px; left: 47%; display: flex; gap: 17px; transform: rotate(-5deg); }
.steam-lines i, .visual-steam i { width: 18px; height: 92px; display: block; border-radius: 50%; border-left: 2px solid rgba(255,255,255,.28); transform: skewX(-12deg); }
.steam-lines i:nth-child(2) { height: 124px; margin-top: -20px; }
.hero-stamp { position: absolute; right: -10px; bottom: 28px; width: 128px; height: 128px; display: flex; flex-direction: column; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.22); border-radius: 50%; background: rgba(16,42,33,.82); backdrop-filter: blur(8px); transform: rotate(7deg); }
.hero-stamp::after { content: ''; position: absolute; inset: 7px; border: 1px dashed rgba(255,255,255,.2); border-radius: 50%; }
.hero-stamp strong { font-family: var(--font-serif); font-size: 22px; font-weight: 400; }.hero-stamp span { color: var(--amber); font-size: 8px; letter-spacing: .14em; text-transform: uppercase; }

.section { padding: 112px 0; }
.section-heading { margin-bottom: 44px; }
.section-heading h2, .owners-copy h2, .contact-inner h2 { margin: 0; font-family: var(--font-serif); font-size: clamp(40px, 5vw, 62px); font-weight: 400; line-height: 1.06; letter-spacing: -.04em; }
.split-heading { display: flex; align-items: end; justify-content: space-between; gap: 40px; }
.split-heading > p { max-width: 430px; margin: 0 0 6px; color: var(--muted); }
.centered-heading { max-width: 670px; margin-inline: auto; text-align: center; }

.featured-section { background: var(--cream); }
.featured-card { display: grid; grid-template-columns: .82fr 1.18fr; overflow: hidden; border: 1px solid rgba(23,56,44,.1); border-radius: var(--radius); background: white; box-shadow: var(--shadow); }
.featured-visual { min-height: 650px; position: relative; overflow: hidden; color: white; background: linear-gradient(145deg, #9a5939, #cb8756); }
.featured-visual::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(64,30,17,.42)); }
.featured-label { position: absolute; z-index: 4; top: 28px; left: 28px; padding: 8px 13px; border-radius: 999px; background: var(--forest); font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.featured-visual svg { position: absolute; z-index: 2; left: 5%; bottom: 11%; width: 90%; }
.featured-visual svg circle { fill: #f1bd79; }.featured-visual svg path:nth-of-type(1) { fill: #935535; }.featured-visual svg path:nth-of-type(2) { fill: #e0a270; }.featured-visual svg path:nth-of-type(3) { fill: #70412e; }.featured-visual svg path:nth-of-type(4) { fill: #f2c982; }
.visual-steam { position: absolute; z-index: 1; top: 55px; right: 25%; display: flex; gap: 16px; opacity: .7; }
.visual-steam i:nth-child(2) { height: 130px; margin-top: -25px; }
.visual-caption { position: absolute; z-index: 4; right: 28px; bottom: 28px; display: flex; flex-direction: column; align-items: end; font-size: 13px; }
.visual-caption span { font-family: var(--font-serif); font-size: 34px; line-height: 1; }
.featured-content { padding: clamp(34px, 5vw, 66px); }
.card-kicker { margin: 0 0 8px; color: var(--copper); font-size: 11px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.featured-content h3 { margin: 0; font-family: var(--font-serif); font-size: clamp(36px, 4.4vw, 54px); font-weight: 400; line-height: 1.08; letter-spacing: -.04em; }
.featured-intro { max-width: 640px; margin: 18px 0 30px; color: var(--muted); font-size: 17px; }
.facts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin: 0; border-top: 1px solid var(--line); }
.facts-grid div { padding: 19px 18px 19px 0; border-bottom: 1px solid var(--line); }
.facts-grid div:nth-child(odd) { border-right: 1px solid var(--line); }.facts-grid div:nth-child(even) { padding-left: 22px; }
.facts-grid dt { margin-bottom: 5px; color: var(--muted); font-size: 10px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.facts-grid dd { margin: 0; font-size: 13px; line-height: 1.55; }
.price-row { display: flex; gap: 40px; padding: 24px 0; }
.price-row div { display: flex; flex-direction: column; }.price-row span { color: var(--muted); font-size: 11px; }.price-row strong { font-family: var(--font-serif); color: var(--copper); font-size: 28px; line-height: 1.3; }
.contact-line { display: flex; flex-wrap: wrap; gap: 8px 20px; font-size: 12px; }.contact-line a { text-underline-offset: 3px; }
.source-note { padding-left: 13px; margin: 18px 0; color: var(--muted); border-left: 2px solid var(--amber); font-size: 11px; line-height: 1.5; }
.card-actions { display: flex; flex-wrap: wrap; gap: 8px; }

.categories-section { background: var(--paper); }
.category-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.category-card { min-height: 220px; padding: 30px; border: 1px solid var(--line); border-radius: 20px; background: white; transition: transform .25s ease, box-shadow .25s ease; }
.category-card:hover { transform: translateY(-5px); box-shadow: 0 20px 45px rgba(23,56,44,.08); }
.category-icon { width: 44px; height: 44px; display: grid; place-items: center; margin-bottom: 30px; color: var(--copper); border-radius: 50%; background: #f6e9dc; font-family: var(--font-serif); font-size: 24px; }
.category-card h3 { margin: 0 0 9px; font-family: var(--font-serif); font-size: 24px; font-weight: 400; }.category-card p { margin: 0; color: var(--muted); font-size: 13px; }

.catalog-section { background: #efeadf; }
.catalog-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.catalog-card { overflow: hidden; border-radius: 20px; background: white; box-shadow: 0 12px 35px rgba(31,44,37,.06); }
.catalog-art { height: 190px; position: relative; display: grid; place-items: center; overflow: hidden; }
.catalog-art::before, .catalog-art::after { content: ''; position: absolute; width: 190px; height: 190px; border: 1px solid rgba(255,255,255,.2); border-radius: 50%; }
.catalog-art::after { width: 110px; height: 110px; }
.catalog-art span { position: absolute; z-index: 2; top: 15px; left: 15px; padding: 6px 9px; border-radius: 99px; color: white; background: rgba(16,42,33,.78); font-size: 8px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.catalog-art i { position: relative; z-index: 2; color: rgba(255,255,255,.85); font-family: var(--font-serif); font-size: 58px; font-style: normal; }
.art-one { background: #a45f3d; }.art-two { background: #486c57; }.art-three { background: #b1845a; }.art-four { background: #637b78; }
.catalog-body { padding: 24px; }.catalog-body > p { margin: 0 0 4px; color: var(--copper); font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.catalog-body h3 { min-height: 60px; margin: 0 0 10px; font-family: var(--font-serif); font-size: 23px; font-weight: 400; line-height: 1.2; }
.catalog-body ul { margin: 0 0 18px; padding: 0; list-style: none; color: var(--muted); font-size: 12px; }.catalog-body li::before { content: '—'; margin-right: 7px; color: var(--copper); }
.coming-soon { font-size: 10px; font-weight: 700; }

.how-section { color: white; background: var(--forest); }
.how-section .section-heading h2 { color: white; }
.steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin: 0; padding: 0; list-style: none; border-top: 1px solid rgba(255,255,255,.16); }
.steps-grid li { min-height: 250px; display: flex; flex-direction: column; justify-content: space-between; padding: 28px 26px 0; border-left: 1px solid rgba(255,255,255,.16); }
.steps-grid li:last-child { border-right: 1px solid rgba(255,255,255,.16); }
.steps-grid > li > span { color: var(--amber); font-family: var(--font-serif); font-size: 17px; }
.steps-grid h3 { margin: 0 0 8px; font-family: var(--font-serif); font-size: 24px; font-weight: 400; }.steps-grid p { margin: 0; color: rgba(255,255,255,.6); font-size: 13px; }

.owners-section { background: var(--paper); }
.owners-grid { display: grid; grid-template-columns: .82fr 1.18fr; align-items: center; gap: 100px; }
.owners-copy > p:not(.eyebrow) { margin: 24px 0 30px; color: var(--muted); font-size: 17px; }
.placement-list { border-top: 1px solid var(--line); }
.placement-list div { display: grid; grid-template-columns: 48px 1fr auto; align-items: center; gap: 18px; padding: 22px 6px; border-bottom: 1px solid var(--line); }
.placement-list span { color: var(--copper); font-family: var(--font-serif); }.placement-list strong { font-family: var(--font-serif); font-size: 22px; font-weight: 400; }.placement-list small { color: var(--muted); font-size: 11px; }

.contact-section { padding: 78px 0; color: white; background: linear-gradient(120deg, #985738, #c4774d); }
.contact-inner { display: flex; align-items: center; justify-content: space-between; gap: 60px; }
.contact-inner > div { max-width: 720px; }.contact-inner p:not(.eyebrow) { max-width: 600px; margin: 20px 0 0; color: rgba(255,255,255,.72); }
.contact-inner .button-accent { flex: 0 0 auto; background: var(--cream); }

.site-footer { padding: 70px 0 25px; color: white; background: #0d211a; }
.footer-grid { display: grid; grid-template-columns: 1.2fr .7fr 1fr; gap: 50px; align-items: start; }
.footer-brand { color: white; font-size: 24px; }.footer-grid p { margin: 12px 0 0; color: rgba(255,255,255,.46); font-size: 12px; }.footer-grid > div:nth-child(2) { display: flex; flex-direction: column; gap: 6px; }.footer-grid > div:nth-child(2) span { color: rgba(255,255,255,.5); font-size: 12px; }
.footer-bottom { display: flex; justify-content: space-between; margin-top: 60px; padding-top: 20px; color: rgba(255,255,255,.36); border-top: 1px solid rgba(255,255,255,.1); font-size: 10px; }

@media (max-width: 1040px) {
  .site-nav { gap: 15px; }.site-nav > a:not(.button) { display: none; }
  .hero-grid { gap: 30px; }.hero-art { min-height: 450px; }
  .featured-card { grid-template-columns: 1fr; }.featured-visual { min-height: 430px; }.featured-visual svg { width: 65%; left: 17%; bottom: -2%; }
  .catalog-grid { grid-template-columns: repeat(2, 1fr); }.category-grid { grid-template-columns: repeat(2, 1fr); }
  .owners-grid { gap: 55px; }.placement-list div { grid-template-columns: 42px 1fr; }.placement-list small { grid-column: 2; }
}

@media (max-width: 760px) {
  .container { width: min(100% - 30px, 620px); }
  .site-header { position: absolute; }.header-inner { min-height: 72px; }.brand { font-size: 19px; }.brand-mark { width: 36px; height: 36px; }
  .menu-toggle { display: block; }
  .site-nav { position: absolute; top: 65px; left: 15px; right: 15px; display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 14px; border: 1px solid rgba(255,255,255,.12); border-radius: 18px; background: rgba(13,33,26,.98); box-shadow: var(--shadow); }
  .site-nav.is-open { display: flex; }.site-nav > a:not(.button) { display: block; padding: 10px; }.site-nav .button { margin-top: 8px; }
  .hero { min-height: auto; padding: 120px 0 66px; }.hero-grid { grid-template-columns: 1fr; }.hero-copy { text-align: left; }.hero h1 { font-size: clamp(52px, 16vw, 72px); }.hero-lead { font-size: 16px; }.hero-actions { flex-direction: column; align-items: stretch; }.hero-actions .button { width: 100%; }
  .hero-art { min-height: 385px; margin-top: 15px; }.hero-art::before { inset: 10px 0 0; }.bathhouse { bottom: 0; }.sun { width: 90px; height: 90px; right: 45px; top: 66px; }.hero-stamp { width: 105px; height: 105px; right: 3px; bottom: 8px; }.hero-stamp strong { font-size: 18px; }
  .section { padding: 76px 0; }.section-heading { margin-bottom: 30px; }.section-heading h2, .owners-copy h2, .contact-inner h2 { font-size: 41px; }.split-heading { display: block; }.split-heading > p { margin-top: 14px; }
  .featured-visual { min-height: 320px; }.featured-visual svg { width: 90%; left: 5%; }.featured-content { padding: 30px 20px; }.featured-content h3 { font-size: 38px; }.facts-grid { grid-template-columns: 1fr; }.facts-grid div:nth-child(odd) { border-right: 0; }.facts-grid div:nth-child(even) { padding-left: 0; }.price-row { gap: 24px; }.price-row strong { font-size: 23px; }.card-actions { flex-direction: column; }.card-actions .button { width: 100%; }
  .category-grid, .catalog-grid { grid-template-columns: 1fr; }.category-card { min-height: 190px; }.category-icon { margin-bottom: 22px; }
  .steps-grid { grid-template-columns: 1fr; border-top: 0; }.steps-grid li { min-height: 0; display: grid; grid-template-columns: 45px 1fr; gap: 10px; padding: 24px 0; border-top: 1px solid rgba(255,255,255,.16); border-left: 0; }.steps-grid li:last-child { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.16); }
  .owners-grid { grid-template-columns: 1fr; gap: 50px; }.placement-list div { padding: 20px 0; }.placement-list strong { font-size: 20px; }
  .contact-inner { flex-direction: column; align-items: stretch; gap: 30px; }.contact-inner .button { width: 100%; }
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }.footer-bottom { flex-direction: column; gap: 5px; margin-top: 35px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}
