/* Sito pubblico + guest portal + area clienti — mobile-first */
:root{
  --bg:#f6f1e6;
  --surface:#fffdf8;
  --surface-2:#f1ead9;
  --line:#e5dcc7;
  --text:#2b3540;
  --muted:#8a8578;
  --brand:#0e8f84;          /* sovrascritto dal tenant */
  --amber:#d98a2b;
  --ok:#3f9d63;
  --danger:#cf4d4d;
  --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:var(--bg);color:var(--text);
  font-family:'Inter',system-ui,sans-serif;font-size:15px;line-height:1.55;
  min-height:100vh;display:flex;flex-direction:column;
}
h1,h2,h3{font-family:'Outfit',sans-serif;line-height:1.25}
.mono{font-family:'JetBrains Mono',monospace}
a{color:var(--brand)}
img{max-width:100%;display:block}

.pub-header{
  background:var(--surface);border-bottom:1px solid var(--line);
  padding:14px 16px;display:flex;align-items:center;gap:12px;
  position:sticky;top:0;z-index:20;
}
.pub-header .logo{height:34px;border-radius:6px}
.pub-header .name{font-family:'Outfit';font-weight:700;font-size:17px;color:var(--text);text-decoration:none}
.pub-header .lang{margin-left:auto;display:flex;gap:6px;font-size:13px}
.pub-header .lang a{padding:4px 8px;border-radius:6px;text-decoration:none;color:var(--muted)}
.pub-header .lang a.on{background:var(--surface-2);color:var(--text);font-weight:600}

.wrap{width:100%;max-width:960px;margin:0 auto;padding:20px 16px 70px;flex:1}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:18px}
.btn{
  background:var(--brand);color:#fff;border:none;border-radius:10px;
  padding:13px 20px;font:inherit;font-weight:600;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:44px;
}
.btn:hover{filter:brightness(1.07)}
.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn.block{width:100%}
.hint{font-size:13px;color:var(--muted)}
.error-box{background:rgba(207,77,77,.1);border:1px solid var(--danger);color:var(--danger);border-radius:10px;padding:12px 14px;font-size:14px;margin-bottom:12px}
.ok-box{background:rgba(63,157,99,.12);border:1px solid var(--ok);color:#2c7a4a;border-radius:10px;padding:12px 14px;font-size:14px;margin-bottom:12px}

/* hero / property cards */
.prop-card{overflow:hidden;padding:0}
.prop-card .cover{height:220px;object-fit:cover;width:100%}
.prop-card .body{padding:18px}
.rating{color:var(--amber);font-weight:600;font-size:14px}
.unit-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
.unit-card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface);display:flex;flex-direction:column}
.unit-card img{height:160px;object-fit:cover;width:100%}
.unit-card .body{padding:14px;display:flex;flex-direction:column;gap:6px;flex:1}
.unit-card .price{font-family:'JetBrains Mono';font-size:14px;color:var(--muted)}
.unit-card .btn{margin-top:auto}

/* gallery */
.gallery{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;border-radius:var(--radius);-webkit-overflow-scrolling:touch}
.gallery img{height:240px;min-width:82%;object-fit:cover;border-radius:10px;scroll-snap-align:center}
@media(min-width:700px){.gallery img{min-width:46%;height:320px}}

/* booking widget */
.bk-widget{position:sticky;bottom:0}
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}
.field label{font-size:12px;font-weight:600;color:var(--muted)}
.field input,.field select,.field textarea{
  background:var(--surface-2);border:1px solid var(--line);border-radius:10px;
  padding:12px;font:inherit;min-height:44px;width:100%;
}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* mini calendar */
.mini-cal{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:10px;user-select:none}
.mini-cal .head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-weight:600;font-family:'Outfit'}
.mini-cal .head button{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;width:34px;height:34px;font-size:15px;cursor:pointer}
.mini-cal table{width:100%;border-collapse:collapse;font-size:13px}
.mini-cal th{color:var(--muted);font-weight:500;padding:4px 0;font-size:11px;text-transform:uppercase}
.mini-cal td{text-align:center;padding:2px 0}
.mini-cal td button{
  width:38px;height:38px;border-radius:8px;border:none;background:none;
  font:inherit;cursor:pointer;color:var(--text);
}
.mini-cal td button:hover:not(:disabled){background:var(--surface-2)}
.mini-cal td button:disabled{color:#cfc7b4;text-decoration:line-through;cursor:not-allowed}
.mini-cal td button.sel{background:var(--brand);color:#fff;font-weight:600}
.mini-cal td button.inrange{background:color-mix(in srgb, var(--brand) 18%, transparent)}

.quote-line{display:flex;justify-content:space-between;font-size:14px;padding:4px 0}
.quote-line.total{font-weight:700;border-top:1px solid var(--line);margin-top:6px;padding-top:10px}

/* reviews */
.review{border-top:1px solid var(--line);padding:12px 0}
.review:first-child{border-top:none}
.review .who{font-weight:600;font-size:14px}
.review .stars{color:var(--amber)}
.review .reply{background:var(--surface-2);border-radius:8px;padding:8px 10px;margin-top:6px;font-size:13px}

footer.pub{
  background:var(--surface);border-top:1px solid var(--line);
  padding:18px 16px;font-size:13px;color:var(--muted);text-align:center;
}

/* stars input */
.star-input{display:flex;gap:6px;font-size:32px;cursor:pointer}
.star-input span{color:#d8cfb8;transition:color .1s}
.star-input span.on{color:var(--amber)}

@media(min-width:700px){
  .unit-grid{grid-template-columns:1fr 1fr}
  .unit-page{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start}
  .bk-widget{position:sticky;top:80px;bottom:auto}
}
