/* Reset + tokens */
:root{
  --bg:#ffffff;--text:#222;--muted:#6a6a6a;--border:#e5e5e5;--chip:#f7f7f7;--brand:#ab814c;
  --radius-8:8px;--radius-12:12px;--shadow:0 6px 20px rgba(0,0,0,.08);
  /* Glass + brand gradient */
  --glass-bg: rgba(255,255,255,.10);
  --glass-stroke: rgba(255,255,255,.22);
  --glass-shadow: 0 10px 30px rgba(0,0,0,.25);
  --brand-g1:#ab814c;          /* Driftwood base */
  --brand-g2:#c7925a;          /* lighter tip */
  --brand-press:#8e6b40;       /* pressed */
  --focus:#1a73e8;             /* focus outline */
  --focus-offset:2px;
}
:root{
  /* Typography & motion tokens (vanguarda minimalista) */
  --fs-sm: clamp(12px, 0.25vw + 11px, 13px);
  --fs-base: clamp(14px, 0.30vw + 12px, 16px);
  --fs-md: clamp(16px, 0.50vw + 14px, 18px);
  --fs-lg: clamp(20px, 1.00vw + 16px, 28px);
  --fs-xl: clamp(28px, 1.40vw + 22px, 40px);

  --ease-out: cubic-bezier(.2,.8,.2,1);
  --ease-inout: cubic-bezier(.4,0,.2,1);
  --dur-1: 120ms;
  --dur-2: 180ms;
  --dur-3: 240ms;

  /* Calendar selection palette (brand browns) */
  --sel-dark: #8e6b40;           /* endpoints */
  --sel-light: rgba(171,129,76,.18);  /* confirmed range */
  --sel-preview: rgba(171,129,76,.28);/* hover preview */
}
*{box-sizing:border-box}
body{margin:0;font-family:"Manrope",-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:var(--fs-base);line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-kerning:normal;font-feature-settings:"liga","kern"}
img{max-width:100%;display:block}
.container{max-width:1280px;margin-inline:auto;padding-inline:16px}
.desktop-only{display:none}
@media(min-width:744px){.desktop-only{display:block}}

/* Header container padding tweak for mobile */
@media(max-width:744px){
  .container.header-inner{padding-inline:20px}
}

/* Reserve space on mobile for sticky bar */
@media(max-width:979px){body{padding-bottom:calc(110px + env(safe-area-inset-bottom,0px))}}

/* Header container padding remains 16px on mobile to avoid overflow */
@media(max-width:744px){
  .container.header-inner{padding-inline:16px}
}
/* Header */
.site-header{position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;color:var(--brand);text-decoration:none}
.brand img{height:32px;width:auto;display:block;border-radius:8px}
.brand .brand-text{font-size:22px;font-weight:700;letter-spacing:-.01em}
.nav-link{color:var(--text);text-decoration:none;font-weight:500}
.nav-link{position:relative;display:inline-block}
.nav-link::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform var(--dur-2) var(--ease-out);opacity:.7}
.nav-link:hover::after,.nav-link:focus-visible::after{transform:scaleX(1)}
/* Remove sublinhado globalmente */
a{color:inherit;text-decoration:none}
a:hover,a:focus{text-decoration:none}
html{scroll-behavior:smooth}
h1{font-family:"Fraunces",serif;font-size:var(--fs-xl);letter-spacing:-.01em;line-height:1.1;margin:0 0 .2em;text-wrap:balance;font-optical-sizing:auto}
h2{font-family:"Fraunces",serif;font-size:var(--fs-lg);letter-spacing:-.01em;line-height:1.2;margin:1.2em 0 .5em;text-wrap:balance;font-optical-sizing:auto}
h3{font-family:"Fraunces",serif;font-size:var(--fs-md);letter-spacing:-.005em;line-height:1.3;margin:1em 0 .4em;text-wrap:balance;font-optical-sizing:auto}
small,.muted{font-size:var(--fs-sm);color:var(--muted)}
::selection{background:rgba(171,129,76,.18);color:#111}
::-moz-selection{background:rgba(171,129,76,.18);color:#111}
/* mobile-first: menu some on mobile */
.main-nav{gap:18px;align-items:center}
@media(min-width:744px){.main-nav{display:flex}}
.btn.small{padding:8px 12px;font-size:13px}
.ambient-title{font-weight:600;color:#333}

/* Buttons */
:where(a, button, input, select, textarea, .btn, .nav-link, .ambient-knob, .date-close, .nav-btn, .day):focus-visible{outline:3px solid var(--focus);outline-offset:var(--focus-offset)}
:where(.btn):focus-visible{box-shadow:0 0 0 3px rgba(26,115,232,.25),0 6px 16px rgba(171,129,76,.35)}
:where(:focus-visible){scroll-margin-block:140px}
.btn{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:999px;cursor:pointer;font-weight:600;transition:transform var(--dur-1) var(--ease-out),filter var(--dur-2) var(--ease-out),box-shadow var(--dur-2) var(--ease-out)}
.btn.primary{color:#111;padding:12px 16px;background:linear-gradient(135deg,var(--brand-g1),var(--brand-g2));box-shadow:0 6px 16px rgba(171,129,76,.35)}
.btn.primary:hover{filter:brightness(1.03);transform:translateY(-1px)}
.btn.primary:active{transform:translateY(1px);filter:brightness(.96);background:linear-gradient(135deg,var(--brand-press),var(--brand-g1))}
.btn.outline{background:#fff;border:1px solid var(--border);color:#222;padding:10px 14px;border-radius:12px;justify-content:center}
.btn.outline:hover{background:#fafafa;border-color:#ddd;transform:translateY(-1px)}
.btn.large{padding:14px 18px;font-size:15px;width:100%;justify-content:center}

/* Landing hero */
.hero-landing{position:relative}
@media(min-width:900px){.hero-landing{min-height:60vh}}
.hero-landing .cover{width:100%;height:48vh;object-fit:cover;border-radius:0}
@media(min-width:900px){.hero-landing .cover{height:60vh}}
.hero-landing .overlay{position:absolute;inset:auto 0 24px 0;color:#fff}
.hero-landing .pill{display:inline-block;background:rgba(0,0,0,.5);padding:6px 10px;border-radius:999px;margin-bottom:10px}
.hero-landing .title{font-family:"Fraunces",serif;font-size:clamp(28px,2.5vw + 16px,40px);margin:0 0 6px;letter-spacing:-.01em;text-shadow:0 1px 6px rgba(0,0,0,.22)}
.hero-landing .subtitle{margin:0;text-shadow:0 2px 10px rgba(0,0,0,.35)}
@media(max-width:899px){.hero-landing .overlay{display:none}}
/* Floating photos CTA */
.hero-landing .photos-cta{position:absolute;right:16px;bottom:16px;border-radius:12px;padding:10px 14px;background:#fff;border:1px solid var(--border);color:#222;text-decoration:none;display:none}
.hero-landing .photos-cta:hover{background:#f8f8f8}
/* Floating ambient play button */
.ambient-fab{position:absolute;left:16px;bottom:16px;width:48px;height:48px;border:0;border-radius:999px;display:grid;place-items:center;cursor:pointer;background:linear-gradient(135deg,var(--brand-g1),var(--brand-g2));box-shadow:0 10px 20px rgba(171,129,76,.35)}
.ambient-fab:hover{filter:brightness(1.03)}
.ambient-fab:active{transform:translateY(1px);filter:brightness(.96)}

/* Header small ambient icon button */
.ambient-icon{display:inline-grid;place-items:center;padding:8px 10px;border-radius:999px}
/* Mobile ambient button shows note + knob side by side */
@media(max-width:744px){
  #ambientBtnMobile.ambient-icon{display:flex;align-items:center;gap:6px;padding:8px 10px}
  .mnote{display:inline-grid;width:22px;height:22px}
  .mnote svg{width:100%;height:100%}
  .mnote .dance{animation:dance 1.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
}

@keyframes dance{
  0%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-2px) rotate(-8deg)}
  100%{transform:translateY(0) rotate(0)}
}
@media (prefers-reduced-motion: reduce){
  *,*:before,*:after{animation:none !important;transition:none !important}
  .dance{animation:none !important}
}

/* Minimal reveal (Awwwards-style) */
.reveal{opacity:0;transform:translateY(10px);transition:opacity var(--dur-3) var(--ease-out),transform var(--dur-3) var(--ease-out)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1 !important;transform:none !important}
}

/* Mobile visibility helpers */
.mobile-only{display:none}
@media(max-width:744px){.mobile-only{display:inline-grid}}

/* Ambient control pill (desktop) */
.ambient-ctrl{display:flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;background:rgba(171,129,76,.10);border:1px solid rgba(171,129,76,.28);box-shadow:0 8px 22px rgba(171,129,76,.18)}
.ambient-ctrl .lbl{font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#1f1f1f;font-size:13px}
.ambient-ctrl .note{display:flex;align-items:center;margin-left:2px}
.ambient-ctrl .note svg{display:block}
.ambient-ctrl .note .dance{animation:dance 1.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
.ambient-knob{display:inline-grid;place-items:center;width:34px;height:34px;border:0;border-radius:999px;cursor:pointer;background:linear-gradient(135deg,var(--brand-g1),var(--brand-g2));box-shadow:0 6px 16px rgba(171,129,76,.4)}
.ambient-knob svg{display:block}
.ambient-knob:hover{filter:brightness(1.03)}
.ambient-knob:active{transform:translateY(1px);filter:brightness(.96)}
@media(max-width:899px){.hero-landing .photos-cta{display:none}}

/* Intro card under hero (mobile) */
.intro-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow);margin-top:16px;position:relative;z-index:2}
.intro-card .title{font-family:"Fraunces",serif;margin:4px 0 6px;font-size:22px}
.intro-card .subtitle{color:#444;margin:0 0 6px}
@media(min-width:900px){.intro-card{display:block;margin-top:24px}}

/* Gallery mosaic - mobile first */
.gallery{display:grid;gap:8px;margin-top:16px;grid-template-columns:1fr 1fr;grid-auto-rows:auto}
.gallery .g1{grid-column:1/-1;grid-row:span 2}
.gallery img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:12px;transition:transform var(--dur-2) var(--ease-out)}
.gallery img:hover{transform:scale(1.01)}
@media(min-width:900px){
  .gallery{grid-template-columns:2fr 1fr 1fr;grid-template-rows:220px 220px}
  .gallery .g1{grid-row:1/3;grid-column:auto}
}
/* Mobile "todas as fotos" button */
.gallery-cta-mobile{margin-top:8px;width:auto;grid-column:1/-1;display:inline-block;justify-self:center}
.gallery .btn.small.gallery-cta-mobile{padding:8px 12px;font-size:13px;border-radius:10px}
@media(min-width:900px){.gallery .btn.gallery-cta-mobile{display:inline-block}}
@media(min-width:900px){.gallery-cta-mobile{display:inline-block}}

/* 2-column layout */
.layout{display:grid;gap:24px;margin-top:20px}
@media(min-width:980px){.layout{grid-template-columns:1.4fr .8fr}}
.main h2{margin:16px 0 8px;font-family:"Fraunces",serif;font-size:var(--fs-lg);letter-spacing:-.01em;line-height:1.2}
.quick-specs{display:flex;gap:12px;flex-wrap:wrap;color:#444;margin:6px 0 10px}
.highlights{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding-left:0;list-style:none}
@media(max-width:599px){.highlights{grid-template-columns:1fr}}

/* Amenities reused */
.amenities-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
@media(min-width:744px){.amenities-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.amenity{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:12px;background:#fff;padding:10px 12px}
.amenity .ico{font-size:18px}
.amenity{transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2) var(--ease-out)}
.amenity:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

/* Reviews */
.reviews{display:grid;gap:12px}
.review{border:1px solid var(--border);border-radius:12px;background:#fff;padding:12px}
.review strong{margin-right:6px}
.map{display:none}
.rules{padding-left:16px}

/* Booking card */
.book-card{position:relative;top:auto;align-self:start;border:1px solid var(--border);border-radius:16px;padding:16px;background:#fff;box-shadow:var(--shadow)}
@media(min-width:980px){.book-card{position:sticky;top:88px}}
.book-card .price{font-size:22px;display:flex;align-items:baseline;gap:6px;font-family:"Fraunces",serif}
.book-card .rating-row{color:#444;margin:4px 0 10px}
.book-form{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.book-form label{display:flex;flex-direction:column;gap:6px}
.book-form input,.book-form select{height:40px;border:1px solid var(--border);border-radius:10px;padding:0 10px;font:inherit}
.book-form .full{grid-column:1/3}
.book-card .total{margin-top:10px;color:#111;font-weight:700;font-size:18px}
.book-card.has-total .total{font-size:18px}
.book-card .hint{margin:6px 0 8px;color:var(--muted)}
.contact-mini{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}

/* Footer */
.site-footer{border-top:1px solid var(--border);padding:16px 0;margin-top:16px;background:#fff}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:12px}
.foot-links{display:flex;gap:12px}
.foot-links a{color:var(--muted);text-decoration:none}

/* Sticky bottom bar */
.sticky-bar{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--border);padding:10px 0;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));z-index:9999;box-shadow:0 -6px 20px rgba(0,0,0,.06);display:block;transition:transform var(--dur-2) var(--ease-out),opacity var(--dur-2) var(--ease-out)}
.sticky-bar.hidden{transform:translateY(100%);opacity:0;pointer-events:none}
.sticky-bar.show{transform:translateY(0);opacity:1;pointer-events:auto}
.sticky-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.sticky-left{display:flex;flex-direction:column;gap:2px}
.sticky-price{font-size:16px}
.sticky-price strong{font-size:18px}
.sticky-sub{font-size:12px;color:#444}
@media(min-width:980px){.sticky-bar{display:none}}
.sticky-inner .btn{min-width:140px;height:44px}

/* Dates-first card */
.sr-only{position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}
.dates-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow);margin-top:12px}
.dates-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dates-grid label{display:flex;flex-direction:column;gap:6px}
.dates-grid input,.dates-grid select{height:44px;border:1px solid var(--border);border-radius:12px;padding:0 12px;font:inherit}
.dates-grid input[readonly]{cursor:pointer}
.dates-grid .full{grid-column:1/-1}
.dates-grid .btn.full{grid-column:1/-1;width:100%}
.dates-quick{display:flex;gap:8px;flex-wrap:wrap}
.chip{appearance:none;background:var(--chip);border:1px solid var(--border);color:#222;border-radius:999px;padding:8px 12px;cursor:pointer}
/* Desktop: manter a largura do container da galeria (1280px máx + 16px padding) */
@media(min-width:980px){.dates-card{max-width:1280px;margin-inline:auto}}
@media(max-width:480px){.dates-grid{grid-template-columns:1fr}}

/* Date-range modal */
.date-modal{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;align-items:center;justify-content:center;z-index:10000;padding:16px}
.date-dialog{background:#fff;border-radius:16px;box-shadow:var(--shadow);width:100%;max-width:720px;overflow:hidden}
.date-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.date-title{font-size:18px;font-weight:700}
.date-sub{font-size:12px;color:#444;min-height:1.2em}
.date-close{appearance:none;border:0;background:#fff;border:1px solid var(--border);width:32px;height:32px;border-radius:999px;cursor:pointer}
.date-nav{display:flex;align-items:center;gap:8px;padding:10px 16px}
.month-label{font-weight:700;text-align:center;flex:1}
.date-nav .nav-btn{flex:0 0 auto}
.nav-btn{appearance:none;border:0;background:#fff;border:1px solid var(--border);border-radius:12px;cursor:pointer;width:36px;height:36px}
.date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:0 16px 16px}
.date-grid .dow{font-size:14px;color:#666;text-align:center;padding:6px 0;font-weight:700;font-family:"Montserrat","Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
/* Day cell look: minimal, no default button border */
.day{height:36px;display:grid;place-items:center;border-radius:10px;cursor:pointer;border:0;background:transparent;color:var(--text);touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-family:"Montserrat","Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-weight:700;font-size:14px}
.day:hover:not(.disabled):not(.start):not(.end):not(.in-range):not(.selected){background:#f7f7f7}
/* Preserve contrast on selected endpoints and range */
.day.start:hover,.day.end:hover{background:var(--sel-dark)}
.day.in-range:hover{background:var(--sel-light)}
.day.disabled{color:#c6c6c6;cursor:default;background:transparent;pointer-events:none}
/* Range styles */
.day.in-range{background:var(--sel-light)}
.day.start,.day.end{background:var(--sel-dark);color:#fff}
.day.preview-in-range{background:var(--sel-preview)}
.day.preview-end{outline:2px solid var(--sel-dark);outline-offset:-2px}
.day.selected{outline:2px solid var(--sel-dark);outline-offset:-2px}
.date-actions{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding:10px 16px}
.date-actions .link{appearance:none;border:0;background:transparent;color:#222;text-decoration:none;cursor:pointer}

/* Inline calendar (always visible) */
.date-inline{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);margin-top:12px}
.date-inline .date-head{border-bottom:1px solid var(--border)}
.price-inline{font-family:"Fraunces",serif;font-weight:700;font-size:22px;color:#111}
.date-cal-wrap{display:grid;gap:8px;padding:12px 16px}
@media(min-width:900px){.date-cal-wrap{grid-template-columns:repeat(2,minmax(0,1fr))}}
.date-inline .cal .date-nav{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.date-actions.inline{border-top:1px solid var(--border);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;padding:10px 16px}
.date-actions.inline .cta-center{display:flex;justify-content:center}
.date-actions.inline .inline-hint{justify-self:end;font-size:18px;color:#222;font-weight:600}
/* Bigger CTA size (desktop), matching reference hierarchy */
.date-actions.inline .cta-center .btn{min-width:240px;height:48px;font-size:16px;padding:12px 20px}

/* Mobile: mostrar apenas 1 mês no calendário inline */
@media(max-width:744px){
  #ambientBtnMobile.ambient-icon{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;min-width:68px}
  .date-inline .cal:last-child{display:none}
  /* Inline actions: stack like the reference layout */
  .date-actions.inline{grid-template-columns:1fr;gap:10px}
  .date-actions.inline .cta-center .btn{width:100%}
  .date-actions.inline .inline-hint{justify-self:center;margin-top:2px;text-align:center}
  #topBtn, #cta, #stickyBtn{justify-content:center;text-align:center}
  .book-card .total{text-align:center}
}
  .knob-icon svg{display:block}

/* Glass utility (frosted) */
.glass{background:var(--glass-bg);border:1px solid var(--glass-stroke);backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);box-shadow:var(--glass-shadow)}
.glass.round{border-radius:24px}

/* ---- Calendar tooltips (generic) ---- */
.day[data-tip]{position:relative}
.day.soft-disabled{color:#c6c6c6} /* visual cinza, mas mantém pointer events */
.day[data-tip]:hover::after,
.day[data-tip]:focus-visible::after{
  content:attr(data-tip);
  position:absolute;
  bottom:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  background:#111;
  color:#fff;
  padding:6px 8px;
  border-radius:8px;
  font-size:12px;
  white-space:nowrap;
  box-shadow:0 6px 16px rgba(0,0,0,.18);
  z-index:10;
}
.day[data-tip]:hover::before,
.day[data-tip]:focus-visible::before{
  content:"";
  position:absolute;
  bottom:100%;
  left:50%;
  transform:translateX(-50%);
  border:6px solid transparent;
  border-top-color:#111;
}

/* Disable hover tooltips on touch devices */
@media (hover: none) and (pointer: coarse){
  .day[data-tip]::after,
  .day[data-tip]::before{display:none !important}
}
