/* Solara shared base styles. Used by about.html and contact.html.
   Lifted verbatim from the inline CSS in Solara Living.html / pergolas.html
   so language is identical across the site. */

:root{
  --bg:#F7F2EA;
  --bg-2:#EFE7DA;
  --ink:#1A1714;
  --ink-2:#3B342C;
  --muted:#7A7064;
  --line:rgba(26,23,20,.12);
  --pill: rgba(26,23,20,.06);
  --glass: rgba(247,242,234,.62);
  --r-lg: 22px;
  --r-md: 14px;
  --r-sm: 10px;
  --max: 1320px;
}
*{box-sizing:border-box}
html{ scroll-behavior:smooth; }
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:'Hanken Grotesk', ui-sans-serif, system-ui, -apple-system, Segoe UI, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv11";}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
::selection{background:#1A1714;color:#F7F2EA}

.display{ font-weight:400; letter-spacing:-0.025em; line-height:0.96; }
.h2{ font-weight:400; letter-spacing:-0.022em; line-height:1.02; }
.eyebrow{
  font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted); font-weight:500;
}
.body-lg{font-size:18px;line-height:1.5;color:var(--ink-2);font-weight:400}
.body{font-size:15.5px;line-height:1.55;color:var(--ink-2)}
.small{font-size:13px;color:var(--muted)}

.wrap{max-width:var(--max); margin:0 auto; padding:0 32px}
@media (max-width:720px){ .wrap{ padding:0 20px } }

/* shared photo placeholder block */
.ph{
  position:relative;
  background:
    radial-gradient(120% 80% at 30% 20%, #d6b48a 0%, transparent 55%),
    radial-gradient(140% 100% at 80% 90%, #5b4836 0%, transparent 55%),
    linear-gradient(180deg, #8c6e51 0%, #3d2f24 100%);
  overflow:hidden; isolation:isolate;
}
.ph::after{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,.025) 0 2px, transparent 2px 6px),
    radial-gradient(transparent 0, rgba(0,0,0,.18) 100%);
  mix-blend-mode:overlay; pointer-events:none;
}
.ph .ph-tag{
  position:absolute; left:14px; bottom:12px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size:10.5px; letter-spacing:.06em; color:rgba(255,255,255,.78);
  background:rgba(0,0,0,.32); padding:5px 8px; border-radius:6px;
  backdrop-filter: blur(6px);
}
.ph .ph-img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; display:block;
}
.ph.has-photo::after{ display:none; }

.ph.v-pergola{
  background:
    radial-gradient(120% 80% at 25% 15%, #efc790 0%, transparent 55%),
    radial-gradient(120% 90% at 80% 100%, #4a3a2a 0%, transparent 60%),
    linear-gradient(180deg,#a98463 0%, #2e2519 100%);
}
.ph.v-sauna{
  background:
    radial-gradient(90% 60% at 50% 60%, #f0a86a 0%, transparent 55%),
    radial-gradient(120% 90% at 50% 100%, #2a1d12 0%, transparent 70%),
    linear-gradient(180deg,#231711 0%, #0d0907 100%);
}
.ph.v-tub{
  background:
    radial-gradient(100% 70% at 70% 30%, #e9b178 0%, transparent 60%),
    radial-gradient(120% 80% at 20% 90%, #1f2a2e 0%, transparent 60%),
    linear-gradient(180deg,#465154 0%, #1a1f22 100%);
}
.ph.v-cream{
  background:
    radial-gradient(110% 70% at 30% 30%, #d8c4a3 0%, transparent 60%),
    linear-gradient(180deg,#c8b698 0%, #8a7a60 100%);
}
.ph.v-deck{
  background:
    radial-gradient(100% 70% at 60% 40%, #d9a36f 0%, transparent 55%),
    linear-gradient(180deg,#7a5c3f 0%, #2a1d11 100%);
}

/* Buttons */
.btn{
  appearance:none; border:0; background:#F7F2EA; color:#1A1714;
  padding: 14px 22px; border-radius:999px;
  font-size: 14.5px; font-weight:500; letter-spacing:-.005em;
  display:inline-flex; align-items:center; gap:10px;
  white-space:nowrap;
  transition: transform .25s ease, background .25s ease, color .25s ease;
}
.btn:hover{ transform: translateY(-1px); }
.btn.dark{ background:#1A1714; color:#F7F2EA; }
.btn.ghost{ background:transparent; color:#F7F2EA; padding-left:0; }
.btn.ghost-dark{ background:transparent; color:var(--ink); border:1px solid var(--ink); }
.btn .arrow{
  width:18px; height:18px; border-radius:999px;
  display:inline-flex; align-items:center; justify-content:center;
  background: rgba(26,23,20,.08); font-size:11px;
}
.btn.dark .arrow{ background: rgba(247,242,234,.14)}
.btn.ghost .arrow{ background: rgba(247,242,234,.14)}

/* Pill nav (same as landing) */
.nav{ position: fixed; left:0; right:0; top:18px; z-index:50; display:flex; justify-content:center; pointer-events:none; }
.nav-pill{
  pointer-events:auto;
  display:flex; align-items:center; gap:4px;
  background: var(--glass);
  border:1px solid rgba(255,255,255,.5);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-radius:999px; padding:6px;
  box-shadow: 0 8px 30px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.5);
  font-size:13.5px;
  transition: background .3s ease, color .3s ease, border-color .3s ease;
}
.nav.on-dark .nav-pill{
  background: rgba(20,16,12,.42);
  border-color: rgba(255,255,255,.14);
  color:#F7F2EA;
  box-shadow: 0 8px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.08);
}
.nav-brand{ padding:8px 14px; font-weight:500; letter-spacing:.04em; font-size:13px; color:var(--ink); display:flex; align-items:center; gap:8px;}
.nav-brand .mark{ width:30px; height:30px; display:block; flex-shrink:0; }
.nav.on-dark .nav-brand{ color:#F7F2EA }
.nav.on-dark .nav-brand .mark{ filter: invert(1); }
.nav-brand b{ font-weight:600 }
.nav-link{ padding:8px 14px; border-radius:999px; color:var(--ink-2); position:relative; white-space:nowrap; }
.nav.on-dark .nav-link{ color: rgba(247,242,234,.82)}
.nav-link:hover{ background: rgba(26,23,20,.06)}
.nav.on-dark .nav-link:hover{ background: rgba(255,255,255,.08)}
.nav-link.active{ color:var(--ink); background: rgba(26,23,20,.08); }
.nav.on-dark .nav-link.active{ color:#F7F2EA; background: rgba(255,255,255,.12); }
.nav-cta{ background:#1A1714; color:#F7F2EA; padding:8px 14px; border-radius:999px; font-weight:500; margin-left:4px; margin-right:8px; white-space:nowrap; }
.nav.on-dark .nav-cta{ background:#F7F2EA; color:#1A1714 }
.nav-dropdown{ position:relative; }
.nav-dropdown-menu{
  position:absolute; top:calc(100% + 8px); left:50%; transform:translateX(-50%);
  background: var(--glass);
  border:1px solid rgba(255,255,255,.5);
  backdrop-filter: blur(18px) saturate(140%);
  border-radius:14px; padding:6px; min-width:160px;
  box-shadow: 0 10px 40px rgba(0,0,0,.12);
  opacity:0; visibility:hidden; transform:translate(-50%,-4px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
}
.nav.on-dark .nav-dropdown-menu{ background: rgba(20,16,12,.7); border-color: rgba(255,255,255,.14); }
.nav-dropdown:hover .nav-dropdown-menu{ opacity:1; visibility:visible; transform:translate(-50%,0); }
.nav-dropdown-menu a{ display:block; padding:8px 12px; border-radius:8px; font-size:13px; color:var(--ink-2); }
.nav.on-dark .nav-dropdown-menu a{ color: rgba(247,242,234,.85)}
.nav-dropdown-menu a:hover{ background: rgba(26,23,20,.06)}
.nav.on-dark .nav-dropdown-menu a:hover{ background: rgba(255,255,255,.08)}

.nav-hamburger{ display:none; appearance:none; border:0; background:transparent; width:38px; height:38px; padding:0; margin:0; align-items:center; justify-content:center; color:var(--ink); cursor:pointer; border-radius:999px; transition: background .25s ease;}
.nav-hamburger:hover{ background: rgba(26,23,20,.06); }
.nav.on-dark .nav-hamburger{ color:#F7F2EA; }
.nav.on-dark .nav-hamburger:hover{ background: rgba(255,255,255,.08); }
.nav-hamburger svg{ width:20px; height:20px; display:block; }

.nav-drawer-backdrop{ position:fixed; inset:0; z-index:48; background: rgba(15,11,8,.55); backdrop-filter: blur(14px) saturate(120%); opacity:0; pointer-events:none; transition: opacity .3s ease;}
.nav-drawer-backdrop.open{ opacity:1; pointer-events:auto; }
.nav-drawer{ position:fixed; left:20px; right:20px; top:80px; z-index:49; background: rgba(247,242,234,.96); border:1px solid rgba(255,255,255,.5); border-radius:22px; padding:14px; box-shadow: 0 30px 80px rgba(0,0,0,.32); max-height: calc(100vh - 100px); overflow-y:auto; transform: translateY(-12px) scale(.98); opacity:0; pointer-events:none; transition: opacity .3s ease, transform .3s cubic-bezier(.2,.7,.2,1);}
.nav-drawer.open{ opacity:1; transform:none; pointer-events:auto; }
.nav-drawer-section{ font-family: ui-monospace, monospace; font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); padding: 14px 16px 8px 16px; }
.nav-drawer-section + .nav-drawer-section{ border-top: 1px solid var(--line); margin-top: 6px; }
.nav-drawer-link{ display:flex; justify-content:space-between; align-items:center; padding: 14px 16px; font-size:17px; color:var(--ink); border-radius: 12px; letter-spacing:-.005em; transition: background .2s ease;}
.nav-drawer-link:hover, .nav-drawer-link:active{ background: rgba(26,23,20,.06); }
.nav-drawer-link.active{ font-weight:500; }
.nav-drawer-link .arrow{ font-family: ui-monospace, monospace; font-size:14px; color:var(--muted); }

@media (max-width:720px){
  .nav{ top:14px; left:20px; right:20px; }
  .nav-pill{ padding:5px; gap:0; width:100%; box-sizing:border-box; }
  .nav-pill .nav-link, .nav-pill .nav-dropdown{ display:none; }
  .nav-brand{ padding: 8px 12px; font-size:13px; letter-spacing:.04em; }
  .nav-hamburger{ display:inline-flex; margin-left:auto; }
  .nav-cta{ padding: 7px 14px; font-size:13px; margin-left:2px; margin-right:8px; }
}

/* Page hero (photo-backed, breadcrumb + headline + sub) */
.p-hero{ position:relative; height: 78vh; height:78dvh; min-height:560px; overflow:hidden; background:#1a1714; }
.p-hero-photo{ position:absolute; inset:0; width:100%; height:100%; }
.p-hero-photo img{ width:100%; height:100%; object-fit:cover; object-position:center 40%; display:block; }
.p-hero-veil{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(15,11,8,.15) 0%, rgba(15,11,8,.55) 70%, rgba(15,11,8,.85) 100%),
    radial-gradient(120% 80% at 50% 0%, rgba(0,0,0,.0) 30%, rgba(0,0,0,.35) 100%);
  pointer-events:none;
}
.p-hero-inner{
  position:relative; z-index:1; height:100%;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding-bottom: 72px; color:#F7F2EA;
}
.p-breadcrumb{
  position:absolute; top: 110px; left: 32px; right: 32px;
  font-family: ui-monospace, monospace; font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color: rgba(247,242,234,.78);
}
.p-breadcrumb a{ color:rgba(247,242,234,.78); }
.p-breadcrumb a:hover{ color:#F7F2EA; }
.p-breadcrumb .arrow{ display:inline-block; margin-right:8px; }
.p-hero-copy{
  display:flex; align-items:flex-end; justify-content:space-between; gap:48px;
}
@media (max-width:1100px){ .p-hero-copy{ flex-direction:column; align-items:flex-start; gap:24px; } }
.p-hero-headline{
  color:#F7F2EA;
  font-size: clamp(56px, 9vw, 132px);
  font-weight:400; letter-spacing:-0.03em; line-height:0.95;
  max-width: 14ch; text-wrap: balance; margin:0;
}
.p-hero-sub-block{ display:flex; flex-direction:column; align-items:flex-start; gap:18px; max-width: 36ch; }
.p-hero-sub{ color: rgba(247,242,234,.78); font-size: 16.5px; line-height:1.5; }
.p-hero-actions{ display:flex; align-items:center; gap:16px; }
@media (max-width:720px){
  .p-breadcrumb{ left:20px; right:20px; top:96px; }
  .p-hero-headline{ font-size: clamp(36px, 10vw, 56px); max-width:none; }
}

/* Section head reused on internal pages */
.p-section-head{ max-width: 720px; margin:0 0 64px 0; }
.p-section-head .eyebrow{ display:block; margin-bottom: 18px; }
.p-section-head h2{ font-size: clamp(40px, 5vw, 72px); margin: 0 0 18px 0; }
.p-section-head p{ margin:0; max-width: 48ch; }

/* Marquee strip from landing */
.note-strip{ background:#1A1714; color:#F7F2EA; padding: 12px 0; overflow:hidden; border-top: 1px solid #1A1714; border-bottom: 1px solid #1A1714; }
.marquee{ display:flex; gap:48px; align-items:center; white-space: nowrap; animation: marq 40s linear infinite; font-size: 13px; letter-spacing:.04em; }
.marquee span{ display:inline-flex; align-items:center; gap:48px; color: rgba(247,242,234,.78)}
.marquee b{ font-weight:500; color:#F7F2EA}
@keyframes marq{ from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Final CTA from landing */
.final-cta{ padding: 18vh 0; background: var(--bg); border-top: 1px solid var(--line); text-align:center; }
.final-inner{ display:flex; flex-direction:column; align-items:center; gap:24px; max-width: 920px; margin:0 auto; }
.final-eyebrow{ font-family: ui-monospace, monospace; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color: var(--muted); }
.final-headline{ font-size: clamp(56px, 9vw, 144px); margin: 8px 0 16px 0; letter-spacing:-.03em; line-height:.94; }
.final-sub{ font-size: 18px; line-height:1.5; color: var(--ink-2); max-width: 50ch; margin: 0 0 16px 0; }
.final-actions{ display:flex; gap:16px; flex-wrap:wrap; justify-content:center }

/* Footer */
.footer{ background: var(--ink); color: rgba(247,242,234,.78); padding: 80px 0 32px 0; }
.footer .small{ color: rgba(247,242,234,.55); max-width: 30ch; margin-top: 14px }
.footer-inner{ display:grid; grid-template-columns: 1.2fr 2fr; gap: 64px; padding-bottom: 56px; }
@media (max-width:900px){ .footer-inner{ grid-template-columns: 1fr; gap: 40px } }
.footer-brand .wordmark{ font-size: 22px; letter-spacing:.06em; color:#F7F2EA; display:flex; align-items:center; gap:14px; }
.footer-brand .wordmark .mark{ width:48px; height:48px; display:block; flex-shrink:0; filter: invert(1); }
.footer-brand .wordmark b{ font-weight:600 }
.footer-cols{ display:grid; grid-template-columns: repeat(3,1fr); gap: 32px }
@media (max-width:560px){ .footer-cols{ grid-template-columns: 1fr 1fr } }
.footer-cols .col-h{ font-family: ui-monospace, monospace; font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color: rgba(247,242,234,.55); margin-bottom: 20px; }
.footer-cols a{ display:block; padding: 6px 0; color: rgba(247,242,234,.85); font-size:14.5px; }
.footer-cols a:hover{ color:#F7F2EA }
.footer-base{ display:flex; justify-content:space-between; align-items:center; padding-top: 32px; border-top: 1px solid rgba(247,242,234,.14); font-size: 12.5px; color: rgba(247,242,234,.5); }

/* Reveal-on-scroll */
[data-reveal]{ opacity:0; transform: translateY(28px); transition: opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1); }
[data-reveal].in{ opacity:1; transform:none; }
