/* ── CA LA FUSTERETA – Global Styles ── */
:root{
  --w:#fdfaf7;--cr:#f7f0e8;--pt:#f0e6d8;--bi:#e8d9c5;
  --la:#d4b896;--mo:#b8916a;--wa:#8c6340;--es:#5a3e28;--ink:#3a2416;
  --rf:999px;--rxl:28px;--rlg:18px;--rmd:12px;--rsm:8px;
  --ss:0 4px 24px rgba(90,62,40,.08);
  --sc:0 8px 40px rgba(90,62,40,.11);
  --sf:0 20px 60px rgba(90,62,40,.15);
  --max:1080px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cr);color:var(--ink);overflow-x:hidden}
img{max-width:100%;display:block}

/* NAV */
nav{position:fixed;top:.85rem;left:50%;transform:translateX(-50%);z-index:300;
  display:flex;align-items:center;gap:1.4rem;
  background:rgba(253,250,247,.93);backdrop-filter:blur(18px);
  border:1px solid rgba(212,184,150,.3);border-radius:var(--rf);
  padding:.55rem .9rem .55rem 1.2rem;
  box-shadow:0 4px 24px rgba(90,62,40,.09);white-space:nowrap;
  transition:box-shadow .3s;max-width:calc(100vw - 1rem)}
.nav-logo img{height:38px;width:auto}
.nav-links{display:flex;gap:.06rem;list-style:none;align-items:center}
.nav-links a{font-size:.71rem;font-weight:500;color:var(--es);text-decoration:none;
  padding:.36rem .75rem;border-radius:var(--rf);transition:background .2s}
.nav-links a:hover{background:var(--pt)}
.nav-cta{background:var(--mo)!important;color:var(--w)!important;
  padding:.46rem 1.1rem!important;border-radius:var(--rf)!important;
  box-shadow:0 3px 12px rgba(184,145,106,.28)!important}
.nav-cta:hover{background:var(--wa)!important}
.ham{display:none;flex-direction:column;gap:4px;background:none;border:none;
  cursor:pointer;padding:.4rem}
.ham span{display:block;width:20px;height:2px;background:var(--es);border-radius:2px}
.mob-menu{display:none;position:fixed;inset:0;z-index:290;
  background:rgba(253,250,247,.97);flex-direction:column;
  align-items:center;justify-content:center;gap:1.8rem}
.mob-menu.open{display:flex}
.mob-menu a{font-size:1.2rem;font-family:'Playfair Display',serif;font-style:italic;
  color:var(--es);text-decoration:none}
.mob-close{position:absolute;top:1.4rem;right:1.4rem;background:var(--pt);border:none;
  width:34px;height:34px;border-radius:50%;font-size:1rem;cursor:pointer;color:var(--wa)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.34rem;font-family:'DM Sans',sans-serif;
  font-size:.77rem;font-weight:500;letter-spacing:.03em;text-decoration:none;cursor:pointer;
  border:none;padding:.74rem 1.5rem;border-radius:var(--rf);transition:all .22s;white-space:nowrap}
.btn-p{background:var(--mo);color:var(--w);box-shadow:0 4px 16px rgba(184,145,106,.3)}
.btn-p:hover{background:var(--wa);transform:translateY(-2px)}
.btn-g{background:rgba(253,250,247,.16);backdrop-filter:blur(8px);
  color:var(--w);border:1.5px solid rgba(253,250,247,.38)}
.btn-g:hover{background:rgba(253,250,247,.27)}
.btn-o{background:transparent;color:var(--wa);border:1.5px solid var(--la)}
.btn-o:hover{background:var(--pt);border-color:var(--mo)}
.btn-w2{background:var(--w);color:var(--mo)}
.btn-w2:hover{background:var(--cr);transform:translateY(-2px)}
.btn-gw{background:transparent;color:var(--w);border:1.5px solid rgba(253,250,247,.4)}
.btn-gw:hover{border-color:var(--w);background:rgba(253,250,247,.1)}
.btn-sm{padding:.46rem 1rem;font-size:.69rem}
.btn-full{width:100%;justify-content:center}

/* SECTIONS */
.sec{padding:5rem 1.5rem}
.inn{max-width:var(--max);margin:0 auto}
.ctr{text-align:center}
.ey{display:inline-block;font-size:.65rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mo);margin-bottom:.55rem}
h2.ti{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3.2vw,2.6rem);
  font-weight:400;line-height:1.15;color:var(--es);margin-bottom:.75rem}
h2.ti em{font-style:italic;color:var(--mo)}
.sub{font-size:.89rem;font-weight:300;color:var(--wa);line-height:1.78;max-width:500px;margin:0 auto}

/* FOOTER */
footer{background:var(--es);padding:2.8rem 1.5rem 1.5rem}
.fg{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr;
  gap:2.4rem;padding-bottom:1.8rem;border-bottom:1px solid rgba(212,184,150,.1)}
.fb img{height:46px;width:auto;margin-bottom:.5rem}
.ft{font-size:.73rem;font-weight:300;color:rgba(212,184,150,.45);line-height:1.7}
.fcol h4{font-size:.63rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;
  color:var(--la);margin-bottom:.8rem}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:.36rem}
.fcol a{font-size:.75rem;font-weight:300;color:rgba(212,184,150,.5);
  text-decoration:none;transition:color .2s}
.fcol a:hover{color:var(--la)}
.fbot{max-width:var(--max);margin:1.2rem auto 0;display:flex;justify-content:space-between;
  font-size:.65rem;color:rgba(212,184,150,.26);flex-wrap:wrap;gap:.35rem}

/* MODAL */
.mov{position:fixed;inset:0;z-index:500;background:rgba(44,26,14,.5);
  backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;
  padding:1rem;opacity:0;pointer-events:none;transition:opacity .28s}
.mov.open{opacity:1;pointer-events:all}
.modal{background:var(--w);border-radius:var(--rxl);
  max-width:480px;width:100%;box-shadow:var(--sf);
  transform:translateY(16px);transition:transform .28s;
  max-height:90svh;overflow-y:auto;padding:2rem}
.mov.open .modal{transform:translateY(0)}
.mhd{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.2rem}
.mtt{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--es)}
.mcl{background:var(--pt);border:none;width:27px;height:27px;border-radius:50%;
  cursor:pointer;font-size:.8rem;color:var(--wa);
  display:flex;align-items:center;justify-content:center;transition:background .18s}
.mcl:hover{background:var(--bi)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:.7rem}
.fgrp{display:flex;flex-direction:column;gap:.3rem}
.fgrp.full{grid-column:1/-1}
label{font-size:.66rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--wa)}
input,select,textarea{font-family:'DM Sans',sans-serif;font-size:.82rem;color:var(--es);
  background:var(--cr);border:1px solid var(--bi);border-radius:var(--rmd);
  padding:.62rem .86rem;outline:none;width:100%;
  transition:border-color .18s,box-shadow .18s}
input:focus,select:focus,textarea:focus{border-color:var(--mo);box-shadow:0 0 0 3px rgba(184,145,106,.12)}
textarea{resize:vertical;min-height:60px}
.psum{background:var(--pt);border:1px solid var(--bi);border-radius:var(--rlg);
  padding:.9rem 1.2rem;margin:.7rem 0;font-size:.79rem;color:var(--wa)}
.prow{display:flex;justify-content:space-between;margin-bottom:.27rem}
.ptot{font-weight:500;color:var(--es);border-top:1px solid var(--bi);
  padding-top:.36rem;margin-top:.36rem;font-size:.9rem}
.payrow{display:flex;align-items:center;gap:.36rem;justify-content:center;
  margin-bottom:.88rem;font-size:.66rem;color:var(--wa)}
.pbdg{background:var(--pt);border:1px solid var(--bi);border-radius:var(--rsm);
  padding:.15rem .46rem;font-size:.63rem;font-weight:500;color:var(--wa)}
.succ{text-align:center;padding:.9rem 0}
.succ-i{font-size:2.4rem;margin-bottom:.72rem}
.succ-t{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--es);margin-bottom:.36rem}
.succ-d{font-size:.79rem;color:var(--wa);line-height:1.7}

/* CALENDAR (shared) */
.cal-wrap{background:var(--cr);border:1px solid var(--bi);border-radius:var(--rxl);padding:2rem}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.cal-ml{font-family:'Playfair Display',serif;font-size:1rem;color:var(--es)}
.cnav{background:var(--pt);border:1px solid var(--bi);width:28px;height:28px;
  border-radius:50%;cursor:pointer;color:var(--wa);font-size:.78rem;
  display:flex;align-items:center;justify-content:center;
  transition:background .18s;font-family:inherit}
.cnav:hover{background:var(--bi)}
.cgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.cdh{font-size:.58rem;font-weight:500;color:var(--la);padding:.22rem 0}
.cd{aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:.7rem;border-radius:6px;cursor:pointer;color:var(--wa);transition:all .14s}
.cd:hover:not(.bk):not(.emp):not(.past){background:var(--mo);color:var(--w)}
.cd.av{background:rgba(140,99,64,.08);color:var(--es)}
.cd.bk{background:rgba(184,145,106,.15);color:var(--la);text-decoration:line-through;cursor:not-allowed}
.cd.td{outline:1.5px solid var(--mo);font-weight:600;color:var(--es)}
.cd.emp,.cd.past{pointer-events:none;opacity:.2}
.cd.s1,.cd.s2{background:var(--mo);color:var(--w);font-weight:600}
.cd.rng{background:rgba(184,145,106,.18);color:var(--es)}
.cal-leg{display:flex;gap:1rem;justify-content:center;margin-top:.9rem;
  font-size:.63rem;color:var(--wa);flex-wrap:wrap}
.ld{width:8px;height:8px;border-radius:2px;display:inline-block;margin-right:4px;vertical-align:middle}
.ld-av{background:rgba(140,99,64,.22)}.ld-bk{background:rgba(184,145,106,.45)}.ld-sel{background:var(--mo)}
.cal-foot{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--bi);
  display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap}
.cal-info{font-size:.76rem;color:var(--wa);font-weight:300;flex:1}
.cal-info strong{color:var(--es);font-weight:500}

/* RESPONSIVE */
@media(max-width:768px){
  nav{top:.4rem;padding:.42rem .68rem;gap:.6rem}
  .nav-links{display:none}
  .ham{display:flex}
  .nav-logo img{height:32px}
  .sec{padding:3.4rem 1.1rem}
  .fg{grid-template-columns:1fr;gap:1.5rem}
  .fbot{flex-direction:column;text-align:center}
  .frow{grid-template-columns:1fr}
}
@keyframes fu{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

@keyframes toastIn {
  from { opacity:0; transform:translateX(-50%) translateY(10px); }
  to   { opacity:1; transform:translateX(-50%) translateY(0); }
}
