
:root{--ink:#20201d;--muted:#69645d;--paper:#fbf7ef;--card:#fffdf8;--olive:#47583a;--olive2:#263322;--clay:#b86f45;--wheat:#e9d5ae;--line:#e6dccb;--ok:#2f6b3f}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--paper);color:var(--ink);line-height:1.62}a{color:inherit}.wrap{width:min(1120px,calc(100% - 36px));margin:auto}.topbar{position:sticky;top:0;z-index:20;background:rgba(251,247,239,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}.brand{font-weight:850;letter-spacing:.02em}.brand span{display:block;font-size:.75rem;font-weight:650;color:var(--muted);letter-spacing:.09em;text-transform:uppercase}.links{display:flex;gap:18px;align-items:center;font-size:.95rem}.links a{text-decoration:none;color:#3a372f}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:999px;padding:12px 18px;background:var(--clay);color:white;text-decoration:none;font-weight:800;box-shadow:0 10px 26px rgba(184,111,69,.24)}.btn.alt{background:var(--clay)}.btn.ghost{background:transparent;color:var(--olive2);box-shadow:none;border:1px solid var(--line)}.hero{padding:74px 0 54px;background:radial-gradient(circle at 78% 20%,rgba(184,111,69,.22),transparent 34%),linear-gradient(135deg,#f9efd9 0%,#fbf7ef 48%,#e9eddc 100%)}.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center}.eyebrow{display:inline-flex;gap:8px;align-items:center;border:1px solid var(--line);background:rgba(255,253,248,.7);padding:7px 11px;border-radius:999px;color:#514d45;font-weight:700;font-size:.88rem}.hero h1{font-size:clamp(2.45rem,5vw,5.25rem);line-height:.98;margin:18px 0 18px;letter-spacing:-.06em}.lead{font-size:clamp(1.07rem,2vw,1.28rem);color:#504c44;max-width:62ch}.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:32px}.fact{background:rgba(255,253,248,.78);border:1px solid var(--line);border-radius:18px;padding:16px}.fact b{display:block;font-size:1.3rem}.fact span{color:var(--muted);font-size:.9rem}.photo-card{position:relative;min-height:520px;border-radius:34px;overflow:hidden;box-shadow:0 30px 70px rgba(39,34,25,.18);background:#ddd}.photo-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}.photo-note{position:absolute;left:18px;right:18px;bottom:18px;background:rgba(255,253,248,.9);padding:16px;border-radius:22px;border:1px solid rgba(255,255,255,.7)}section{padding:70px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:22px;margin-bottom:26px}.section-head h2{font-size:clamp(2rem,3.5vw,3.6rem);line-height:1.02;margin:0;letter-spacing:-.045em}.section-head p{color:var(--muted);max-width:48ch;margin:0}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.card{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 14px 34px rgba(52,45,34,.06)}.card h3{margin:0 0 10px;font-size:1.18rem}.card p,.card li{color:var(--muted)}.badge{display:inline-block;padding:5px 10px;border-radius:999px;background:#eef1e6;color:var(--olive2);font-weight:800;font-size:.78rem;margin-bottom:10px}.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:start}.panel{background:var(--olive2);color:white;border-radius:30px;padding:30px}.panel p{color:#e7eadf}.checklist{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:14px}.check{background:#fffdf8;border:1px solid var(--line);border-radius:18px;padding:14px}.check b{display:block}.check span{color:var(--muted);font-size:.94rem}.gallery{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:12px}.gallery img{width:100%;height:240px;object-fit:cover;border-radius:22px;border:1px solid var(--line)}.gallery img:first-child{height:492px;grid-row:span 2}.notice{background:#fff8df;border:1px solid #edd592;color:#58451d;padding:16px;border-radius:18px}.faq{display:grid;grid-template-columns:1fr 1fr;gap:14px}.faq details{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:18px}.faq summary{cursor:pointer;font-weight:800}.footer{padding:36px 0;background:#1f241d;color:#e9eadf}.footer-grid{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}.muted{color:var(--muted)}.form{display:grid;gap:12px}.form input,.form textarea,.form select{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:14px;background:white;font:inherit}.form label{font-weight:750}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.status{padding:14px 16px;border-radius:16px;background:#eef1e6;border:1px solid #d8dec8}.danger{background:#fff1ec;border-color:#f0c2b4}@media(max-width:860px){.hero-grid,.split,.faq{grid-template-columns:1fr}.links{display:none}.facts,.cards,.checklist{grid-template-columns:1fr 1fr}.photo-card{min-height:380px}.gallery{grid-template-columns:1fr}.gallery img,.gallery img:first-child{height:260px;grid-row:auto}.section-head{display:block}}@media(max-width:560px){.facts,.cards,.checklist,.grid2{grid-template-columns:1fr}.hero{padding-top:44px}.cta-row .btn{width:100%}}
.booking-page{padding:0;background:#f5efe4;min-height:calc(100vh - 72px)}.booking-layout{display:grid;grid-template-columns:220px minmax(420px,1fr) 300px;gap:18px;width:min(1280px,calc(100% - 24px));margin:auto;padding:18px 0 28px}.booking-side,.booking-form-card{position:sticky;top:86px;align-self:start}.side-card,.booking-form-card{background:#fffdf8;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 12px 32px rgba(52,45,34,.08)}.side-card h2,.booking-form-card h2{font-size:1.1rem;margin:0 0 14px;border-bottom:2px solid #40513a;padding-bottom:8px}.stay-option{display:flex;gap:10px;align-items:flex-start;background:#e7f1df;border:1px solid #7f9b6e;border-radius:4px;padding:14px;margin-bottom:12px}.stay-option input{margin-top:4px}.stay-option b{display:block;text-transform:uppercase;font-size:.9rem}.stay-option small{display:block;color:#52604a;font-size:.78rem}.selection-box{background:#e8f2ff;border-left:4px solid #7da2c4;padding:12px;border-radius:8px;font-size:.9rem}.selection-box span{display:block;color:#456;margin-top:6px}.calendar-panel{background:#fffdf8;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 12px 32px rgba(52,45,34,.08)}.calendar-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.calendar-head h1{text-transform:capitalize;font-size:1.55rem;margin:0}.calendar-head button{border:0;background:var(--clay);color:white;border-radius:999px;width:42px;height:42px;font-size:2rem;line-height:1;cursor:pointer}.weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.weekdays span{text-align:center;color:#8a7e6d;font-weight:800;font-size:.86rem;padding:8px 0}.day{min-height:88px;border:0;border-radius:2px;font:inherit;font-weight:800;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;background:#eee7dc;color:#9b9286}.day-available{background:#536845;color:white}.day-occupied{background:#c9282d;color:white;cursor:not-allowed}.day-occupied b{position:absolute;font-size:4rem;font-weight:200;line-height:1;opacity:.82}.day-occupied span{position:relative;z-index:1}.day-selected{background:#b86f45!important;color:white;outline:4px solid #f0d1bd;z-index:2}.muted-day{background:transparent;cursor:default}.loading{opacity:.55}.legend{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:14px;color:#5d564e;font-size:.9rem}.legend i{display:inline-block;width:14px;height:14px;margin-right:6px;vertical-align:-2px}.legend .available{background:#536845}.legend .occupied{background:#c9282d}.legend .selected{background:#b86f45}.bizum-note{background:#e8f6fb;border:1px solid #8fc3d7;padding:14px;border-radius:4px;margin-bottom:14px;text-align:center}.bizum-note b{display:block;color:#465f6a}.bizum-note span{font-size:.84rem;color:#52636a}.date-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px;background:#f7f1e8;border:1px solid var(--line);padding:10px;border-radius:8px}.date-summary input{background:white}.mini-status{margin:0;color:#8a6b53;font-size:.9rem}.status.ok{background:#e6f4df;border-color:#b9d5aa}@media(max-width:980px){.booking-layout{grid-template-columns:1fr}.booking-side,.booking-form-card{position:static}.day{min-height:58px}.links{display:none}}@media(max-width:560px){.booking-layout{width:min(100% - 16px,1280px)}.calendar-panel,.side-card,.booking-form-card{padding:12px}.day{min-height:46px}.day-occupied b{font-size:2.6rem}.weekdays span{font-size:.75rem}.calendar-head h1{font-size:1.2rem}.date-summary{grid-template-columns:1fr}}

.day-past{background:#d8d1c7!important;color:#8e857a!important;cursor:not-allowed;opacity:.55;text-decoration:line-through}.day:disabled{pointer-events:none}

.btn{transition:transform .12s ease,background .18s ease,box-shadow .18s ease,opacity .18s ease}.btn:active{transform:scale(.97);background:#7f4a2e!important;box-shadow:inset 0 3px 8px rgba(0,0,0,.22)}.btn.sending,.btn:disabled.sending{background:#263322!important;color:#fff!important;cursor:wait;opacity:1;box-shadow:inset 0 0 0 2px rgba(255,255,255,.35),0 8px 20px rgba(38,51,34,.22)}.btn.sent,.btn:disabled.sent{background:#2f6b3f!important;color:#fff!important;cursor:default;opacity:1;box-shadow:0 8px 20px rgba(47,107,63,.22)}

.bizum-alert{background:#e8f6fb!important;border:2px solid #5aa6c8!important;border-radius:0!important}.bizum-alert b{font-size:1rem;color:#385b69}.price-box{background:#fff8e8;border:2px solid #d9a24f;border-radius:8px;padding:14px;margin:0 0 14px;text-align:center}.price-box b{display:block;color:#7d4b25;font-size:1.05rem;margin-bottom:6px}.price-box span{display:block;color:#604f3f;font-size:.9rem;line-height:1.45}.price-box strong{color:#b86f45}

.calendar-disabled{min-height:360px;display:flex!important;align-items:center;justify-content:center;background:#eee7dc;border:1px dashed #cdbfa9;border-radius:4px;padding:18px}.calendar-message{grid-column:1/-1;text-align:center;max-width:420px;color:#5d564e}.calendar-message b{display:block;color:#263322;font-size:1.2rem;margin-bottom:8px}.calendar-message span{display:block}.calendar-head button:disabled{opacity:.45;cursor:not-allowed}


/* Professional pass San Pablo 2026-06-14 */
.hero h1,.section-head h2{letter-spacing:0}
.card,.panel,.check,.faq details,.notice,.side-card,.booking-form-card,.calendar-panel,.photo-note,.fact{border-radius:8px}
.photo-card{border-radius:10px}
.gallery img{border-radius:8px}
.topbar{box-shadow:0 8px 24px rgba(32,32,29,.04)}
.card,.check,.faq details{box-shadow:0 10px 24px rgba(52,45,34,.045)}
.photo-note{background:rgba(255,253,248,.94)}
.btn{border-radius:8px}


/* Mobile overflow guard San Pablo 2026-06-14 */
@media(max-width:560px){
  .wrap{width:min(100% - 24px,1120px)}
  .brand{max-width:220px;line-height:1.15;overflow-wrap:anywhere}
  .brand span{font-size:.68rem;line-height:1.2}
  .hero h1{font-size:2rem;line-height:1.08;margin:14px 0;letter-spacing:0}
  .lead{font-size:1rem;line-height:1.5}
  .eyebrow{border-radius:8px;max-width:100%;white-space:normal}
  .fact b{font-size:1.05rem;overflow-wrap:anywhere}
  .fact span,.check span,.card p{font-size:.9rem}
  .section-head h2{font-size:1.75rem;line-height:1.12;letter-spacing:0}
  .panel{padding:20px}
  .photo-card{min-height:320px}
}

/* Responsive hardening San Pablo 2026-06-14 */
html,body{max-width:100%;overflow-x:hidden}
img,video{max-width:100%}
.hero-grid,.split,.cards,.facts,.checklist,.gallery,.booking-layout,.calendar-panel,.booking-form-card,.booking-side{min-width:0}
.hero-grid>* ,.split>* ,.cards>* ,.facts>* ,.checklist>* ,.gallery>* ,.booking-layout>*{min-width:0}
.btn{max-width:100%;white-space:normal;text-align:center;line-height:1.2}
.lead,p,h1,h2,h3,.brand,.fact,.check,.card,.panel,.photo-note,.status,.price-box,.bizum-note{overflow-wrap:anywhere}
.booking-layout{grid-template-columns:minmax(180px,220px) minmax(0,1fr) minmax(260px,300px)}
.date-summary{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
.form input,.form textarea,.form select{min-width:0}
@media(max-width:1100px){.booking-layout{grid-template-columns:1fr}.booking-side,.booking-form-card{position:static}}
@media(max-width:560px){.nav{min-width:0}.cta-row{width:100%}.cta-row .btn,.panel .btn,.footer .btn{width:100%}.photo-note{left:10px;right:10px;bottom:10px}.booking-layout{width:calc(100% - 16px);padding-left:0;padding-right:0}.legend{gap:8px}.calendar-disabled{min-height:260px}}
/* Mobile polish San Pablo 2026-06-14 */
@media(max-width:560px){
  .wrap{width:calc(100% - 32px)}
  .hero{padding-top:34px;padding-bottom:38px}
  .hero h1{font-size:1.72rem;line-height:1.12;max-width:100%}
  .lead{font-size:.96rem;max-width:100%}
  .btn{padding:11px 13px}
  .facts{gap:10px}
  .fact{padding:13px}
}
/* Mobile narrow safety San Pablo 2026-06-14 */
@media(max-width:560px){
  .wrap{width:calc(100% - 56px)}
  .hero h1{font-size:1.45rem;line-height:1.18}
  .lead{font-size:.92rem;line-height:1.48}
  .hero-grid{gap:24px}
  .btn{padding:10px 11px;font-size:.94rem}
  .fact,.card,.check,.faq details,.panel{padding:12px}
  .booking-layout{width:calc(100% - 40px)}
  .calendar-message,.bizum-note span,.price-box span,.legend span,.status{word-break:break-word;overflow-wrap:anywhere}
  .calendar-message{max-width:260px}
  .legend{display:grid;grid-template-columns:1fr;justify-items:start;margin-left:auto;margin-right:auto;max-width:260px}
}


/* Calendar narrow viewport guard San Pablo 2026-06-15 */
@media(max-width:560px){.calendar-panel{overflow:hidden}.weekdays,.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:2px}.weekdays span{font-size:.68rem;padding:6px 0}.calendar-disabled{padding:12px}}

/* Visual pass San Pablo 2026-06-15 */
@media(min-width:861px){.hero{padding:54px 0 46px}.hero h1{font-size:clamp(2.3rem,4.2vw,4.45rem);line-height:1.04}.photo-card{min-height:470px}.facts{margin-top:24px}.cta-row{margin-top:22px}}
@media(max-width:560px){.booking-layout{width:calc(100% - 8px)}.calendar-panel,.side-card,.booking-form-card{padding:8px}.calendar-disabled{min-height:230px;padding:8px}.weekdays,.calendar-grid{gap:1px}.weekdays span{font-size:.62rem;padding:5px 0}.calendar-head{gap:6px}.calendar-head button{width:36px;height:36px;font-size:1.5rem}.calendar-head h1{font-size:1.08rem}}

/* Disabled calendar mobile simplification San Pablo 2026-06-15 */
@media(max-width:560px){.weekdays{display:none}.calendar-grid.calendar-disabled{display:flex!important;width:100%;max-width:100%;overflow:hidden}.calendar-message{max-width:100%}}

/* Long email wrap San Pablo 2026-06-15 */
.calendar-message,.calendar-message b,.calendar-message span,.bizum-note,.bizum-note b,.bizum-note span{max-width:100%;overflow-wrap:anywhere;word-break:break-word}
@media(max-width:560px){.calendar-message span,.bizum-note span{display:block;max-width:100%;font-size:.82rem;line-height:1.35}}
