
:root{color-scheme:light;--bg:#f6efe4;--paper:#fffaf2;--surface:#fffdf8;--ink:#211915;--muted:#6d5d51;--line:#eadcc9;--terracotta:#a95336;--terracotta-2:#d18455;--green:#1f5a4d;--gold:#b38a4a;--shadow:0 30px 90px rgba(60,38,23,.13);--soft-shadow:0 16px 50px rgba(60,38,23,.09);--radius:30px;--radius-sm:18px;--container:1180px}html[data-theme=dark]{color-scheme:dark;--bg:#11100e;--paper:#181512;--surface:#211c17;--ink:#fff4e6;--muted:#cbb9a4;--line:#3b3129;--terracotta:#f0a06d;--terracotta-2:#ffc08a;--green:#89c5ae;--gold:#d9ba74;--shadow:0 30px 90px rgba(0,0,0,.44);--soft-shadow:0 16px 50px rgba(0,0,0,.30)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(circle at 12% 8%,rgba(169,83,54,.16),transparent 30%),radial-gradient(circle at 85% 18%,rgba(31,90,77,.12),transparent 27%),linear-gradient(180deg,var(--bg),var(--paper));color:var(--ink);font-family:Manrope,system-ui,sans-serif;line-height:1.65}body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}body.menu-open{overflow:hidden}img{max-width:100%;display:block}a{text-decoration:none;color:inherit}.container{width:min(var(--container),calc(100% - 32px));margin-inline:auto}.narrow{max-width:920px}.skip-link{position:absolute;left:16px;top:-70px;z-index:999;padding:12px 16px;border-radius:999px;background:var(--ink);color:var(--bg);transition:top .2s}.skip-link:focus{top:16px}button:focus-visible,a:focus-visible,summary:focus-visible{outline:3px solid var(--green);outline-offset:4px}.site-header{position:sticky;top:0;z-index:50;border-bottom:1px solid color-mix(in srgb,var(--line) 76%,transparent);background:color-mix(in srgb,var(--bg) 84%,transparent);backdrop-filter:blur(18px)}.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:inline-flex;align-items:center;gap:12px;font-weight:800;letter-spacing:-.03em}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,var(--terracotta),var(--green));color:#fff;font-family:"Cormorant Garamond",serif;font-size:20px;box-shadow:var(--soft-shadow)}.nav-menu{display:flex;align-items:center;gap:22px;color:var(--muted);font-size:.94rem}.nav-menu a{transition:color .2s,transform .2s}.nav-menu a:hover{color:var(--ink);transform:translateY(-1px)}.nav-cta{padding:11px 17px;border-radius:999px;background:var(--ink);color:var(--bg)!important}.controls{display:flex;gap:8px}.pill,.menu-toggle{border:1px solid var(--line);background:color-mix(in srgb,var(--surface) 90%,transparent);color:var(--ink);cursor:pointer}.pill{min-width:44px;height:42px;padding:0 13px;border-radius:999px;font-weight:800}.menu-toggle{display:none;width:44px;height:44px;border-radius:14px}.menu-toggle span{display:block;width:20px;height:2px;margin:5px auto;background:var(--ink);border-radius:99px}.hero,.page-hero,.property-hero{padding:86px 0 58px}.hero-grid,.property-hero-grid{display:grid;grid-template-columns:1fr .86fr;gap:56px;align-items:center}.eyebrow{margin:0 0 12px;color:var(--terracotta);font-weight:900;text-transform:uppercase;letter-spacing:.14em;font-size:.76rem}h1,h2,h3{line-height:1.02;letter-spacing:-.045em;margin-top:0}h1,h2{font-family:"Cormorant Garamond",Georgia,serif}h1{font-size:clamp(3.2rem,7.2vw,7.4rem);margin-bottom:22px}h2{font-size:clamp(2.2rem,4.4vw,4.8rem);margin-bottom:18px}h3{font-size:1.25rem;margin-bottom:10px}p{color:var(--muted)}.hero-text{max-width:680px;font-size:1.14rem}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}.center-actions{justify-content:center}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:12px 19px;border-radius:999px;border:1px solid var(--line);font-weight:900;letter-spacing:-.015em;transition:transform .2s,box-shadow .2s,background .2s}.btn:hover{transform:translateY(-2px);box-shadow:var(--soft-shadow)}.btn.primary{background:var(--green);color:#fff;border-color:transparent}.btn.secondary{background:var(--surface);color:var(--ink)}.btn.ghost{background:transparent;color:var(--terracotta);border-color:color-mix(in srgb,var(--terracotta) 35%,var(--line))}.hero-card{position:relative;padding:12px;border:1px solid var(--line);border-radius:calc(var(--radius) + 10px);background:color-mix(in srgb,var(--surface) 72%,transparent);box-shadow:var(--shadow)}.hero-card img,.property-card img{border-radius:var(--radius);width:100%;height:auto}.floating-card{position:absolute;left:-22px;bottom:26px;max-width:260px;padding:18px 20px;border:1px solid var(--line);border-radius:22px;background:color-mix(in srgb,var(--surface) 92%,transparent);box-shadow:var(--soft-shadow);backdrop-filter:blur(12px)}.floating-card strong{display:block;font-family:"Cormorant Garamond",serif;font-size:1.5rem}.floating-card span{display:block;color:var(--muted);font-size:.92rem}.trust-strip{padding:18px 0}.trust-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.trust-row span{padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:color-mix(in srgb,var(--surface) 80%,transparent);font-weight:800;font-size:.86rem;color:var(--muted)}.section{padding:76px 0}.section.soft{background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--green) 7%,transparent),transparent)}.split-intro{display:grid;grid-template-columns:1fr .78fr;gap:42px;align-items:end;margin-bottom:34px}.section-heading{text-align:center;max-width:850px;margin-inline:auto;margin-bottom:34px}.property-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.property-grid.large{grid-template-columns:repeat(2,1fr);gap:24px}.property-card{overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--surface) 88%,transparent);box-shadow:var(--soft-shadow)}.property-card img{border-radius:0;height:230px;object-fit:cover;width:100%}.property-content{padding:24px}.property-subtitle{margin:0 0 8px;color:var(--green);font-weight:900;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}.property-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.editorial-grid{display:grid;grid-template-columns:1fr .7fr;gap:26px;align-items:stretch}.editorial-card,.detail-panel,.quote-panel,.guide-card,.cta-card{border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--surface) 88%,transparent);box-shadow:var(--soft-shadow);padding:36px}.note-stack{display:grid;gap:14px}.note-stack div{display:flex;align-items:center;gap:16px;padding:22px;border:1px solid var(--line);border-radius:24px;background:var(--surface)}.note-stack strong{font-family:"Cormorant Garamond",serif;font-size:2.4rem;color:var(--terracotta)}.note-stack span{font-weight:800}.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.review-grid blockquote{margin:0;padding:24px;border:1px solid var(--line);border-radius:24px;background:var(--surface);box-shadow:var(--soft-shadow);color:var(--gold);font-weight:900}.review-grid p{font-family:"Cormorant Garamond",serif;font-size:1.35rem;line-height:1.18;color:var(--ink);font-weight:600}.faq-wrap{display:grid;grid-template-columns:.55fr 1fr;gap:42px}.faq-list{display:grid;gap:12px}details{border:1px solid var(--line);border-radius:20px;background:var(--surface);padding:18px 20px}summary{cursor:pointer;font-weight:900}.cta-card{text-align:center;max-width:940px;margin-inline:auto}.cta-card.mini{text-align:left}.page-hero{text-align:center}.property-hero h1{font-size:clamp(3.1rem,6vw,6.5rem)}.detail-grid{display:grid;grid-template-columns:1fr .62fr;gap:24px}.check-list{padding:0;margin:24px 0 0;list-style:none;display:grid;gap:12px}.check-list li{padding-left:34px;position:relative;color:var(--muted);font-weight:700}.check-list li:before{content:"✓";position:absolute;left:0;top:0;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:color-mix(in srgb,var(--green) 15%,transparent);color:var(--green);font-weight:900}.quote-panel{align-self:start}.quote-panel p{font-family:"Cormorant Garamond",serif;font-size:1.7rem;line-height:1.15;color:var(--ink)}.guide-card{display:flex;gap:28px;align-items:center;justify-content:space-between}.footer{padding:46px 0;border-top:1px solid var(--line);background:color-mix(in srgb,var(--surface) 70%,transparent)}.footer-grid{display:grid;grid-template-columns:1fr auto;gap:30px;align-items:start}.footer strong{font-family:"Cormorant Garamond",serif;font-size:2rem}.footer-links{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted)}.reveal{animation:rise .7s ease both}.property-card:nth-child(2){animation-delay:.07s}.property-card:nth-child(3){animation-delay:.14s}.property-card:nth-child(4){animation-delay:.21s}@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;animation:none!important;transition:none!important}}@media (max-width:980px){.nav-menu{position:fixed;inset:78px 16px auto 16px;display:none;flex-direction:column;align-items:stretch;padding:20px;border:1px solid var(--line);border-radius:24px;background:var(--surface);box-shadow:var(--shadow)}.nav-menu.is-open{display:flex}.menu-toggle{display:block}.hero-grid,.property-hero-grid,.split-intro,.editorial-grid,.faq-wrap,.detail-grid,.footer-grid,.guide-card{grid-template-columns:1fr}.property-grid,.property-grid.large,.review-grid{grid-template-columns:1fr 1fr}.floating-card{left:18px;bottom:18px}.controls{margin-left:auto}}@media (max-width:640px){.container{width:min(100% - 24px,var(--container))}.hero,.page-hero,.property-hero{padding:54px 0 38px}.section{padding:52px 0}.property-grid,.property-grid.large,.review-grid{grid-template-columns:1fr}.hero-actions,.property-actions{align-items:stretch}.btn{width:100%}.nav{height:72px}.controls .pill{min-width:40px;height:40px}.brand span:last-child{max-width:122px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.footer-links{flex-direction:column}.editorial-card,.detail-panel,.quote-panel,.guide-card,.cta-card{padding:26px}.floating-card{position:static;margin-top:12px;max-width:none}h1{font-size:clamp(2.9rem,16vw,4.2rem)}}

/* v4.2 enhancements: scroll motion, galleries, light texture, availability */
body{
  background:
    radial-gradient(circle at 12% 8%,rgba(169,83,54,.18),transparent 30%),
    radial-gradient(circle at 84% 18%,rgba(31,90,77,.14),transparent 28%),
    radial-gradient(circle at 50% 72%,rgba(179,138,74,.10),transparent 36%),
    linear-gradient(180deg,var(--bg),var(--paper));
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  opacity:.34;
  background-image:
    linear-gradient(90deg, color-mix(in srgb,var(--line) 50%,transparent) 1px, transparent 1px),
    linear-gradient(180deg, color-mix(in srgb,var(--line) 50%,transparent) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 72%);
}
html[data-theme=dark] body::after{opacity:.18}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s ease, transform .75s ease;transition-delay:var(--delay,0ms)}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.btn:hover,.nav-menu a:hover{transform:none}}
.gallery-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;grid-auto-rows:220px;gap:14px;margin-top:28px}
.gallery-item{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:26px;background:var(--surface);box-shadow:var(--soft-shadow)}
.gallery-item:first-child{grid-row:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .65s ease, filter .65s ease}
.gallery-item:hover img{transform:scale(1.045);filter:saturate(1.04)}
.gallery-item span{position:absolute;left:14px;bottom:14px;padding:8px 12px;border-radius:999px;background:color-mix(in srgb,var(--surface) 86%,transparent);color:var(--ink);font-size:.78rem;font-weight:900;backdrop-filter:blur(10px);border:1px solid var(--line)}
.availability-card{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--surface) 90%,transparent);box-shadow:var(--soft-shadow);padding:34px}
.availability-status{display:inline-flex;align-items:center;gap:9px;margin-top:8px;color:var(--muted);font-weight:800}
.availability-dot{width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px color-mix(in srgb,var(--gold) 18%,transparent)}
@media (max-width:820px){.gallery-grid{grid-template-columns:1fr;grid-auto-rows:240px}.gallery-item:first-child{grid-row:auto}.availability-card{grid-template-columns:1fr}}


/* v4.4 FAQ + future hero video support */
.hero-video-frame{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--surface)}
.hero-video-frame video,.hero-video-frame img{width:100%;height:100%;min-height:420px;object-fit:cover;display:block}
.hero-video-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(31,90,77,.20),rgba(169,83,54,.10) 45%,rgba(17,16,14,.20));pointer-events:none}
.faq-list details p{margin-bottom:0}
@media (max-width:640px){.hero-video-frame video,.hero-video-frame img{min-height:300px}}

/* v4.5 editorial premium: subtle hero video + richer paper texture */
:root{
  --editorial-blur: 18px;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  opacity:.32;
  background-image:
    radial-gradient(circle at 18% 22%, rgba(169,83,54,.09), transparent 28%),
    radial-gradient(circle at 82% 10%, rgba(31,90,77,.08), transparent 32%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.72' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.28'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
html[data-theme=dark] body::before{opacity:.18;mix-blend-mode:screen}
.hero-editorial{
  position:relative;
  min-height:calc(100vh - 86px);
  display:grid;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
  background:var(--charcoal);
  border-bottom:1px solid color-mix(in srgb,var(--gold) 24%,transparent);
}
.hero-bg-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:-4;
  opacity:.74;
  filter:saturate(.94) contrast(1.04) brightness(.86);
  transform:scale(1.02);
}
.hero-film{
  position:absolute;
  inset:0;
  z-index:-3;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(17,16,14,.76) 0%, rgba(17,16,14,.56) 38%, rgba(17,16,14,.24) 72%, rgba(17,16,14,.38) 100%),
    radial-gradient(circle at 72% 32%, rgba(179,138,74,.22), transparent 32%),
    radial-gradient(circle at 26% 70%, rgba(31,90,77,.28), transparent 30%);
}
.hero-editorial::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  pointer-events:none;
  opacity:.22;
  background-image:
    linear-gradient(115deg, transparent 0 42%, rgba(255,255,255,.18) 42.2% 42.45%, transparent 42.7% 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23g)' opacity='.5'/%3E%3C/svg%3E");
  mix-blend-mode:soft-light;
}
.hero-editorial .hero-grid{position:relative;z-index:1;padding:48px 0}
.hero-editorial .eyebrow{color:rgba(249,241,228,.82)}
.hero-editorial h1{color:#fff7ea;text-shadow:0 18px 60px rgba(0,0,0,.38)}
.hero-editorial .hero-text{color:rgba(255,247,234,.86);max-width:58ch}
.hero-editorial .btn.primary{box-shadow:0 18px 44px rgba(0,0,0,.22)}
.hero-editorial .btn.secondary{background:rgba(255,247,234,.12);color:#fff7ea;border-color:rgba(255,247,234,.26);backdrop-filter:blur(14px)}
.hero-editorial .btn.secondary:hover{background:rgba(255,247,234,.20)}
.editorial-glass{
  background:linear-gradient(145deg, rgba(255,247,234,.14), rgba(255,247,234,.06));
  border-color:rgba(255,247,234,.20);
  box-shadow:0 26px 70px rgba(0,0,0,.36);
  backdrop-filter:blur(var(--editorial-blur));
}
.editorial-glass img{filter:saturate(.94) contrast(1.02)}
.editorial-glass .floating-card{background:rgba(255,247,234,.78);backdrop-filter:blur(16px)}
html[data-theme=light] .section.soft,
html[data-theme=light] .site-footer{
  background-image:
    radial-gradient(circle at 10% 20%, rgba(169,83,54,.06), transparent 28%),
    radial-gradient(circle at 90% 70%, rgba(31,90,77,.06), transparent 32%);
}
@media (prefers-reduced-motion:reduce){.hero-bg-video{display:none}.hero-editorial{background:linear-gradient(135deg,var(--charcoal),#2f473f)}}
@media (max-width:980px){.hero-editorial{min-height:auto}.hero-editorial .hero-grid{padding:24px 0}.hero-film{background:linear-gradient(180deg, rgba(17,16,14,.78), rgba(17,16,14,.50))}}
@media (max-width:640px){.hero-editorial{padding-top:36px}.hero-bg-video{opacity:.58}.hero-editorial .hero-card{display:none}.hero-editorial h1{font-size:clamp(3.1rem,18vw,4.6rem)}}

/* v4.7: visible editorial paper texture in light mode too */
body{position:relative;min-height:100vh;}
body::before{
  z-index:0!important;
  opacity:.20!important;
  mix-blend-mode:multiply!important;
  background-image:
    radial-gradient(circle at 16% 18%, rgba(169,83,54,.10), transparent 24%),
    radial-gradient(circle at 86% 16%, rgba(31,90,77,.08), transparent 28%),
    radial-gradient(circle at 48% 80%, rgba(179,138,74,.08), transparent 30%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Cfilter id='paper'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.95' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23paper)' opacity='.34'/%3E%3C/svg%3E")!important;
}
body::after{
  z-index:0!important;
  opacity:.115!important;
  mix-blend-mode:multiply!important;
  background-image:
    linear-gradient(90deg, rgba(120,82,54,.22) 1px, transparent 1px),
    linear-gradient(180deg, rgba(120,82,54,.16) 1px, transparent 1px)!important;
  background-size:86px 86px!important;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,.18) 58%, transparent 100%)!important;
}
html[data-theme=dark] body::before{opacity:.16!important;mix-blend-mode:screen!important;}
html[data-theme=dark] body::after{opacity:.10!important;mix-blend-mode:screen!important;}
.site-header, main, .footer, .site-footer{position:relative;z-index:1;}
.hero-editorial{z-index:1;}
/* very subtle paper wash behind content blocks */
html[data-theme=light] .section,
html[data-theme=light] .page-hero,
html[data-theme=light] .property-hero{
  background-image:
    radial-gradient(circle at 10% 10%, rgba(169,83,54,.035), transparent 28%),
    radial-gradient(circle at 92% 18%, rgba(31,90,77,.035), transparent 30%);
}


/* v4.8: clean hero video, no global dark opacity over the video */
.hero-bg-video{
  opacity:1!important;
  filter:none!important;
  transform:scale(1.01);
}
.hero-film{
  background:none!important;
}
.hero-editorial::after{
  opacity:.07!important;
  mix-blend-mode:soft-light;
}
.hero-editorial .hero-content,
.hero-editorial .hero-copy,
.hero-editorial .hero-text{
  position:relative;
}
.hero-editorial .hero-copy::before,
.hero-editorial .hero-content::before{
  content:"";
  position:absolute;
  inset:-24px -28px;
  z-index:-1;
  border-radius:32px;
  background:linear-gradient(90deg, rgba(17,16,14,.30), rgba(17,16,14,.06) 72%, transparent);
  filter:blur(2px);
  pointer-events:none;
}
@media (max-width:980px){
  .hero-film{background:none!important;}
  .hero-editorial .hero-copy::before,
  .hero-editorial .hero-content::before{
    inset:-18px -14px;
    background:linear-gradient(180deg, rgba(17,16,14,.22), rgba(17,16,14,.05));
  }
}
@media (max-width:640px){
  .hero-bg-video{
    opacity:1!important;
    filter:none!important;
  }
  .hero-editorial::after{
    opacity:.045!important;
  }
}


/* v4.9: refined boutique buttons, especially on mobile */
.btn,
button,
.lang-toggle,
.theme-toggle,
.menu-toggle {
  -webkit-tap-highlight-color: transparent;
}

.btn {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  width: auto;
  min-width: unset;
  justify-content: center;
  transition:
    transform .24s ease,
    box-shadow .24s ease,
    background-color .24s ease,
    border-color .24s ease;
}

.btn::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    115deg,
    transparent 0 34%,
    rgba(255,255,255,.32) 44%,
    transparent 56% 100%
  );
  transform: translateX(-130%);
  opacity: .55;
  transition: transform .7s cubic-bezier(.2,.8,.2,1), opacity .3s ease;
  z-index: -1;
}

.btn:hover::after,
.btn:focus-visible::after {
  transform: translateX(130%);
}

.btn:hover {
  transform: translateY(-2px);
}

.btn:active {
  transform: translateY(0) scale(.985);
}

.hero-actions,
.property-actions,
.cta-actions,
.card-actions,
.actions {
  align-items: center;
}

@media (max-width: 640px) {
  .hero-actions,
  .property-actions,
  .cta-actions,
  .card-actions,
  .actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 12px;
  }

  .hero-actions .btn,
  .property-actions .btn,
  .cta-actions .btn,
  .card-actions .btn,
  .actions .btn {
    width: auto !important;
    max-width: max-content;
    min-width: 0;
    padding: 13px 20px;
    font-size: .94rem;
    border-radius: 999px;
    box-shadow: 0 12px 30px rgba(28, 22, 18, .16);
  }

  .hero-actions .btn.primary,
  .property-actions .btn.primary,
  .cta-actions .btn.primary {
    padding-inline: 22px;
  }

  .hero-actions .btn.secondary,
  .property-actions .btn.secondary,
  .cta-actions .btn.secondary {
    background: rgba(255,247,234,.13);
    border: 1px solid rgba(255,247,234,.28);
    backdrop-filter: blur(12px);
  }

  /* En páginas claras, los botones secundarios no deben verse pesados */
  html[data-theme="light"] .btn.secondary {
    background: rgba(255,255,255,.78);
    border-color: rgba(111,84,61,.18);
    box-shadow: 0 10px 24px rgba(60,38,23,.10);
  }

  /* En el hero móvil: botón principal elegante, no full-width */
  .hero-editorial .hero-actions {
    margin-top: 24px;
  }

  .hero-editorial .hero-actions .btn {
    width: auto !important;
    max-width: max-content;
  }

  .hero-editorial .hero-actions .btn.primary {
    background: linear-gradient(135deg, var(--green), color-mix(in srgb, var(--green) 74%, #ffffff 18%));
  }

  .hero-editorial .hero-actions .btn.secondary {
    color: #fff7ea;
  }

  /* Pequeño detalle editorial debajo de los botones */
  .hero-editorial .hero-actions::after {
    content: "";
    flex-basis: 100%;
    width: 86px;
    height: 1px;
    margin-top: 2px;
    background: linear-gradient(90deg, rgba(255,247,234,.55), transparent);
    opacity: .72;
  }
}

@media (max-width: 420px) {
  .hero-actions,
  .property-actions,
  .cta-actions,
  .card-actions,
  .actions {
    gap: 10px;
  }

  .hero-actions .btn,
  .property-actions .btn,
  .cta-actions .btn,
  .card-actions .btn,
  .actions .btn {
    padding: 12px 17px;
    font-size: .9rem;
  }
}


/* v availability live calendar */
.availability-card{align-items:start}
.availability-copy{min-width:0}
.availability-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.availability-card.is-loading .availability-dot{background:var(--gold);animation:availabilityPulse 1.2s ease-in-out infinite}
.availability-card.is-ok .availability-dot{background:#2f9e67;box-shadow:0 0 0 6px color-mix(in srgb,#2f9e67 18%,transparent)}
.availability-card.is-warning .availability-dot{background:var(--gold);box-shadow:0 0 0 6px color-mix(in srgb,var(--gold) 18%,transparent)}
.availability-card.is-error .availability-dot{background:#b94b3d;box-shadow:0 0 0 6px color-mix(in srgb,#b94b3d 18%,transparent)}
.availability-results{margin-top:18px;display:grid;gap:10px}
.availability-summary{font-weight:900;color:var(--ink);margin:0}
.availability-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.availability-list li{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 12px;border:1px solid var(--line);border-radius:16px;background:color-mix(in srgb,var(--paper) 72%,transparent);font-weight:800;color:var(--muted)}
.availability-badge{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);white-space:nowrap}
.availability-help{font-size:.92rem;color:var(--muted);margin:6px 0 0}
@keyframes availabilityPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.18);opacity:.65}}
@media (max-width:820px){.availability-actions{justify-content:flex-start}.availability-list li{align-items:flex-start;flex-direction:column;gap:4px}}


/* Monthly availability calendar */
.availability-card{
  align-items: start;
}

.availability-calendar{
  margin-top: 22px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--soft-shadow);
}

.calendar-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-bottom:16px;
}

.calendar-header h3{
  margin:4px 0 0;
  font-size: clamp(1.7rem, 3vw, 2.35rem);
  line-height:.95;
  text-transform: capitalize;
}

.calendar-nav{
  display:flex;
  gap:8px;
}

.calendar-nav-btn{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--ink);
  font-size:1.6rem;
  line-height:1;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(60,38,23,.08);
  transition:transform .2s ease, background .2s ease;
}

.calendar-nav-btn:hover{
  transform:translateY(-1px);
  background:color-mix(in srgb, var(--terracotta) 9%, var(--surface));
}

.calendar-weekdays,
.calendar-grid{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:7px;
}

.calendar-weekdays{
  margin-bottom:8px;
}

.calendar-weekdays span{
  text-align:center;
  font-size:.78rem;
  font-weight:800;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
}

.calendar-day{
  min-height:58px;
  border-radius:16px;
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--surface) 88%, transparent);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:9px;
  position:relative;
  overflow:hidden;
}

.calendar-day.is-empty{
  border-color:transparent;
  background:transparent;
}

.calendar-day-number{
  font-weight:900;
  color:var(--ink);
  font-size:.95rem;
}

.calendar-day-label{
  font-size:.66rem;
  font-weight:900;
  color:var(--terracotta);
  letter-spacing:.02em;
}

.calendar-day.is-available:not(.is-past)::after{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--green);
  position:absolute;
  right:9px;
  bottom:9px;
  opacity:.7;
}

.calendar-day.is-blocked{
  background:color-mix(in srgb, var(--terracotta) 14%, var(--surface));
  border-color:color-mix(in srgb, var(--terracotta) 34%, var(--line));
}

.calendar-day.is-blocked .calendar-day-number{
  color:var(--ink);
}

.calendar-day.is-past{
  opacity:.48;
}

.calendar-day.is-today{
  outline:2px solid color-mix(in srgb, var(--green) 58%, transparent);
  outline-offset:2px;
}

.calendar-legend{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:16px;
  color:var(--muted);
  font-size:.92rem;
  font-weight:700;
}

.calendar-legend span{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.legend-dot{
  width:11px;
  height:11px;
  border-radius:50%;
  display:inline-block;
}

.legend-dot.is-available{
  background:var(--green);
}

.legend-dot.is-blocked{
  background:var(--terracotta);
}

@media (max-width: 720px){
  .availability-calendar{
    padding:14px;
    border-radius:22px;
  }

  .calendar-day{
    min-height:48px;
    border-radius:13px;
    padding:7px;
  }

  .calendar-day-label{
    display:none;
  }

  .calendar-weekdays,
  .calendar-grid{
    gap:5px;
  }

  .calendar-nav-btn{
    width:38px;
    height:38px;
  }
}

@media (max-width: 420px){
  .calendar-day{
    min-height:42px;
    padding:6px;
  }

  .calendar-day-number{
    font-size:.84rem;
  }

  .calendar-weekdays span{
    font-size:.68rem;
  }
}


/* Airbnb-style property gallery and immediate availability */
.property-media-section{
  padding: clamp(22px, 4vw, 46px) 0 18px;
}

.property-title-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:20px;
}

.property-title-row h1{
  margin:6px 0 0;
  font-size: clamp(2.2rem, 6vw, 4.6rem);
  line-height:.9;
}

.property-title-actions{
  display:flex;
  align-items:center;
  gap:12px;
}

.property-title-actions a{
  color:var(--ink);
  font-weight:800;
  text-decoration:underline;
  text-underline-offset:4px;
}

.airbnb-gallery{
  position:relative;
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  grid-template-rows:repeat(2, minmax(170px, 255px));
  gap:8px;
  border-radius:22px;
  overflow:hidden;
}

.airbnb-gallery-item{
  margin:0;
  position:relative;
  cursor:pointer;
  background:var(--line);
  overflow:hidden;
}

.airbnb-gallery-item:first-child{
  grid-row:1 / span 2;
}

.airbnb-gallery-item img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transition:transform .35s ease, filter .35s ease;
}

.airbnb-gallery-item:hover img{
  transform:scale(1.035);
  filter:brightness(.92);
}

.show-all-photos{
  position:absolute;
  right:18px;
  bottom:18px;
  z-index:5;
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(33,25,21,.18);
  background:rgba(255,255,255,.94);
  color:#211915;
  border-radius:12px;
  padding:10px 14px;
  font-weight:850;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}

.photo-tour{
  position:fixed;
  inset:0;
  z-index:5000;
  display:none;
  background:#fff;
  color:#211915;
}

.photo-tour.is-open{
  display:block;
}

body.photo-tour-open{
  overflow:hidden;
}

.photo-tour-top{
  position:sticky;
  top:0;
  z-index:2;
  height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 24px;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid rgba(0,0,0,.08);
  backdrop-filter:blur(12px);
}

.photo-tour-close{
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:#f4f0ea;
  color:#211915;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
}

.photo-tour-actions{
  font-weight:850;
}

.photo-tour-scroll{
  height:calc(100vh - 76px);
  overflow-y:auto;
  padding:32px 20px 60px;
}

.photo-tour-grid{
  width:min(760px, 100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}

.photo-tour-item{
  margin:0;
  background:#f4f0ea;
}

.photo-tour-item:nth-child(3n + 1){
  grid-column:1 / -1;
}

.photo-tour-item img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
}

.photo-tour-item figcaption{
  padding:10px 2px 18px;
  color:#6d5d51;
  font-size:.92rem;
  font-weight:700;
}

.availability-card{
  margin-top:0;
}

.availability-quick-status{
  margin:18px 0 18px;
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:20px;
  background:color-mix(in srgb, var(--green) 7%, var(--surface));
}

.availability-quick-status strong{
  display:block;
  margin-bottom:6px;
  color:var(--ink);
}

.availability-quick-status p{
  margin:0;
  color:var(--muted);
}

@media (max-width: 860px){
  .property-title-row{
    align-items:flex-start;
    flex-direction:column;
  }

  .airbnb-gallery{
    grid-template-columns:1fr 1fr;
    grid-template-rows:220px 150px 150px;
  }

  .airbnb-gallery-item:first-child{
    grid-column:1 / -1;
    grid-row:auto;
  }

  .airbnb-gallery-item:nth-child(n+6){
    display:none;
  }
}

@media (max-width: 560px){
  .airbnb-gallery{
    grid-template-columns:1fr;
    grid-template-rows:300px;
    border-radius:18px;
  }

  .airbnb-gallery-item{
    display:none;
  }

  .airbnb-gallery-item:first-child{
    display:block;
  }

  .show-all-photos{
    right:12px;
    bottom:12px;
    padding:9px 12px;
    font-size:.9rem;
  }

  .photo-tour-grid{
    grid-template-columns:1fr;
  }

  .photo-tour-item:nth-child(n){
    grid-column:auto;
  }

  .photo-tour-scroll{
    padding:18px 14px 50px;
  }
}


/* v2 — galería principal estilo Airbnb: mostrar solo 5 fotos arriba.
   La sexta foto sigue disponible dentro de "Mostrar todas las fotos". */
.airbnb-gallery > .airbnb-gallery-item:nth-of-type(n+6){
  display:none !important;
}

.airbnb-gallery{
  grid-template-columns:2fr 1fr 1fr !important;
  grid-template-rows:repeat(2, minmax(170px, 255px)) !important;
  margin-bottom:0 !important;
}

.property-media-section{
  padding-bottom:10px !important;
}

.property-media-section + .section[aria-labelledby="availability-title"]{
  padding-top:18px !important;
}

@media (max-width: 560px){
  .airbnb-gallery > .airbnb-gallery-item:nth-of-type(n+2){
    display:none !important;
  }
}


/* v3 — Mobile responsive repair: menu overlay, gallery CTAs, compact availability */

/* El menú hamburguesa no debe empujar el contenido */
@media (max-width: 900px){
  .site-header{
    position:sticky;
    top:0;
    z-index:3000;
  }

  .nav,
  .site-nav{
    position:relative;
  }

  .nav-menu,
  .site-menu{
    position:absolute !important;
    top:calc(100% + 10px) !important;
    left:16px !important;
    right:16px !important;
    z-index:3500 !important;
    display:none !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:10px !important;
    padding:18px !important;
    border:1px solid var(--line, #eadcc9) !important;
    border-radius:22px !important;
    background:rgba(255,250,242,.98) !important;
    box-shadow:0 24px 70px rgba(60,38,23,.20) !important;
    backdrop-filter:blur(14px) !important;
  }

  .nav-menu.is-open,
  .site-menu.is-open,
  body.menu-open .nav-menu,
  body.menu-open .site-menu{
    display:flex !important;
  }

  .nav-menu a,
  .site-menu a{
    width:100% !important;
    padding:8px 10px !important;
    line-height:1.2 !important;
  }
}

/* El bloque de título no debe quedar aplastado por el menú */
.property-media-section{
  padding-top:clamp(18px, 3vw, 32px) !important;
}

/* Botones de reservar/contactar sobre la galería, esquina inferior derecha */
.property-title-row{
  align-items:flex-start !important;
  margin-bottom:14px !important;
}

.property-title-actions{
  display:none !important;
}

.airbnb-gallery{
  position:relative !important;
}

.gallery-floating-actions{
  position:absolute;
  right:18px;
  bottom:18px;
  z-index:10;
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
}

.gallery-floating-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 15px;
  border-radius:999px;
  font-weight:850;
  text-decoration:none;
  box-shadow:0 12px 30px rgba(0,0,0,.16);
}

.gallery-floating-actions .primary-action{
  background:var(--green, #1f5a4d);
  color:#fffaf2;
}

.gallery-floating-actions .secondary-action{
  background:rgba(255,255,255,.94);
  color:var(--ink, #211915);
  border:1px solid rgba(33,25,21,.16);
}

/* Botón mostrar fotos se mueve a izquierda para no chocar con CTAs */
.show-all-photos{
  left:18px !important;
  right:auto !important;
  bottom:18px !important;
}

/* Menos alto en la galería para que suba disponibilidad */
.airbnb-gallery{
  grid-template-rows:repeat(2, minmax(145px, 220px)) !important;
}

/* Disponibilidad más compacta y más arriba */
.property-media-section + .section[aria-labelledby="availability-title"]{
  padding-top:10px !important;
}

.availability-card{
  display:grid !important;
  grid-template-columns:minmax(0, .85fr) minmax(320px, 1.15fr) !important;
  gap:20px !important;
  align-items:start !important;
  padding-top:22px !important;
  padding-bottom:22px !important;
}

.availability-copy > p:not(.eyebrow),
.availability-actions{
  display:none !important;
}

.availability-status{
  margin-top:10px !important;
}

.availability-results{
  grid-column:auto !important;
}

.availability-calendar{
  margin-top:0 !important;
  padding:14px !important;
  border-radius:22px !important;
}

.availability-quick-status{
  margin:0 0 12px !important;
  padding:12px 14px !important;
  border-radius:16px !important;
}

.calendar-header{
  margin-bottom:10px !important;
}

.calendar-header h3{
  font-size:clamp(1.65rem, 3vw, 2.4rem) !important;
}

.calendar-day{
  min-height:46px !important;
  border-radius:13px !important;
  padding:7px !important;
}

.calendar-weekdays,
.calendar-grid{
  gap:5px !important;
}

.calendar-legend,
.availability-help{
  margin-top:10px !important;
}

/* Tablet / iPad */
@media (max-width: 900px){
  .airbnb-gallery{
    grid-template-columns:1fr 1fr !important;
    grid-template-rows:260px 165px !important;
  }

  .airbnb-gallery-item:first-child{
    grid-column:1 / -1 !important;
  }

  .airbnb-gallery > .airbnb-gallery-item:nth-of-type(n+4){
    display:none !important;
  }

  .availability-card{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }

  .availability-results{
    width:100% !important;
  }
}

/* Celular */
@media (max-width: 560px){
  .property-title-row{
    margin-bottom:10px !important;
  }

  .property-title-row h1{
    font-size:clamp(2.5rem, 15vw, 4rem) !important;
  }

  .property-title-row .eyebrow{
    max-width:100% !important;
    white-space:normal !important;
  }

  .airbnb-gallery{
    grid-template-columns:1fr !important;
    grid-template-rows:300px !important;
    max-height:300px !important;
  }

  .airbnb-gallery-item:first-child{
    display:block !important;
  }

  .airbnb-gallery > .airbnb-gallery-item:nth-of-type(n+2){
    display:none !important;
  }

  .gallery-floating-actions{
    right:10px;
    bottom:10px;
    gap:8px;
  }

  .gallery-floating-actions a{
    min-height:38px;
    padding:9px 11px;
    font-size:.84rem;
  }

  .show-all-photos{
    left:10px !important;
    bottom:10px !important;
    padding:9px 10px !important;
    font-size:.82rem !important;
  }

  .availability-card{
    padding:18px 16px !important;
  }

  .availability-calendar{
    padding:12px !important;
  }

  .calendar-day{
    min-height:39px !important;
    padding:5px !important;
  }

  .calendar-day-number{
    font-size:.82rem !important;
  }

  .calendar-nav-btn{
    width:36px !important;
    height:36px !important;
  }

  .calendar-legend{
    font-size:.82rem !important;
  }
}


/* v4 — Disponibilidad en 2 columnas en escritorio */
@media (min-width: 901px){
  .availability-card{
    display:grid !important;
    grid-template-columns:minmax(330px, 0.82fr) minmax(460px, 1.18fr) !important;
    gap:42px !important;
    align-items:start !important;
    padding:34px 38px !important;
  }

  .availability-copy{
    max-width:430px !important;
  }

  .availability-copy h2{
    max-width:420px !important;
    margin-bottom:22px !important;
  }

  .availability-status,
  .availability-quick-status{
    max-width:420px !important;
  }

  .availability-results{
    grid-column:2 !important;
    grid-row:1 / span 2 !important;
    width:100% !important;
    align-self:start !important;
  }

  .availability-calendar{
    width:100% !important;
    max-width:620px !important;
    margin:0 0 0 auto !important;
  }

  .calendar-day{
    min-height:54px !important;
  }
}

/* En tablet y móvil vuelve a una columna */
@media (max-width: 900px){
  .availability-card{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .availability-results{
    grid-column:auto !important;
    grid-row:auto !important;
  }

  .availability-calendar{
    max-width:100% !important;
    margin-top:0 !important;
  }
}


/* v5 — Corrección real: calendario a la derecha, texto/frase a la izquierda */
@media (min-width: 901px){
  .availability-card{
    display:grid !important;
    grid-template-columns:minmax(360px, 0.82fr) minmax(520px, 1.18fr) !important;
    grid-template-rows:auto auto auto !important;
    column-gap:44px !important;
    row-gap:16px !important;
    align-items:start !important;
    padding:38px 42px !important;
  }

  .availability-copy{
    grid-column:1 !important;
    grid-row:1 !important;
    max-width:460px !important;
  }

  .availability-copy h2{
    max-width:450px !important;
    margin-bottom:18px !important;
  }

  /* Este contenedor deja de comportarse como caja para poder mandar sus hijos a columnas distintas */
  .availability-results{
    display:contents !important;
  }

  /* Frase rápida queda debajo del texto, columna izquierda */
  .availability-quick-status{
    grid-column:1 !important;
    grid-row:2 !important;
    max-width:460px !important;
    margin:0 !important;
    align-self:start !important;
  }

  /* Calendario mensual sube al lado derecho, usando el espacio blanco */
  .availability-calendar{
    grid-column:2 !important;
    grid-row:1 / span 3 !important;
    width:100% !important;
    max-width:660px !important;
    margin:0 0 0 auto !important;
    align-self:start !important;
  }

  .calendar-header h3{
    font-size:clamp(2rem, 3vw, 3.1rem) !important;
  }

  .calendar-day{
    min-height:58px !important;
  }

  .availability-actions{
    display:none !important;
  }
}

/* En móvil y tablet se apila normal */
@media (max-width: 900px){
  .availability-results{
    display:block !important;
  }

  .availability-quick-status,
  .availability-calendar{
    max-width:100% !important;
    margin-top:0 !important;
  }
}


/* v6 — FIX REAL: .availability-results está dentro de .availability-copy.
   Para que el calendario vaya a la derecha, liberamos ambos contenedores en desktop. */
@media (min-width: 901px){
  .availability-card{
    display:grid !important;
    grid-template-columns:minmax(360px, 0.86fr) minmax(520px, 1.14fr) !important;
    grid-template-rows:auto auto auto !important;
    column-gap:48px !important;
    row-gap:16px !important;
    align-items:start !important;
    padding:38px 42px !important;
  }

  /* clave: este div estaba encerrando todo en la izquierda */
  .availability-copy{
    display:contents !important;
  }

  .availability-copy > .eyebrow{
    grid-column:1 !important;
    grid-row:1 !important;
    align-self:start !important;
    margin:0 0 8px !important;
  }

  .availability-copy > h2{
    grid-column:1 !important;
    grid-row:2 !important;
    max-width:460px !important;
    margin:0 0 18px !important;
    align-self:start !important;
  }

  .availability-copy > p:not(.eyebrow){
    grid-column:1 !important;
    grid-row:3 !important;
    display:none !important;
  }

  .availability-status{
    grid-column:1 !important;
    grid-row:4 !important;
    max-width:460px !important;
    margin:0 0 14px !important;
    align-self:start !important;
  }

  /* clave: este también envolvía frase + calendario */
  .availability-results{
    display:contents !important;
  }

  .availability-quick-status{
    grid-column:1 !important;
    grid-row:5 !important;
    max-width:460px !important;
    margin:0 !important;
    align-self:start !important;
  }

  .availability-calendar{
    grid-column:2 !important;
    grid-row:1 / span 6 !important;
    width:100% !important;
    max-width:680px !important;
    margin:0 !important;
    align-self:start !important;
    justify-self:end !important;
  }

  .calendar-header h3{
    font-size:clamp(2rem, 3vw, 3.1rem) !important;
  }

  .calendar-day{
    min-height:58px !important;
  }

  .availability-actions{
    display:none !important;
  }
}

/* Tablet/móvil: vuelve a estructura normal apilada */
@media (max-width: 900px){
  .availability-copy{
    display:block !important;
  }

  .availability-results{
    display:block !important;
  }

  .availability-quick-status,
  .availability-calendar{
    max-width:100% !important;
    margin-top:0 !important;
  }
}


/* v11 shared persistent language/theme support */
html[data-theme="dark"]{
  color-scheme:dark;
}

/* v6 — brandmark image + full-card property links + mobile photo-tour back arrow fix */
.brand-mark{
  overflow:hidden;
  background:var(--surface) !important;
  border:1px solid var(--line);
  padding:3px;
}
.brand-mark img{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:12px;
}
.property-card[data-card-link]{
  cursor:pointer;
  position:relative;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.property-card[data-card-link]:hover{
  transform:translateY(-3px);
  border-color:color-mix(in srgb,var(--terracotta) 45%,var(--line));
  box-shadow:var(--shadow);
}
.property-card[data-card-link]:focus-visible{
  outline:3px solid var(--green);
  outline-offset:4px;
}
.property-card[data-card-link] .btn{
  position:relative;
  z-index:2;
}
.photo-tour-top{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:7000 !important;
  padding-top:env(safe-area-inset-top) !important;
  height:calc(76px + env(safe-area-inset-top)) !important;
}
.photo-tour-close{
  display:grid !important;
  place-items:center !important;
  flex:0 0 auto !important;
  z-index:7001 !important;
  opacity:1 !important;
  visibility:visible !important;
  -webkit-tap-highlight-color:transparent;
}
.photo-tour-scroll{
  height:100vh !important;
  padding-top:calc(108px + env(safe-area-inset-top)) !important;
  overflow-y:auto !important;
  -webkit-overflow-scrolling:touch;
}
@media (max-width:640px){
  .brand-mark{width:38px;height:38px;border-radius:14px;}
  .photo-tour-top{
    height:calc(66px + env(safe-area-inset-top)) !important;
    padding-left:14px !important;
    padding-right:14px !important;
  }
  .photo-tour-close{
    width:44px !important;
    height:44px !important;
    font-size:2.15rem !important;
    background:#fffaf2 !important;
    border:1px solid rgba(33,25,21,.14) !important;
    box-shadow:0 8px 24px rgba(0,0,0,.14) !important;
  }
  .photo-tour-scroll{
    padding-top:calc(92px + env(safe-area-inset-top)) !important;
  }
}

/* v7 — brandmark uses a real image file, not generated text */
.brand-mark{width:42px !important;height:42px !important;border-radius:16px !important;background:transparent !important;border:0 !important;padding:0 !important;box-shadow:var(--soft-shadow) !important;}
.brand-mark img{width:100% !important;height:100% !important;object-fit:cover !important;border-radius:16px !important;}
@media (max-width:640px){.brand-mark{width:38px !important;height:38px !important;border-radius:14px !important}.brand-mark img{border-radius:14px !important}}

/* v12 — logo completo sin máscara + flecha fija real en galería móvil */
.brand{
  gap:10px !important;
}
.brand-mark{
  width:72px !important;
  height:34px !important;
  min-width:72px !important;
  border-radius:0 !important;
  background:transparent !important;
  border:0 !important;
  padding:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.brand-mark img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center !important;
  border-radius:0 !important;
  display:block !important;
}

.photo-tour.is-open{
  position:fixed !important;
  inset:0 !important;
  z-index:999999 !important;
  overflow:hidden !important;
}
.photo-tour.is-open .photo-tour-top{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:1000000 !important;
  display:flex !important;
  align-items:center !important;
  padding-top:env(safe-area-inset-top) !important;
  background:rgba(255,255,255,.98) !important;
  transform:translateZ(0) !important;
}
.photo-tour.is-open .photo-tour-close{
  position:fixed !important;
  top:calc(14px + env(safe-area-inset-top)) !important;
  left:14px !important;
  z-index:1000001 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  min-height:46px !important;
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  background:#fffaf2 !important;
  color:#211915 !important;
  border:1px solid rgba(33,25,21,.18) !important;
  border-radius:999px !important;
  box-shadow:0 10px 30px rgba(0,0,0,.18) !important;
  line-height:1 !important;
  font-size:2.35rem !important;
  font-weight:400 !important;
  -webkit-appearance:none !important;
  appearance:none !important;
}
.photo-tour.is-open .photo-tour-scroll{
  position:absolute !important;
  inset:0 !important;
  height:100dvh !important;
  max-height:100dvh !important;
  overflow-y:auto !important;
  padding-top:calc(104px + env(safe-area-inset-top)) !important;
  -webkit-overflow-scrolling:touch !important;
}
@supports not (height:100dvh){
  .photo-tour.is-open .photo-tour-scroll{height:100vh !important;max-height:100vh !important;}
}
@media (max-width:640px){
  .brand-mark{
    width:62px !important;
    height:28px !important;
    min-width:62px !important;
  }
  .brand span:last-child{
    font-size:.93rem !important;
  }
  .photo-tour.is-open .photo-tour-top{
    height:calc(70px + env(safe-area-inset-top)) !important;
  }
  .photo-tour.is-open .photo-tour-close{
    top:calc(12px + env(safe-area-inset-top)) !important;
    left:12px !important;
    width:44px !important;
    height:44px !important;
    min-width:44px !important;
    min-height:44px !important;
    font-size:2.25rem !important;
  }
  .photo-tour.is-open .photo-tour-scroll{
    padding-top:calc(92px + env(safe-area-inset-top)) !important;
  }
}
