*{box-sizing:border-box}body{margin:0;font-family:"Segoe UI",Tahoma,sans-serif;background:linear-gradient(135deg,#fdf2f8,#e0f2fe);color:#263044}.top{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:rgba(255,255,255,.75);backdrop-filter:blur(14px);box-shadow:0 8px 30px #94a3b833;position:sticky;top:0;z-index:5}.brand{font-weight:800;font-size:22px;background:linear-gradient(90deg,#ec4899,#0ea5e9);-webkit-background-clip:text;color:transparent}.nav a,.btn{display:inline-block;padding:10px 14px;border-radius:14px;text-decoration:none;border:0;background:linear-gradient(90deg,#f472b6,#38bdf8);color:white;font-weight:700;margin:4px;cursor:pointer}.btn.gray{background:#64748b}.btn.red{background:#ef4444}.wrap{max-width:1200px;margin:24px auto;padding:0 16px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.card{background:rgba(255,255,255,.82);border:1px solid #fff;border-radius:24px;padding:18px;box-shadow:0 15px 45px #94a3b844}.stat{font-size:34px;font-weight:900}.calendar{width:100%;border-collapse:separate;border-spacing:8px}.calendar th{color:#64748b}.calendar td{vertical-align:top;height:118px;background:#fff;border-radius:18px;padding:10px;box-shadow:inset 0 0 0 1px #e2e8f0}.day{font-weight:800}.muted{opacity:.45}.event{font-size:12px;margin-top:6px;padding:5px 7px;background:#f8fafc;border-radius:10px;border-left:6px solid}.dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:6px}.roomlist{display:flex;flex-wrap:wrap;gap:10px}.roomtag{background:#fff;border-radius:999px;padding:8px 12px;box-shadow:0 6px 18px #94a3b833}input,select,textarea{width:100%;padding:12px;border:1px solid #cbd5e1;border-radius:14px;margin:6px 0 12px;background:#fff}label{font-weight:700}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px;border-bottom:1px solid #e2e8f0;text-align:left}.alert{padding:12px;border-radius:14px;background:#fee2e2;color:#991b1b;margin:10px 0}.ok{background:#dcfce7;color:#166534}.roomimg{width:100%;height:150px;object-fit:cover;border-radius:18px;background:#e2e8f0}@media(max-width:700px){.calendar td{height:90px;padding:6px}.event{font-size:10px}.top{display:block}}
.calendar{table-layout:fixed}
.calendar td{height:118px;max-height:118px;overflow:hidden}
.event{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.25}

/* Calendar fixed scale v3 */
.calendar{
  table-layout:fixed !important;
  width:100% !important;
  border-collapse:separate !important;
  border-spacing:8px !important;
}
.calendar tr{
  height:126px !important;
}
.calendar td{
  height:118px !important;
  max-height:118px !important;
  min-height:118px !important;
  overflow:hidden !important;
  position:relative;
}
.calendar td .day{
  height:20px;
}
.calendar td .event{
  display:block;
  max-height:34px !important;
  overflow:hidden !important;
  white-space:nowrap !important;
  text-overflow:ellipsis !important;
  line-height:1.2 !important;
}
.calendar td .event:nth-of-type(n+4){
  display:none !important;
}

/* Calendar hard lock v5 */
.calendar{
  width:100% !important;
  table-layout:fixed !important;
  border-collapse:separate !important;
  border-spacing:8px !important;
}
.calendar tbody,
.calendar tr{
  height:auto !important;
}
.calendar th{
  height:34px !important;
}
.calendar td{
  height:118px !important;
  max-height:118px !important;
  min-height:118px !important;
  padding:8px !important;
  overflow:hidden !important;
  position:relative !important;
  vertical-align:top !important;
}
.calendar .day{
  position:absolute;
  top:8px;
  left:8px;
  height:20px;
  line-height:20px;
  z-index:2;
}
.calendar .events-wrap{
  position:absolute;
  left:8px;
  right:8px;
  top:32px;
  bottom:8px;
  overflow:hidden;
}
.calendar .event{
  display:block !important;
  width:100% !important;
  height:24px !important;
  max-height:24px !important;
  min-height:24px !important;
  line-height:14px !important;
  margin-top:4px !important;
  padding:4px 6px !important;
  overflow:hidden !important;
  white-space:nowrap !important;
  text-overflow:ellipsis !important;
  cursor:pointer;
}
.calendar .event:nth-child(n+4){
  display:none !important;
}
.modal-bg{display:none;position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:99;align-items:center;justify-content:center;padding:16px}
.modal-box{background:white;border-radius:24px;max-width:520px;width:100%;padding:22px;box-shadow:0 25px 80px #0f172a66}
.modal-box h3{margin-top:0}
.modal-close{float:right;background:#ef4444;color:#fff;border:0;border-radius:12px;padding:8px 12px;cursor:pointer}
.detail-row{padding:7px 0;border-bottom:1px solid #e2e8f0}
.detail-row b{display:inline-block;min-width:130px;color:#475569}

body{background:radial-gradient(circle at 10% 10%,rgba(244,114,182,.38),transparent 28%),radial-gradient(circle at 90% 20%,rgba(56,189,248,.36),transparent 30%),radial-gradient(circle at 50% 95%,rgba(168,85,247,.20),transparent 35%),linear-gradient(135deg,#fff1f8,#e0f7ff 48%,#f8fbff)!important;min-height:100vh}
body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.25;z-index:-1;background-image:linear-gradient(30deg,rgba(255,255,255,.5) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.5) 87.5%),linear-gradient(150deg,rgba(255,255,255,.5) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.5) 87.5%);background-size:80px 140px}
.card,.top{border:1px solid rgba(255,255,255,.75)!important;background:rgba(255,255,255,.80)!important}
.badge-off{display:inline-block;background:#fee2e2;color:#991b1b;border-radius:999px;padding:5px 10px;font-weight:800}
.badge-on{display:inline-block;background:#dcfce7;color:#166534;border-radius:999px;padding:5px 10px;font-weight:800}

.room-preview-box{display:flex;align-items:center;gap:10px;margin:8px 0 12px}
.room-thumb{width:70px!important;height:70px!important;object-fit:cover!important;border-radius:14px!important;box-shadow:0 8px 20px #94a3b855;background:#e2e8f0}
.room-legend-top{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0}
.room-legend-top .roomtag{font-size:14px}

.room-thumb{width:100px!important;height:100px!important;object-fit:contain!important;background:#fff!important;border:1px solid #e2e8f0}
.admin-search{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}.admin-search input{max-width:360px}
