:root{--bg: #f4f5f6;--panel: #ffffff;--panel-2: #f7f8f9;--border: #dddddd;--border-soft: #ececec;--text: #333333;--text-2: #666666;--muted: #999999;--accent: #428bca;--accent-dark: #3071a9;--green: #2ecc71;--green-dark: #27ad60;--blue: #428bca;--red: #a94442;--red-bg: #f2dede;--amber: #8a6d3b;--amber-bg: #fcf8e3;--amber-line: #f0ad4e;--header: #3c3c3c;--header-2: #333333;--radius: 4px;--shadow: 0 1px 2px rgba(0, 0, 0, .06);--font: "Helvetica Neue", Helvetica, Arial, sans-serif}*{box-sizing:border-box}html,body{margin:0;background:var(--bg);color:var(--text);font:14px/1.45 var(--font)}#app{max-width:1180px;margin:0 auto;padding:0 16px 80px}h1,h2,h3,h4{font-weight:500;color:var(--text)}h2{font-size:20px}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;margin:16px 0;box-shadow:var(--shadow)}.card>h2{margin:0 0 4px}.card .sub{color:var(--text-2);font-size:12.5px;margin:0 0 14px}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.spacer{flex:1}.muted{color:var(--muted)}.small{font-size:12px}.mono{font-variant-numeric:tabular-nums}button{font:inherit;background:#fff;color:var(--text);border:1px solid #ccc;border-radius:var(--radius);padding:7px 12px;cursor:pointer}button:hover{background:#f5f5f5}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--green);border-color:var(--green-dark);color:#fff}button.primary:hover{background:var(--green-dark)}button.danger{color:var(--red);border-color:#d3a7a7}button.danger:hover{background:var(--red-bg)}button.ghost{background:transparent;border-color:transparent;color:var(--accent)}button.ghost:hover{background:#f0f4f8;text-decoration:none}button.sm{padding:4px 9px;font-size:12px}input,select,textarea{font:inherit;background:#fff;color:var(--text);border:1px solid #ccc;border-radius:var(--radius);padding:7px 9px}input:focus,select:focus,textarea:focus{outline:none;border-color:#66afe9;box-shadow:0 0 0 3px #66afe940}label.field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-2)}label.field input,label.field select,label.field textarea{color:var(--text)}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:3px;font-size:11.5px;font-weight:600;border:1px solid transparent}.badge.ok{background:#dff0d8;color:#3c763d}.badge.warn{background:var(--amber-bg);color:var(--amber)}.badge.err{background:var(--red-bg);color:var(--red)}.badge.info{background:#d9edf7;color:#31708f}.badge.grey{background:#eee;color:#777}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:#ccc}.dot.on{background:#5cd07e;box-shadow:0 0 0 3px #2ecc714d}.dot.off{background:#e57373}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:3px;font-size:12.5px;font-weight:600;border:1px solid transparent}.chip.available{background:var(--green);color:#fff;border-color:var(--green-dark)}.chip.gone{background:#f0f1f2;color:#aaa;text-decoration:line-through;border-color:var(--border-soft)}.chip.booked{background:var(--accent);color:#fff;border-color:var(--accent-dark)}.chip.matched{box-shadow:0 0 0 2px var(--amber-line)}.switch{position:relative;width:46px;height:26px;flex:none}.switch input{display:none}.switch span{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:999px;transition:.15s}.switch span:after{content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.15s;box-shadow:0 1px 2px #0000004d}.switch input:checked+span{background:var(--green)}.switch input:checked+span:after{transform:translate(20px)}.statusbar{position:sticky;top:0;z-index:20;margin:0 -16px 16px;box-shadow:var(--shadow)}.topbar{background:var(--header);color:#fff;display:flex;align-items:center;gap:14px;padding:10px 18px}.topbar .brand{font-size:17px;font-weight:600;letter-spacing:.2px}.topbar .brand .brand-sub{color:#2ecc71;font-weight:400}.topbar .meta{color:#cfcfcf;font-size:12.5px}.controlbar{background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 18px}.live-box{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:var(--radius);border:1px solid var(--border)}.live-box.live{background:#dff0d8;border-color:#b6dba0}.live-box.dry{background:var(--amber-bg);border-color:#faebcc}.daygrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.daycard{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:0;overflow:hidden}.daycard h4{margin:0;font-size:13px;font-weight:600;color:var(--text);display:flex;justify-content:space-between;align-items:center;background:var(--panel-2);border-bottom:1px solid var(--border-soft);padding:7px 10px}.daycard .chips{display:flex;flex-wrap:wrap;gap:5px;padding:10px}.weekgrid{display:grid;grid-template-columns:90px repeat(7,1fr);gap:4px}.weekgrid .cell{height:34px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:11.5px;background:#edeef0;color:var(--muted);position:relative}.weekgrid .head{background:transparent;color:var(--text-2);font-weight:600;height:auto}.weekgrid .rowlabel{background:transparent;color:var(--text-2);justify-content:flex-start;font-size:11px}.heatgrid{display:grid;grid-template-columns:54px repeat(7,1fr);gap:3px}.heatgrid .cell{height:22px;border-radius:3px;background:#edeef0}.heatgrid .head,.heatgrid .rowlabel{background:transparent;color:var(--text-2);font-size:11px;height:auto;display:flex;align-items:center}.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--text-2);align-items:center}.legend .sw{width:12px;height:12px;border-radius:2px;display:inline-block;vertical-align:-2px;margin-right:5px}.toasts{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;z-index:100}.toast{background:#fff;border:1px solid var(--border);border-left-width:4px;border-radius:var(--radius);padding:10px 14px;max-width:360px;box-shadow:0 6px 18px #00000026}.toast.ok{border-left-color:var(--green)}.toast.warn{border-left-color:var(--amber-line)}.toast.err{border-left-color:var(--red)}.toast.info{border-left-color:var(--accent)}.winrow{border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin:8px 0;background:var(--panel)}.winrow.booked{border-color:#b6dba0;background:#f6fbf3}.winrow.disarmed{opacity:.6}table.bookings{width:100%;border-collapse:collapse;font-size:12.5px}table.bookings th,table.bookings td{text-align:left;padding:5px 8px;border-bottom:1px solid var(--border-soft)}table.bookings th{color:var(--text-2);font-weight:600}details summary{cursor:pointer}code.req{display:block;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px;font-size:11px;word-break:break-all;white-space:pre-wrap;margin-top:8px;color:var(--text-2)}.winform{border:1px solid var(--border-soft);border-radius:var(--radius);padding:14px;background:var(--panel-2)}.formsection{margin-bottom:14px}.formhead{display:flex;align-items:center;font-weight:600;font-size:13px;color:var(--text);margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border-soft)}.howto{margin:0 0 14px;padding:10px 12px 10px 32px;background:#f7f8f9;border:1px solid var(--border-soft);border-radius:var(--radius);color:var(--text-2);font-size:13px}.howto li{margin:3px 0}.emptyweek{background:#d9edf7;color:#31708f;border:1px solid #bce8f1;border-radius:var(--radius);padding:8px 12px;margin-bottom:10px;font-size:12.5px}.emptyweek a{color:#245269;font-weight:600;cursor:pointer}.cal-wrap{overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:#fff}.cal{display:flex}.cal-col{flex:1 1 0;min-width:0;border-right:1px solid var(--border-soft)}.cal-col:last-child{border-right:none}.cal-col.ruler{flex:0 0 50px}.cal-col.today .cal-head{background:#fff7e6;color:#8a6d3b;box-shadow:inset 0 -3px 0 var(--amber-line)}.cal-col.wknd .cal-head{background:#eef0f2;color:var(--muted)}.cal-col.wknd .cal-body{background:#fafbfc}.cal-col.past{opacity:.5}.cal-head{background:var(--panel-2);border-bottom:1px solid var(--border);padding:4px;font-size:11px;font-weight:600;text-align:center;height:46px;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.15}.cal-body{position:relative;-webkit-user-select:none;user-select:none;overflow:hidden}.cal-col:not(.ruler):not(.past) .cal-body{cursor:crosshair}.cal-hline{position:absolute;left:0;right:0;border-top:1px solid #f0f1f2}.cal-hour-label{position:absolute;right:5px;font-size:10px;color:var(--muted)}.cal-slot{position:absolute;left:3px;right:3px;border-radius:3px;font-size:10px;font-weight:600;line-height:1.05;padding:0 4px;overflow:hidden;box-sizing:border-box;display:flex;align-items:center;z-index:1}.cal-slot.available{background:var(--green);color:#fff;border:1px solid var(--green-dark)}.cal-slot.gone{background:#eceef0;color:#aaa;border:1px solid var(--border-soft);text-decoration:line-through}.cal-slot.booked{background:var(--accent);color:#fff;border:1px solid var(--accent-dark)}.cal-slot.matched{box-shadow:0 0 0 2px var(--amber-line);z-index:1}.cal-sel{position:absolute;left:0;right:0;background:#428bca38;border:1px dashed var(--accent);z-index:2;pointer-events:none}.cal-sel-label{position:absolute;left:2px;top:1px;font-size:10px;font-weight:600;color:var(--accent-dark);background:#fff;padding:0 3px;border-radius:2px}.cal-band{position:absolute;right:2px;border-radius:3px;border-left:3px solid;z-index:0;overflow:hidden;pointer-events:none}.cal-band-label{font-size:9px;font-weight:700;padding:0 3px;white-space:nowrap;opacity:.85}.stripgrid{display:flex;gap:4px;flex-wrap:wrap}.stripcell{width:48px;padding:4px 2px;border-radius:3px;text-align:center;border:1px solid var(--border-soft);font-size:11px;line-height:1.25}.loginwrap{min-height:75vh;display:flex;align-items:center;justify-content:center}.logincard{width:320px;max-width:90vw;display:flex;flex-direction:column;gap:12px;text-align:center}.logincard input{text-align:center}
