:root{font-family:Inter,system-ui,sans-serif;color:#1f2937;background-color:#f3f4f6}body{margin:0;padding:10px}.container{max-width:1000px;margin:0 auto;background:#fff;padding:12px;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:12px}h1{margin:0;font-size:1.4rem;font-weight:800;color:#111827}.btn{background-color:#2563eb;color:#fff;border:none;padding:6px 14px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;font-size:.8rem;height:32px}.btn:hover{background-color:#1d4ed8;transform:translateY(-1px)}.btn-secondary{background:#fff;border:1px solid #d1d5db;color:#374151;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer}.week-toggle{background:#f3f4f6;padding:2px;border-radius:6px;display:flex;gap:2px}.toggle-btn{background:transparent;border:none;padding:2px 10px;border-radius:4px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s;font-size:.75rem}.toggle-btn.active{background:#fff;color:#111827;box-shadow:0 1px 2px #0000001a}.summary-bar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;background:#f8fafc;padding:6px 10px;border-radius:6px;border:1px solid #e2e8f0;margin-bottom:8px}.summary-item{display:flex;align-items:center;gap:4px;background:#fff;padding:2px 6px;border-radius:4px;border:1px solid #e5e7eb;font-size:.7rem;font-weight:500}.rate-input{width:45px;padding:1px;border:1px solid #d1d5db;border-radius:4px;font-size:.7rem;text-align:right}.calendar-container{display:flex;border:1px solid #e5e7eb;border-radius:8px;background:#fff;overflow-x:auto;position:relative;-webkit-overflow-scrolling:touch}.time-column{width:40px;flex-shrink:0;border-right:1px solid #e5e7eb;background:#fff;position:sticky;left:0;z-index:20;box-shadow:4px 0 8px -4px #0000001a}.time-slot-label{height:18px;font-size:.6rem;color:#9ca3af;text-align:right;padding-right:4px;transform:translateY(-50%)}.day-column{flex:1;border-right:1px solid #e5e7eb;min-width:100px;position:relative}.day-column:last-child{border-right:none}.day-header{height:28px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}.day-slots{position:relative}.slot{height:18px;border-bottom:1px solid #f3f4f6;cursor:pointer;box-sizing:border-box}.slot:nth-child(2n){border-bottom:1px solid #e5e7eb}.slot:hover{background-color:#f8fafc}.slot.selected{background-color:#dbeafe}.event-absolute{position:absolute;left:2px;right:2px;border-radius:3px;padding:1px 3px;font-size:.7rem;color:#fff;overflow:hidden;box-shadow:0 1px 2px #0000001a;z-index:5;cursor:pointer;pointer-events:auto;transition:transform .1s}.event-desc{font-weight:400;font-size:.7em;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bg-blue{background-color:#3b82f6;border-left:3px solid #1e40af}.text-blue{color:#1e40af}.bg-green{background-color:#10b981;border-left:3px solid #065f46}.text-green{color:#065f46}.bg-purple{background-color:#8b5cf6;border-left:3px solid #5b21b6}.text-purple{color:#5b21b6}.bg-orange{background-color:#f97316;border-left:3px solid #9a3412}.text-orange{color:#9a3412}.bg-red{background-color:#ef4444;border-left:3px solid #991b1b}.text-red{color:#991b1b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:50}.modal{background:#fff;padding:20px;border-radius:12px;width:320px;box-shadow:0 20px 25px -5px #0000001a;max-width:90vw}.modal h2{margin:0 0 12px;font-size:1.1rem}.input-group{margin-bottom:12px}.input-group label{display:block;font-size:.8rem;color:#4b5563;margin-bottom:4px}.input-text{width:100%;padding:6px;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box}.input-area{width:100%;padding:6px;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;resize:vertical;min-height:50px;font-family:inherit}.days-selector{display:flex;justify-content:space-between;gap:4px}.day-check{display:flex;flex-direction:column;align-items:center;cursor:pointer}.day-check input{display:none}.day-circle{width:28px;height:28px;border-radius:50%;background:#f3f4f6;color:#6b7280;display:flex;justify-content:center;align-items:center;font-size:.7rem;font-weight:600;border:1px solid #e5e7eb;transition:all .2s}.day-check input:checked+.day-circle{background:#111827;color:#fff;border-color:#111827}.color-picker{display:flex;gap:8px}.color-dot{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent}.color-dot.active{border-color:#111827;transform:scale(1.1)}.modal-actions{display:flex;justify-content:space-between;margin-top:16px}.btn-delete{color:#ef4444;background:none;border:none;font-weight:600;cursor:pointer;font-size:.85rem}.btn-save{background:#111827;color:#fff;padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:.85rem}@media(max-width:640px){body{padding:8px}.container{padding:12px}.header{flex-direction:column;align-items:flex-start;gap:12px}.week-toggle{width:100%;justify-content:center}.toggle-btn{flex:1;text-align:center}.header>div:last-child{width:100%;display:flex;justify-content:space-between}}
