*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#fafafa;color:#111}a{color:inherit}.container{max-width:820px;margin:0 auto;padding:16px}.card{background:#fff;border:1px solid #e6e6e6;border-radius:14px;padding:14px;box-shadow:0 1px 2px #0000000a}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.row>*{flex:0 0 auto}input,select,button,textarea{font:inherit;padding:10px 12px;border:1px solid #dcdcdc;border-radius:12px;background:#fff}button{cursor:pointer}button.primary{background:#111;color:#fff;border-color:#111}button:disabled{opacity:.5;cursor:not-allowed}h1{font-size:20px;margin:0 0 12px}small{color:#666}table{width:100%;border-collapse:collapse}th,td{padding:10px;border-bottom:1px solid #eee;text-align:left;vertical-align:top}.badge{display:inline-block;padding:2px 8px;border:1px solid #ddd;border-radius:999px;font-size:12px;color:#444}.err{color:#b00020}.ok{color:#0b6b2e}.ui-shell{min-height:100vh;background:#f6f7fb;color:#111}.ui-topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;gap:12px;padding:12px 16px;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e9e9ef}.ui-title{font-weight:800;font-size:18px}.ui-subtitle{font-size:12px;color:#666;margin-top:2px}.ui-topbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ui-pin{width:120px;border:1px solid #ddd;border-radius:12px;padding:8px 10px;background:#fff}.ui-btn{border:1px solid #ddd;background:#fff;border-radius:12px;padding:8px 12px;cursor:pointer}.ui-btn.primary{background:#111;color:#fff;border-color:#111}.ui-seg{display:flex;border:1px solid #ddd;border-radius:12px;overflow:hidden;background:#fff}.ui-seg button{border:0;background:transparent;padding:8px 12px;cursor:pointer}.ui-seg button.on{background:#111;color:#fff}.ui-nav{display:flex;gap:6px}.ui-alert{margin:12px 16px;padding:10px 12px;border:1px solid #ffd4d4;background:#fff5f5;border-radius:12px;color:#8a0000}.ui-main{padding:16px}.grid-wrap{background:#fff;border:1px solid #e9e9ef;border-radius:16px;overflow:auto}.grid{position:relative;display:grid;grid-template-columns:90px repeat(5,minmax(140px,1fr));grid-auto-rows:44px;min-width:820px}.corner{position:sticky;left:0;z-index:3;background:#fff;border-bottom:1px solid #eee}.day-head{position:sticky;top:0;z-index:2;background:#fff;border-bottom:1px solid #eee;display:flex;flex-direction:column;justify-content:center;padding:0 10px}.day-name{font-weight:700}.day-date{font-size:12px;color:#666;margin-top:2px}.time-cell{position:sticky;left:0;z-index:2;background:#fff;border-right:1px solid #eee;border-bottom:1px solid #f0f0f4;display:flex;align-items:center;justify-content:center;font-size:12px;color:#555}.slot{border:0;border-bottom:1px solid #f0f0f4;border-right:1px solid #f0f0f4;background:#fff;cursor:pointer}.slot.free:hover{background:#f2f6ff}.slot.busy{background:#fafafb;cursor:not-allowed}.block{z-index:5;margin:4px;border-radius:12px;background:#111;color:#fff;padding:8px 10px;display:flex;flex-direction:column;gap:4px;box-shadow:0 6px 16px #0000001f;cursor:pointer}.block-title{font-weight:700;font-size:13px;line-height:1.1}.block-time{font-size:12px;opacity:.85}.panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;justify-content:center;align-items:flex-end;padding:14px;z-index:50}.panel{width:min(520px,100%);background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 16px 40px #00000040}.panel-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid #eee}.panel-title{font-weight:800}.panel-x{border:0;background:transparent;cursor:pointer;font-size:16px}.panel-body{padding:14px;display:flex;flex-direction:column;gap:12px}.panel-row{display:grid;grid-template-columns:90px 1fr;gap:10px;align-items:center}.label{font-size:12px;color:#666}.value{font-size:13px}.field{width:100%;border:1px solid #ddd;border-radius:12px;padding:10px 12px}.panel-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.panel-hint{font-size:12px;color:#666}
