:root{--casal-bg:#f7f2eb;--casal-card:#fffaf4;--casal-white:#fff;--casal-ink:#1f1712;--casal-muted:#78685b;--casal-line:#e3d4c4;--casal-accent:#8b6b51;--casal-accent-dark:#6d503b;--casal-soft:#efe4d8;--casal-ok:#1f7a4d;--casal-warn:#a06000;--casal-bad:#b42318;--casal-shadow:0 18px 45px rgba(55,35,20,.10)}
.casal-app{font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--casal-bg);color:var(--casal-ink);padding:24px;border:1px solid var(--casal-line);border-radius:24px;box-shadow:var(--casal-shadow);max-width:1400px;margin:0 auto;box-sizing:border-box}
.casal-app *{box-sizing:border-box}.casal-login-box{max-width:520px;margin:32px auto;padding:28px;background:var(--casal-card);border:1px solid var(--casal-line);border-radius:24px;box-shadow:var(--casal-shadow)}.casal-login-box h2{margin:4px 0 10px;font-size:30px}.casal-eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:800;color:var(--casal-accent);margin:0 0 6px}.casal-header{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:18px}.casal-header h1{font-family:Georgia,"Times New Roman",serif;font-size:clamp(34px,5vw,62px);line-height:1.05;margin:0}.casal-userbar{display:flex;gap:14px;align-items:center;flex-wrap:wrap;color:var(--casal-muted);font-size:14px;margin-top:10px}.casal-userbar a{color:var(--casal-accent-dark);font-weight:700;text-decoration:none}.casal-actions,.casal-panel-tools{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.casal-panel-tools label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--casal-muted)}.casal-btn{appearance:none;border:0;background:var(--casal-accent);color:#fff;border-radius:999px;padding:11px 18px;font-weight:800;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px;line-height:1}.casal-btn:hover{background:var(--casal-accent-dark);color:#fff}.casal-btn--ghost{background:#fff;color:var(--casal-accent-dark);border:1px solid var(--casal-line)}.casal-btn--ghost:hover{background:var(--casal-soft);color:var(--casal-accent-dark)}.casal-icon-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--casal-line);background:#fff;font-size:26px;line-height:1;cursor:pointer}.casal-mini{border:1px solid var(--casal-line);background:#fff;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;color:var(--casal-accent-dark);cursor:pointer;margin:2px}.casal-mini.danger{color:var(--casal-bad)}.casal-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}.casal-tabs button{border:0;background:var(--casal-soft);color:var(--casal-accent-dark);font-weight:800;border-radius:999px;padding:10px 16px;cursor:pointer}.casal-tabs button.is-active{background:var(--casal-accent);color:#fff}.casal-panels{background:#fff;border:1px solid var(--casal-line);border-radius:20px;padding:18px}.casal-panel{display:none}.casal-panel.is-active{display:block}.casal-panel-head{display:flex;justify-content:space-between;align-items:center;gap:14px;border-bottom:1px solid var(--casal-line);padding-bottom:14px;margin-bottom:16px}.casal-panel-head h2{font-family:Georgia,"Times New Roman",serif;font-size:34px;margin:0}.casal-muted{color:var(--casal-muted)}.casal-notice{padding:12px 14px;border-radius:14px;margin:12px 0;background:#eaf7ef;color:var(--casal-ok);border:1px solid #bde6cb;font-weight:700}.casal-notice--bad{background:#fff0ee;color:var(--casal-bad);border-color:#ffc8c0}.casal-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:18px}.casal-kpi{background:var(--casal-card);border:1px solid var(--casal-line);border-radius:18px;padding:16px}.casal-kpi span{display:block;color:var(--casal-muted);font-size:13px;margin-bottom:8px}.casal-kpi strong{display:block;font-size:24px}.casal-kpi.warn strong{color:var(--casal-warn)}.casal-two-cols{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}.casal-card{background:#fff;border:1px solid var(--casal-line);border-radius:18px;padding:16px;margin-bottom:14px}.casal-card h3{margin:0 0 12px;font-size:20px}.casal-alert,.casal-incident{border:1px solid var(--casal-line);border-radius:14px;padding:12px;margin:8px 0;background:var(--casal-card)}.casal-alert strong,.casal-incident strong{display:block}.casal-alert span,.casal-incident span{display:block;color:var(--casal-muted);font-size:13px;margin-top:3px}.casal-table-wrap{width:100%;overflow:auto;border:1px solid var(--casal-line);border-radius:14px;background:#fff}.casal-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.casal-table th{background:var(--casal-soft);color:var(--casal-accent-dark);text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding:10px;white-space:nowrap}.casal-table td{padding:10px;border-top:1px solid var(--casal-line);vertical-align:top}.casal-table tr:hover td{background:#fffdf9}.casal-table textarea,.casal-table select{width:100%;min-width:120px;border:1px solid var(--casal-line);border-radius:10px;padding:7px;background:#fff}.casal-badge{display:inline-block;padding:4px 9px;border-radius:999px;background:var(--casal-soft);color:var(--casal-accent-dark);font-size:12px;font-weight:800;white-space:nowrap}.casal-badge.confirmada,.casal-badge.pagat,.casal-badge.fet,.casal-badge.preparat,.casal-badge.revisat{background:#e6f5ed;color:var(--casal-ok)}.casal-badge.pendent,.casal-badge.parcial,.casal-badge.previst{background:#fff4dc;color:var(--casal-warn)}.casal-badge.cancellada,.casal-badge.cancelada{background:#fff0ee;color:var(--casal-bad)}.casal-filters{display:flex;gap:10px;margin:0 0 14px}.casal-filters input,.casal-filters select,.casal-panel-tools input{border:1px solid var(--casal-line);border-radius:999px;padding:10px 12px;background:#fff}.casal-filters input{min-width:280px;flex:1}.casal-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.casal-calendar-grid>b{text-align:center;color:var(--casal-muted);font-size:12px}.casal-day{min-height:116px;border:1px solid var(--casal-line);border-radius:14px;background:#fff;padding:8px;overflow:hidden}.casal-day.muted{background:transparent;border-color:transparent}.casal-day.today{outline:3px solid rgba(139,107,81,.2)}.casal-day-num{font-weight:900;margin-bottom:6px}.casal-day-res{font-size:12px;background:var(--casal-soft);color:var(--casal-accent-dark);border-radius:8px;padding:4px 6px;margin:3px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.casal-month-title{text-transform:capitalize;color:var(--casal-accent-dark)}.casal-room-map{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.casal-room-state{border:1px solid var(--casal-line);border-radius:16px;padding:12px;background:#f5fbf7}.casal-room-state.busy{background:#fff4dc}.casal-room-state strong,.casal-room-state span,.casal-room-state small,.casal-room-state em{display:block}.casal-room-state em{margin-top:8px;font-style:normal;font-weight:800}.casal-modal{position:fixed;inset:0;z-index:99999;display:grid;place-items:center;padding:18px}.casal-modal[hidden]{display:none}.casal-modal__backdrop{position:absolute;inset:0;background:rgba(25,18,12,.48);backdrop-filter:blur(3px)}.casal-modal__card{position:relative;background:var(--casal-bg);border:1px solid var(--casal-line);border-radius:24px;box-shadow:0 30px 90px rgba(0,0,0,.25);width:min(1180px,96vw);max-height:92vh;overflow:auto;padding:22px}.casal-modal__head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border-bottom:1px solid var(--casal-line);padding-bottom:12px;margin-bottom:16px}.casal-modal__head h2{font-family:Georgia,"Times New Roman",serif;font-size:36px;margin:0}.casal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.casal-form-grid--main{grid-template-columns:1.05fr .95fr}.casal-form-section{background:#fff;border:1px solid var(--casal-line);border-radius:18px;padding:16px;margin-bottom:16px}.casal-form-section h3{margin:0 0 12px;font-size:18px}.casal-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.casal-fields label,.casal-wide-label,.casal-mini-form label,.casal-config-form label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:800;color:var(--casal-accent-dark)}.casal-fields input,.casal-fields select,.casal-wide-label textarea,.casal-wide-label input,.casal-mini-form input,.casal-mini-form select,.casal-mini-form textarea,.casal-config-form input{border:1px solid var(--casal-line);border-radius:12px;padding:10px;background:#fff;color:var(--casal-ink);font:inherit}.casal-checks{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:8px;margin-bottom:12px}.casal-checks label,.casal-inline{background:var(--casal-card);border:1px solid var(--casal-line);border-radius:12px;padding:9px;display:flex;align-items:center;gap:8px;color:var(--casal-accent-dark);font-weight:800}.casal-section-row{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.casal-room-summary{display:flex;gap:10px;align-items:center;flex-wrap:wrap;color:var(--casal-muted)}.casal-room-summary .ok{color:var(--casal-ok);font-weight:900}.casal-room-summary .bad{color:var(--casal-bad);font-weight:900}.casal-rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.casal-room-card{display:flex;gap:10px;align-items:flex-start;border:1px solid var(--casal-line);border-radius:14px;padding:10px;background:var(--casal-card);cursor:pointer}.casal-room-card:has(input:checked){outline:3px solid rgba(139,107,81,.22);background:#fff}.casal-room-card span,.casal-room-card small{display:block}.casal-room-card small{color:var(--casal-muted);margin-top:3px}.casal-price-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px;margin-bottom:12px}.casal-price-preview div{background:var(--casal-card);border:1px solid var(--casal-line);border-radius:14px;padding:10px}.casal-price-preview span{display:block;color:var(--casal-muted);font-size:12px}.casal-price-preview strong{display:block;font-size:17px}.casal-price-preview .total{background:#e6f5ed}.casal-extra-meal{display:grid;grid-template-columns:repeat(7,minmax(100px,1fr));gap:8px;align-items:end;border-bottom:1px solid var(--casal-line);padding:10px 0}.casal-extra-meal label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--casal-muted);font-weight:800}.casal-extra-meal input,.casal-extra-meal select{border:1px solid var(--casal-line);border-radius:10px;padding:8px}.casal-form-footer{display:flex;justify-content:flex-end;align-items:center;gap:10px;position:sticky;bottom:0;background:linear-gradient(180deg,rgba(247,242,235,0),var(--casal-bg) 30%);padding:18px 0 4px}.casal-form-message{margin-right:auto;color:var(--casal-bad);font-weight:800}.casal-mini-form{display:flex;flex-direction:column;gap:10px}.casal-incident p{margin:8px 0 0}.casal-config-form .casal-fields{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}@media(max-width:900px){.casal-app{padding:14px;border-radius:18px}.casal-header,.casal-panel-head,.casal-two-cols,.casal-form-grid,.casal-form-grid--main{grid-template-columns:1fr;display:block}.casal-actions{margin-top:12px}.casal-panel-head h2{font-size:28px}.casal-panels{padding:12px}.casal-table{font-size:13px}.casal-calendar-grid{gap:4px}.casal-day{min-height:92px;padding:6px}.casal-extra-meal{grid-template-columns:1fr 1fr}.casal-modal{padding:0}.casal-modal__card{width:100vw;height:100vh;max-height:100vh;border-radius:0}.casal-header h1{font-size:38px}.casal-filters{display:block}.casal-filters input,.casal-filters select{width:100%;margin-bottom:8px}}

/* === v1.4 · Responsive app shell inside the plugin === */
.casal-app{
  width:100%;
  max-width:none;
  min-height:calc(100vh - 32px);
  margin:0 auto;
  background:
    radial-gradient(circle at top left, rgba(139,107,81,.12), transparent 34%),
    linear-gradient(135deg,#f8f3eb 0%,#efe6db 100%);
}
.casal-header{
  position:sticky;
  top:0;
  z-index:80;
  padding:14px 0 16px;
  background:rgba(248,243,235,.92);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(139,107,81,.16);
}
.casal-tabs{
  position:sticky;
  top:92px;
  z-index:70;
  padding:10px;
  background:rgba(255,255,255,.74);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(139,107,81,.16);
  border-radius:22px;
  box-shadow:0 16px 36px rgba(55,35,20,.07);
}
.casal-tabs button,.casal-btn,.casal-mini{
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.casal-tabs button:hover,.casal-btn:hover,.casal-mini:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(70,45,28,.13);
}
.casal-panels{
  background:rgba(255,255,255,.88);
  box-shadow:0 24px 70px rgba(55,35,20,.10);
}
.casal-day-res{
  border-left:4px solid var(--casal-accent);
}
.casal-table-wrap{
  -webkit-overflow-scrolling:touch;
}
.casal-form-footer{
  z-index:20;
}

@media (max-width: 1100px){
  .casal-two-cols,
  .casal-form-grid,
  .casal-form-grid--main{
    grid-template-columns:1fr;
  }
  .casal-panel-head{
    align-items:flex-start;
  }
}

@media (max-width: 760px){
  .casal-app{
    min-height:100vh;
    padding:0 0 24px;
    border:0;
    border-radius:0;
    box-shadow:none;
  }
  .casal-login-box{
    margin:18px 12px;
    border-radius:22px;
  }
  .casal-header{
    display:block;
    padding:14px 14px 12px;
    margin:0;
  }
  .casal-header h1{
    font-size:28px;
    line-height:1.08;
    letter-spacing:-.035em;
  }
  .casal-userbar{
    gap:8px;
    font-size:13px;
  }
  .casal-actions{
    display:flex;
    gap:8px;
    overflow-x:auto;
    flex-wrap:nowrap;
    padding-bottom:2px;
    margin-top:12px;
    scrollbar-width:none;
  }
  .casal-actions::-webkit-scrollbar{display:none;}
  .casal-actions .casal-btn{
    white-space:nowrap;
    flex:0 0 auto;
  }
  .casal-tabs{
    top:120px;
    overflow-x:auto;
    flex-wrap:nowrap;
    margin:0 12px 14px;
    border-radius:18px;
    padding:8px;
    scrollbar-width:none;
  }
  .casal-tabs::-webkit-scrollbar{display:none;}
  .casal-tabs button{
    white-space:nowrap;
    flex:0 0 auto;
    padding:11px 14px;
  }
  .casal-panels{
    margin:0 12px;
    padding:14px;
    border-radius:22px;
  }
  .casal-panel-head{
    display:block;
    padding-bottom:12px;
  }
  .casal-panel-head h2{
    font-size:26px;
  }
  .casal-panel-tools{
    display:flex;
    gap:8px;
    overflow-x:auto;
    flex-wrap:nowrap;
    margin-top:12px;
    padding-bottom:2px;
    scrollbar-width:none;
  }
  .casal-panel-tools::-webkit-scrollbar{display:none;}
  .casal-panel-tools input,
  .casal-panel-tools select,
  .casal-panel-tools .casal-mini{
    flex:0 0 auto;
    white-space:nowrap;
  }
  .casal-kpis{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }
  .casal-kpi{
    padding:12px;
  }
  .casal-kpi span{
    font-size:12px;
  }
  .casal-kpi strong{
    font-size:22px;
  }
  .casal-card,
  .casal-form-section{
    border-radius:18px;
    padding:14px;
  }
  .casal-filters{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }
  .casal-filters input,
  .casal-filters select{
    width:100%;
    min-width:0;
    margin:0;
  }
  .casal-table{
    min-width:760px;
  }
  .casal-calendar-grid{
    display:block;
  }
  .casal-calendar-grid > b{
    display:none;
  }
  .casal-day,
  .casal-day.muted{
    display:block;
    min-height:auto;
    margin-bottom:10px;
    border:1px solid var(--casal-line);
    background:#fffaf4;
  }
  .casal-day.muted:not(:has(.casal-day-res)){
    display:none;
  }
  .casal-day-num{
    font-size:14px;
  }
  .casal-day-res{
    white-space:normal;
    overflow:visible;
    text-overflow:clip;
    font-size:13px;
    padding:7px 8px;
  }
  .casal-room-map,
  .casal-rooms-grid,
  .casal-checks,
  .casal-price-preview,
  .casal-fields{
    grid-template-columns:1fr;
  }
  .casal-extra-meal{
    grid-template-columns:1fr;
    border:1px solid var(--casal-line);
    border-radius:16px;
    padding:12px;
    margin-bottom:10px;
    background:#fff;
  }
  .casal-modal{
    padding:0;
  }
  .casal-modal__card{
    width:100vw;
    height:100vh;
    max-height:100vh;
    border-radius:0;
    padding:14px;
  }
  .casal-modal__head{
    position:sticky;
    top:0;
    z-index:5;
    background:var(--casal-bg);
    padding-top:6px;
  }
  .casal-modal__head h2{
    font-size:26px;
  }
  .casal-form-footer{
    position:sticky;
    bottom:0;
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    background:linear-gradient(180deg,rgba(247,242,235,0),var(--casal-bg) 24%);
    padding:20px 0 8px;
  }
  .casal-form-footer .casal-btn,
  .casal-form-footer .casal-btn--ghost{
    width:100%;
    justify-content:center;
  }
  .casal-form-message{
    margin:0;
  }
}

@media (max-width: 390px){
  .casal-kpis{
    grid-template-columns:1fr;
  }
  .casal-header h1{
    font-size:25px;
  }
  .casal-tabs{
    top:128px;
  }
}

/* === v1.5 · Poliment d'app real === */
.casal-dashboard-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-bottom:16px;
}
.casal-card--focus{
  background:linear-gradient(180deg,#fffaf3,#f4eadf);
  border-color:#d9c6b2;
}
.casal-card--danger{
  background:#fff3f1;
  border-color:#efb4ad;
}
.casal-today-card{
  width:100%;
  display:block;
  text-align:left;
  border:1px solid var(--casal-line);
  border-radius:16px;
  background:#fff;
  padding:12px;
  margin:8px 0;
  color:var(--casal-ink);
  cursor:pointer;
}
.casal-today-card strong,
.casal-today-card span,
.casal-today-card small,
.casal-mini-card strong,
.casal-mini-card span{
  display:block;
}
.casal-today-card span,.casal-mini-card span{color:var(--casal-muted);margin-top:3px;}
.casal-today-card small{color:var(--casal-accent-dark);margin-top:6px;font-weight:800;}
.casal-mini-card{
  border:1px solid var(--casal-line);
  background:#fff;
  border-radius:14px;
  padding:10px;
  margin:8px 0;
}
.casal-alert--danger{
  background:#ffe7e2;
  border-color:#efb4ad;
}
.casal-agenda{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.casal-agenda-day{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:14px;
  border:1px solid var(--casal-line);
  border-radius:22px;
  background:#fff;
  padding:14px;
}
.casal-agenda-day.today{
  outline:3px solid rgba(139,107,81,.18);
  background:#fffaf4;
}
.casal-agenda-date strong,
.casal-agenda-date span{
  display:block;
}
.casal-agenda-date strong{
  font-size:17px;
  color:var(--casal-accent-dark);
}
.casal-agenda-date span{
  margin-top:4px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:900;
  color:var(--casal-muted);
}
.casal-agenda-content h4{
  margin:12px 0 7px;
  color:var(--casal-accent-dark);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.casal-agenda-content h4:first-child{margin-top:0;}
.casal-agenda-item{
  width:100%;
  display:block;
  text-align:left;
  border:1px solid #eadfD4;
  border-radius:14px;
  background:#fffdf9;
  padding:10px;
  margin:7px 0;
  color:var(--casal-ink);
}
.casal-agenda-item strong,
.casal-agenda-item span{display:block;}
.casal-agenda-item span{color:var(--casal-muted);font-size:13px;margin-top:3px;}
.casal-mobile-list{display:none;}
.casal-app-card{
  border:1px solid var(--casal-line);
  border-radius:18px;
  background:#fff;
  padding:14px;
  margin:10px 0;
  box-shadow:0 8px 22px rgba(55,35,20,.05);
}
.casal-app-card strong,
.casal-app-card span,
.casal-app-card small{display:block;}
.casal-app-card span{color:var(--casal-muted);margin-top:3px;}
.casal-app-card small{color:var(--casal-accent-dark);margin-top:6px;}
.casal-app-card__actions{
  display:grid;
  grid-template-columns:minmax(110px,180px) 1fr auto;
  gap:8px;
  align-items:end;
  margin-top:12px;
}
.casal-app-card__actions select,
.casal-app-card__actions textarea{
  border:1px solid var(--casal-line);
  border-radius:12px;
  padding:9px;
  width:100%;
}

@media (max-width: 900px){
  .casal-dashboard-grid{
    grid-template-columns:1fr;
    gap:12px;
  }
  .casal-agenda-day{
    grid-template-columns:1fr;
    gap:8px;
    border-radius:18px;
    padding:12px;
  }
  .casal-mobile-list{display:block;}
  .casal-desktop-table{display:none;}
  .casal-app-card__actions{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .casal-app{
    padding-bottom:92px;
  }
  .casal-tabs{
    position:fixed;
    top:auto;
    left:0;
    right:0;
    bottom:0;
    z-index:9999;
    margin:0;
    border-radius:20px 20px 0 0;
    box-shadow:0 -18px 42px rgba(55,35,20,.16);
    border-left:0;
    border-right:0;
    border-bottom:0;
  }
  .casal-tabs button{
    font-size:13px;
    padding:10px 12px;
  }
  .casal-notice{
    position:fixed;
    left:12px;
    right:12px;
    bottom:82px;
    z-index:10000;
    box-shadow:0 18px 42px rgba(55,35,20,.18);
  }
  .casal-panel-tools label{
    background:#fff;
    border:1px solid var(--casal-line);
    border-radius:14px;
    padding:8px;
  }
  .casal-panel-tools input,
  .casal-panel-tools select{
    min-height:38px;
  }
  .casal-today-card,
  .casal-mini-card,
  .casal-app-card,
  .casal-agenda-item{
    border-radius:16px;
  }
}


/* v1.6 · Calendaris iCal */
.casal-calendar-feeds{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:16px 0}.casal-calendar-feed{display:grid;gap:14px}.casal-calendar-feed h3{margin:6px 0 4px}.casal-calendar-feed p{margin:0;color:#7b624e}.casal-calendar-feed input[readonly]{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:12px;background:#fffdf9}.casal-feed-badge{display:inline-flex;align-items:center;border-radius:999px;background:#8b6b51;color:#fff;padding:4px 9px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.casal-feed-actions{display:flex;gap:10px;flex-wrap:wrap}.casal-steps{margin:10px 0 0;padding-left:22px}.casal-steps li{margin:7px 0}.casal-card--focus{border-color:#c9ad92!important;background:linear-gradient(180deg,#fffaf4,#f5eadf)!important}
@media(max-width:700px){.casal-calendar-feeds{grid-template-columns:1fr}.casal-feed-actions .casal-btn{width:100%;justify-content:center}.casal-calendar-feed input[readonly]{font-size:11px}}


/* === v1.7 · Poliment operatiu === */
.casal-app .casal-table th,
.casal-app .casal-table thead th{
  position:static!important;
  top:auto!important;
  z-index:auto!important;
}
.casal-app .casal-table thead{
  display:table-header-group!important;
}
.casal-app .casal-table tbody{
  display:table-row-group!important;
}
.casal-app .casal-table tr{
  display:table-row!important;
}
.casal-app .casal-table th,
.casal-app .casal-table td{
  display:table-cell!important;
}
.casal-app .casal-table-wrap{
  clear:both;
}
.casal-app select:disabled,
.casal-app textarea:disabled,
.casal-app input:disabled{
  background:#f7f2eb!important;
  color:#6f6258!important;
  opacity:1!important;
  cursor:not-allowed!important;
}

/* v1.8 · Fitxa de consulta només lectura */
.casal-detail-card{max-width:min(1120px,96vw);max-height:92vh;overflow:auto}
.casal-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.casal-detail-wide{grid-column:1/-1}
.casal-detail-line{display:grid;grid-template-columns:minmax(120px,.6fr) 1fr;gap:12px;border-bottom:1px solid var(--casal-line);padding:8px 0}
.casal-detail-line span{color:var(--casal-muted);font-size:13px}
.casal-detail-line strong{font-size:14px;font-weight:800;white-space:pre-wrap}
.casal-detail-modal .casal-table-wrap{max-height:280px}
@media(max-width:760px){.casal-detail-grid{grid-template-columns:1fr}.casal-detail-line{grid-template-columns:1fr;gap:2px}.casal-detail-card{border-radius:0;max-width:100vw;max-height:100vh;height:100vh}}

/* v2.4 · seguretat, diagnòstic, PWA i disponibilitat visual */
.casal-room-card.is-busy {
  opacity: .7;
  border-color: #d46a4c !important;
  background: #fff1ec !important;
}
.casal-room-card.is-busy input:not(:checked) {
  cursor: not-allowed;
}
.casal-room-card.is-free {
  border-color: #d8c7b5;
}
.casal-room-card [data-room-status] {
  display: block;
  margin-top: 4px;
  font-style: normal;
  font-size: 12px;
  color: #6d503b;
}
.casal-room-card.is-busy [data-room-status] {
  color: #a63d25;
  font-weight: 700;
}
.casal-card--danger {
  border-color: #e59b88 !important;
  background: #fff3ef !important;
}
.casal-incident {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}
.casal-incident > div {
  flex: 1 1 auto;
}
.casal-incident .danger,
.casal-mini.danger {
  background: #9d3f2d !important;
  color: #fff !important;
  border-color: #9d3f2d !important;
}
.casal-steps {
  margin-left: 1.2rem;
}
.casal-steps li {
  margin-bottom: 8px;
}
.casal-kpis code,
.casal-card code {
  white-space: normal;
  word-break: break-all;
}
@media (max-width: 720px) {
  .casal-incident {
    display: block;
  }
  .casal-incident button {
    margin-top: 10px;
    width: 100%;
  }
}
