:root{
  --serra:#0B3D2E; --serra-700:#155C44; --areia:#FAF6EC; --areia-200:#EFE6D2;
  --sol:#E8A33D; --coral:#E2674A; --ink:#2B2B2B; --muted:#7A7468; --linha:#E3DAC6;
  --ok:#2E8B57; --r:14px;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--areia);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}
h1{font-size:24px;margin:.2em 0}
h2{font-size:17px;color:var(--serra);margin:1.4em 0 .6em}
.logo-juju{display:flex;align-items:baseline;gap:1px;font-weight:700;font-size:30px;color:var(--serra)}
.logo-juju em{color:var(--sol);font-style:italic;font-size:34px;padding:0 2px}
.logo-juju--sm{font-size:22px}.logo-juju--sm em{font-size:25px}

/* ===== Login ===== */
.tela-login{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{background:#fff;border:1px solid var(--linha);border-radius:18px;padding:32px 26px;
  max-width:380px;width:100%;text-align:center;box-shadow:0 12px 40px rgba(11,61,46,.10)}
.login-card .logo-juju{justify-content:center;margin-bottom:14px}
.login-card .sub{color:var(--muted);font-size:14px;margin:.4em 0 1.6em}
.login-card label{display:block;text-align:left;font-size:13px;font-weight:600;color:var(--serra);margin-bottom:6px}
.login-card input{width:100%;padding:13px 14px;border:1.5px solid var(--linha);border-radius:10px;font-size:16px;margin-bottom:14px}
.login-card button,.btn-pri{background:var(--serra);color:#fff;border:0;padding:14px;border-radius:10px;
  font-size:16px;font-weight:600;width:100%;cursor:pointer}
.alerta-erro{background:#FCEBE8;color:#B23A23;padding:10px 12px;border-radius:8px;font-size:14px;margin:0 0 14px}

/* ===== App ===== */
.topo{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;
  background:#fff;border-bottom:1px solid var(--linha);position:sticky;top:0;z-index:5}
.sair{color:var(--muted);text-decoration:none;font-size:14px;font-weight:600}
.conteudo{max-width:640px;margin:0 auto;padding:18px 16px 80px}
.intro{color:var(--muted);font-size:14px;margin-top:0}
.titulo-quartos{margin-top:1.8em}

.bloco-areas{background:#fff;border:1px solid var(--linha);border-radius:var(--r);padding:16px}
.bloco-areas h2{margin-top:0}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.chip{border:1.5px solid var(--linha);background:#fff;color:var(--ink);border-radius:999px;
  padding:8px 14px;font-size:14px;cursor:pointer;user-select:none}
.chip.on{border-color:var(--sol);background:#FBF1DF;color:var(--serra);font-weight:600}
.btn-sec{background:#fff;color:var(--serra);border:1.5px solid var(--serra);padding:10px 16px;
  border-radius:10px;font-size:14px;font-weight:600;cursor:pointer}

.lista-quartos{display:flex;flex-direction:column;gap:10px}
.quarto{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;
  border:1px solid var(--linha);border-radius:var(--r);padding:15px 16px;cursor:pointer;
  transition:border-color .15s,transform .05s}
.quarto:active{transform:scale(.99)}
.quarto:hover{border-color:var(--sol)}
.quarto__info b{display:block;font-size:16px;color:var(--serra)}
.quarto__info span{font-size:13px;color:var(--muted)}
.badge{font-size:12px;font-weight:700;padding:5px 10px;border-radius:999px;white-space:nowrap}
.badge--ok{background:#E6F4EC;color:var(--ok)}
.badge--falta{background:#FCEFD9;color:#B5791B}

/* ===== Editor (modal) ===== */
.overlay{position:fixed;inset:0;background:rgba(11,61,46,.45);z-index:20}
.editor{position:fixed;z-index:21;left:0;right:0;bottom:0;background:var(--areia);
  border-radius:20px 20px 0 0;max-height:92vh;display:flex;flex-direction:column;
  max-width:640px;margin:0 auto}
.editor__head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--linha)}
.editor__head h3{margin:0;color:var(--serra);font-size:18px}
.ed-x{background:none;border:0;font-size:30px;line-height:1;color:var(--muted);cursor:pointer}
.editor__corpo{overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:16px}
.editor__rodape{padding:14px 18px;border-top:1px solid var(--linha);background:#fff}
.campo{display:flex;flex-direction:column;gap:6px}
.campo>span{font-size:13px;font-weight:600;color:var(--serra)}
.campo input,.campo textarea{padding:12px;border:1.5px solid var(--linha);border-radius:10px;font-size:16px;width:100%;font-family:inherit}
.camas,.tarifas{border:1px solid var(--linha);border-radius:12px;padding:14px;margin:0;background:#fff}
.camas legend,.tarifas legend{font-size:13px;font-weight:700;color:var(--serra);padding:0 6px}
.stepper{display:flex;align-items:center;justify-content:space-between;padding:8px 0}
.stepper>div{display:flex;align-items:center;gap:14px}
.stepper button{width:38px;height:38px;border:1.5px solid var(--serra);background:#fff;color:var(--serra);
  border-radius:10px;font-size:20px;cursor:pointer}
.stepper b{min-width:22px;text-align:center;font-size:17px}
.toggle{display:flex;gap:8px}
.toggle button{flex:1;padding:11px;border:1.5px solid var(--linha);background:#fff;border-radius:10px;font-size:14px;cursor:pointer}
.toggle button.on{border-color:var(--sol);background:#FBF1DF;color:var(--serra);font-weight:600}
.tarifas label{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.tarifas label span{font-size:14px;color:var(--ink)}
.tarifas label input{max-width:130px}
.tarifas .dica{font-size:12px;color:var(--muted);margin:4px 0 0}
.preview{background:#fff;border:1px dashed var(--sol);border-radius:12px;padding:14px;font-size:14px}
.preview h4{margin:0 0 6px;color:var(--serra)}
.preview .pv-preco{color:var(--coral);font-weight:700}

/* Tabs de unidade */
.tabs-unidade{display:flex;gap:8px;margin:0 0 14px}
.tab-uni{flex:1;padding:12px 10px;border:1.5px solid var(--linha);background:#fff;border-radius:10px;
  font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;line-height:1.2}
.tab-uni.on{border-color:var(--serra);background:var(--serra);color:#fff}
/* Dois campos lado a lado */
.dois{display:flex;gap:10px}
.dois .campo{flex:1}
/* Botão sugerir descrição */
.btn-sugerir{align-self:flex-start;margin-top:6px;background:#FBF1DF;color:var(--serra);
  border:1.5px solid var(--sol);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer}
/* Preço por pessoa */
.pp-temp{display:flex;align-items:flex-end;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.pp-temp>b{min-width:46px;font-size:13px;color:var(--serra);padding-bottom:9px}
.pp-temp label{display:flex;flex-direction:column;gap:3px;flex:1;min-width:90px;font-size:11px;font-weight:600;color:var(--muted)}
.pp-temp input{padding:10px;border:1.5px solid var(--linha);border-radius:8px;font-size:15px;width:100%}
.dica--fora{margin:-8px 0 2px;font-size:12px;color:var(--muted)}

/* ===== Temporadas ===== */
.legenda{display:flex;gap:14px;flex-wrap:wrap;margin:4px 0 16px;font-size:13px}
.leg{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}
.leg::before{content:'';width:12px;height:12px;border-radius:50%;display:inline-block}
.leg--baixa::before{background:var(--ok)}
.leg--media::before{background:var(--sol)}
.leg--alta::before{background:var(--coral)}
.lista-periodos{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.periodo{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;
  border:1px solid var(--linha);border-left:5px solid var(--ok);border-radius:var(--r);padding:14px 16px;cursor:pointer;transition:transform .05s}
.periodo:active{transform:scale(.99)}
.periodo--media{border-left-color:var(--sol);background:#FFFBF2}
.periodo--alta{border-left-color:var(--coral);background:#FDF2EF}
.periodo b{display:block;color:var(--serra);font-size:15px}
.periodo span{font-size:13px;color:var(--muted)}
.periodo__tag{font-size:12px;font-weight:700;padding:5px 10px;border-radius:999px;white-space:nowrap}
.periodo--media .periodo__tag{background:#FBF1DF;color:#B5791B}
.periodo--alta .periodo__tag{background:#FCEBE8;color:#B23A23}
.vazio{color:var(--muted);font-size:14px;text-align:center;padding:22px;background:#fff;border:1px dashed var(--linha);border-radius:var(--r)}
.btn-remover{background:#fff;color:var(--coral);border:1.5px solid var(--coral);padding:14px 18px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}
.editor__rodape--duplo{display:flex;gap:10px}
.editor__rodape--duplo .btn-pri{flex:1}

.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:var(--serra);color:#fff;
  padding:13px 20px;border-radius:999px;font-size:14px;font-weight:600;z-index:30;box-shadow:0 8px 24px rgba(0,0,0,.2)}

/* Em telas grandes (desktop) o editor vira modal centralizado */
@media(min-width:680px){
  .editor{top:50%;bottom:auto;transform:translateY(-50%);border-radius:18px;max-height:88vh;
    box-shadow:0 20px 60px rgba(0,0,0,.3)}
}
