html,body,#root{width:100%;min-height:100%;margin:0;padding:0}body{overflow:hidden}*{box-sizing:border-box}body{color:#222;background:#f4f5f8;margin:0;font-family:Arial,sans-serif;overflow:hidden}.app{width:100vw;height:100vh;overflow:auto}.main-header{z-index:50;background:#111;align-items:center;gap:30px;height:70px;padding:8px 16px;display:flex;position:sticky;top:0}.small-logo{color:#fff;min-width:110px;font-size:28px;font-weight:700}.top-menu{flex:1;align-items:center;gap:24px;font-weight:600;display:flex}.top-menu span{color:#fff;cursor:pointer}.top-menu .active{color:#b266ff}button{color:#fff;cursor:pointer;background:#7b00ff;border:none;border-radius:10px;padding:10px 16px;font-weight:700}.title-bar{color:#fff;background:#9e9e9e;padding:10px 16px}.title-left{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:20px;display:flex}.title-bar h1{margin:0;font-size:26px}.calendar-nav{align-items:center;gap:10px;display:flex}.nav-btn{background:#7b00ff;width:38px;height:38px;padding:0;font-size:16px}.action-btn{background:#5d5d5d}.calendar{background:#fff;border-top:1px solid #ddd;border-left:1px solid #ddd;grid-template-columns:55px repeat(6,1fr);width:max-content;min-width:100%;display:grid}.time-header,.day-header{text-align:center;background:#fff;border-right:2px solid #d4d4d4;height:86px}.time-header{color:#fff;z-index:20;background:#111;justify-content:center;align-items:center;font-weight:700;display:flex;position:sticky;left:0}.day-title{border-bottom:1px solid #dcdcdc;flex-direction:column;justify-content:center;align-items:center;height:52px;display:flex}.day-name{font-size:18px;font-weight:700}.date-line{color:#666;font-size:14px;font-weight:600}.employee-row{border-bottom:2px solid #6d00ff;grid-template-columns:repeat(8,1fr);height:32px;display:grid}.employee-row span{color:#fff;border-right:1px solid #e5e5e5;justify-content:center;align-items:center;font-size:9px;font-weight:700;display:flex}.employee-row span:first-child,.employee-row span:nth-child(2),.employee-row span:nth-child(3){background:#7b00ff}.employee-row span:nth-child(4),.employee-row span:nth-child(5),.employee-row span:nth-child(6),.employee-row span:nth-child(7),.employee-row span:nth-child(8){background:#9e9e9e}.time-column{z-index:10;background:#111;grid-column:1;position:sticky;left:0}.day-column{border-right:2px solid #bdbdbd;grid-template-columns:repeat(8,1fr);display:grid}.employee-column{border-right:1px solid #ededed;position:relative}.slot{cursor:pointer;border-bottom:1px solid #ededed;height:26px}.slot:hover{background:#f4ebff}.time{color:#fff;text-align:center;border-bottom:1px solid #2a2a2a;padding:4px;font-size:11px}.appointment{color:#fff;z-index:5;border-radius:8px;padding:4px;font-size:10px;position:absolute;left:2px;right:2px;overflow:hidden}.appointment strong{font-size:11px;display:block}.appointment span{display:block}.appointment small{opacity:.8;display:block}.purple{background:#7b00ff}.blocked-slot{z-index:4;background:#ff000040;border:2px solid red;border-radius:8px;position:absolute;left:2px;right:2px}.modal-bg{z-index:100;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.month-calendar{background:#fff;border-radius:16px;width:500px;max-width:90vw;padding:20px}.month-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.month-header button{width:40px;height:40px;padding:0}.month-days{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.month-days button{color:#000;background:#f1f1f1;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:6px;height:65px;display:flex}.month-days button:hover{background:#e5d4ff}.mini-day{color:#777;font-size:11px}.today-btn{width:100%;margin-top:18px}input,select,textarea{border:1px solid #ccc;border-radius:8px;width:100%;margin-top:5px;padding:10px}label{font-size:13px;font-weight:700}.small-logo-img{width:auto;height:52px;display:block}
