*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#2d3748;background:#f8fafc;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*:focus{outline:3px solid #4c4a48;outline-offset:2px}button:focus,[tabindex]:focus{outline:3px solid #4c4a48;outline-offset:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#4c4a48;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3a3836}.fade-in{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media print{body{background:#fff}.calendar-container{box-shadow:none;background:#fff}.nav-button,.modal-backdrop{display:none}}.calendar-container{max-width:1200px;margin:0 auto;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#fff;min-height:100vh;border-radius:20px;box-shadow:0 20px 40px #0000001a}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#f8fafc;padding:20px 30px;border-radius:15px;border:1px solid #e2e8f0}.calendar-title{font-size:2.5rem;font-weight:700;color:#2d3748;margin:0;text-align:center;flex:1}.nav-button{background:#4c4a48;color:#fff;border:none;width:50px;height:50px;border-radius:50%;font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #4c4a4866}.nav-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4c4a4899}.nav-button:focus{outline:3px solid rgba(76,74,72,.5);outline-offset:2px}.calendar-grid{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 8px 32px #0000001a;border:1px solid #e2e8f0}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background:#4c4a48}.weekday-header{padding:15px 10px;text-align:center;font-weight:600;color:#fff;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.calendar-days{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;background:#e2e8f0;grid-auto-rows:minmax(120px,auto)}.calendar-day{min-height:120px;padding:8px;background:#fff;border:none;cursor:pointer;transition:all .2s ease;position:relative;display:flex;flex-direction:column;overflow:hidden;word-wrap:break-word}.calendar-day:hover{background:#f7fafc;transform:scale(1.02);z-index:1;box-shadow:0 4px 12px #0000001a}.calendar-day:focus{outline:3px solid #4c4a48;outline-offset:-3px;z-index:2}.calendar-day.other-month{background:#f8f9fa;color:#a0aec0}.calendar-day.today{background:#4c4a48;color:#fff;font-weight:700}.calendar-day.today .day-number{background:#fff3;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.day-number{font-size:1rem;font-weight:600;margin-bottom:4px;color:inherit}.events-container{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden;min-width:0}.empty-day{background:#f8f9fa;cursor:default}.empty-day:hover{transform:none;box-shadow:none}.event-item{padding:4px 6px;border-radius:6px;font-size:.75rem;cursor:pointer;transition:all .2s ease;color:#fff;font-weight:500;display:flex;flex-direction:column;gap:1px;box-shadow:0 2px 4px #0000001a;overflow:hidden;min-width:0;width:100%;box-sizing:border-box}.event-item:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.event-item:focus{outline:2px solid white;outline-offset:1px}.event-time{font-size:.7rem;opacity:.9;font-weight:600}.event-title{font-size:.75rem;line-height:1.3;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;min-width:0;width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.more-events{font-size:.7rem;color:#4c4a48;font-weight:600;text-align:center;padding:2px;background:#4c4a481a;border-radius:4px;margin-top:2px}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:#fff;border-radius:20px;padding:30px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{position:absolute;top:15px;right:20px;background:none;border:none;font-size:2rem;cursor:pointer;color:#a0aec0;transition:color .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-close:hover{color:#e53e3e;background:#e53e3e1a}.modal-close:focus{outline:3px solid #e53e3e;outline-offset:2px}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px;gap:15px}.modal-title{font-size:1.8rem;font-weight:700;color:#2d3748;margin:0;flex:1}.modal-category{padding:6px 12px;border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.modal-body{display:flex;flex-direction:column;gap:15px}.event-detail{display:flex;flex-direction:column;gap:5px}.event-detail strong{color:#4a5568;font-size:.9rem;font-weight:600}.event-description{margin:0;color:#718096;line-height:1.6;font-size:.95rem}.modal-footer{margin-top:25px;padding-top:20px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}.modal-button{display:inline-block;padding:12px 24px;background-color:#4c4a48;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .3s ease;cursor:pointer;border:none;text-align:center}.modal-button:hover{background-color:#3a3836;transform:translateY(-2px);box-shadow:0 4px 12px #4c4a4866}.modal-button:focus{outline:3px solid rgba(76,74,72,.5);outline-offset:2px}.modal-button:active{transform:translateY(0)}@media (max-width: 768px){.calendar-container{padding:10px;border-radius:10px}.calendar-header{padding:15px 20px;margin-bottom:20px}.calendar-title{font-size:1.8rem}.nav-button{width:40px;height:40px;font-size:1.2rem}.calendar-day{min-height:80px;padding:6px}.day-number{font-size:.9rem}.event-item{font-size:.7rem;padding:3px 4px}.modal-content{padding:20px;margin:10px}.modal-title{font-size:1.5rem}.modal-button{padding:10px 20px;font-size:.9rem}}@media (max-width: 480px){.calendar-title{font-size:1.5rem}.calendar-day{min-height:70px;padding:4px}.weekday-header{padding:10px 5px;font-size:.8rem}.event-item{font-size:.65rem}}.app{width:100%;max-width:1400px;margin:0 auto}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;color:#fff;font-size:1.2rem}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-right:15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background:#ef44441a;border:2px solid #ef4444;border-radius:15px;padding:20px;color:#dc2626;text-align:center;margin:20px 0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.error-title{font-size:1.2rem;font-weight:600;margin-bottom:10px}.error-message{font-size:.95rem;opacity:.8}@media (max-width: 768px){.app{padding:0 10px}}@media (max-width: 480px){.app{padding:0 5px}}
