.navbar{background-color:#2c3e50;color:#fff;padding:1rem 0;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.navbar-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.navbar-brand{text-decoration:none;color:#fff;display:flex;align-items:center;gap:.75rem}.navbar-brand:hover{opacity:.9}.navbar-logo{height:42px;width:auto;object-fit:contain;background:#fff;border-radius:6px;padding:3px}.navbar-company{display:flex;flex-direction:column}.navbar-company-name{font-size:1rem;font-weight:700;line-height:1.2;color:#fff}.navbar-company-sub{font-size:.75rem;color:#bdc3c7;line-height:1.2}.navbar-menu{display:flex;gap:1.5rem;align-items:center}.navbar-menu a{color:#fff;text-decoration:none;transition:color .3s}.navbar-menu a:hover{color:#3498db}.navbar-user{font-weight:700}.btn-logout{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background-color .3s}.btn-logout:hover{background-color:#c0392b}.cal-page{padding:1rem;max-width:1400px;margin:0 auto}.cal-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.cal-toolbar-left,.cal-toolbar-right{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.cal-header-label{font-size:1.2rem;font-weight:700;color:#2c3e50}.cal-btn{padding:.4rem .9rem;border:1px solid #bdc3c7;background:#fff;border-radius:4px;cursor:pointer;font-size:.95rem;transition:all .2s}.cal-btn:hover{background:#f0f0f0}.cal-btn-today{background:#3498db;color:#fff;border-color:#3498db}.cal-btn-today:hover{background:#2980b9}.cal-btn-active{background:#2c3e50;color:#fff;border-color:#2c3e50}.cal-view-btns{display:flex;border:1px solid #bdc3c7;border-radius:4px;overflow:hidden}.cal-view-btns .cal-btn{border:none;border-radius:0;border-right:1px solid #bdc3c7}.cal-view-btns .cal-btn:last-child{border-right:none}.cal-select{padding:.4rem .8rem;border:1px solid #bdc3c7;border-radius:4px;font-size:.95rem}.cal-event{font-size:.78rem;color:#fff;padding:2px 6px;border-radius:3px;margin-bottom:2px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .2s}.cal-event:hover{opacity:.85}.cal-event-day{display:flex;flex-direction:column;gap:2px;padding:6px 8px;white-space:normal;font-size:.9rem}.cal-month{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.cal-month-header{display:grid;grid-template-columns:repeat(7,1fr);background:#2c3e50;color:#fff}.cal-month-day-name{text-align:center;padding:.75rem;font-weight:600;font-size:.9rem}.cal-month-grid{display:grid;grid-template-columns:repeat(7,1fr)}.cal-month-cell{min-height:110px;border-right:1px solid #ecf0f1;border-bottom:1px solid #ecf0f1;padding:6px;position:relative}.cal-month-cell.cal-empty{background:#f9f9f9}.cal-month-cell.cal-today{background:#ebf5fb}.cal-date-num{font-size:.9rem;font-weight:600;color:#2c3e50;display:block;margin-bottom:4px}.cal-month-cell.cal-today .cal-date-num{background:#3498db;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem}.cal-month-events{display:flex;flex-direction:column;gap:2px}.cal-more{font-size:.75rem;color:#7f8c8d;padding:1px 4px;cursor:pointer}.cal-week{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.cal-week-header{display:grid;grid-template-columns:60px repeat(7,1fr);background:#2c3e50;color:#fff;position:sticky;top:0;z-index:10}.cal-week-day-header{text-align:center;padding:.75rem .5rem;display:flex;flex-direction:column;gap:2px;font-size:.9rem;border-left:1px solid rgba(255,255,255,.1)}.cal-week-day-header.cal-today{background:#3498db}.cal-day-header .cal-today{background:#3498db;color:#fff}.cal-week-body{overflow-y:auto;max-height:70vh}.cal-week-row{display:grid;grid-template-columns:60px repeat(7,1fr);border-bottom:1px solid #ecf0f1;min-height:50px}.cal-time-gutter{padding:4px 8px;font-size:.75rem;color:#95a5a6;text-align:right;border-right:1px solid #ecf0f1;background:#fafafa}.cal-week-cell{padding:2px;border-left:1px solid #ecf0f1;min-height:50px}.cal-day{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.cal-day-header{display:grid;grid-template-columns:60px 1fr;background:#2c3e50;color:#fff}.cal-day-title{padding:1rem;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:1rem}.cal-day-count{background:#fff3;padding:2px 10px;border-radius:12px;font-size:.85rem;font-weight:400}.cal-day-body{overflow-y:auto;max-height:70vh}.cal-day-cell{padding:4px;border-left:1px solid #ecf0f1;min-height:50px;flex:1}.cal-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.cal-modal{background:#fff;border-radius:8px;width:380px;max-width:90%;box-shadow:0 8px 30px #0003;overflow:hidden}.cal-modal-header{padding:1rem 1.5rem;color:#fff;display:flex;justify-content:space-between;align-items:center}.cal-modal-header h3{margin:0;font-size:1.1rem}.cal-modal-close{background:#fff3;border:none;color:#fff;font-size:1rem;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.cal-modal-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.6rem}.cal-modal-body p{margin:0;font-size:.95rem;color:#333}.cal-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;padding:.75rem 1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.cal-legend-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#555}.cal-legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.cal-today{background:#ebf5fb!important}@media (max-width: 768px){.cal-week-header,.cal-week-row{grid-template-columns:40px repeat(7,1fr)}.cal-time-gutter{padding:4px 2px;font-size:.65rem}.cal-event{font-size:.65rem}.cal-month-cell{min-height:70px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}#root{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.page-container{padding:2rem 1rem}button,.btn{font-family:inherit;font-size:1rem;padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;transition:all .3s}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-secondary{background-color:#95a5a6;color:#fff}.btn-secondary:hover{background-color:#7f8c8d}.btn-success{background-color:#27ae60;color:#fff}.btn-success:hover{background-color:#229954}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}.form-group{margin-bottom:1.5rem}label{display:block;margin-bottom:.5rem;font-weight:500}input,select,textarea{width:100%;padding:.75rem;border:1px solid #bdc3c7;border-radius:4px;font-family:inherit;font-size:1rem}input:focus,select:focus,textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}textarea{resize:vertical;min-height:100px}.card{background:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;margin-bottom:1rem}.card-header{border-bottom:1px solid #ecf0f1;margin-bottom:1rem;padding-bottom:1rem}.card-header h2{margin:0;color:#2c3e50}.alert{padding:1rem;border-radius:4px;margin-bottom:1rem}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-info{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:2rem auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}table{width:100%;border-collapse:collapse;background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 2px 4px #0000001a}th{background-color:#34495e;color:#fff;padding:1rem;text-align:left;font-weight:600}td{padding:1rem;border-bottom:1px solid #ecf0f1}tr:hover{background-color:#f8f9fa}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}@media (max-width: 768px){.grid,.grid-2{grid-template-columns:1fr}.navbar-menu{flex-direction:column;gap:.5rem}}
