.calendar-container{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#f8fafc,rgba(239,246,255,.3))}.calendar-container.dark{background:linear-gradient(135deg,#0f172a,#1e293b)}.calendar-header{position:sticky;top:0;z-index:20;backdrop-filter:blur(24px);background:rgba(255,255,255,.8);border-bottom:1px solid rgba(226,232,240,.5);box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06)}.calendar-header.dark{background:rgba(15,23,42,.8);border-bottom:1px solid rgba(51,65,85,.5)}.header-content{justify-content:space-between;padding:1.5rem}.header-content,.header-left{display:flex;align-items:center}.header-left{gap:1.5rem}.header-title-section{display:flex;align-items:center;gap:.5rem}.calendar-icon{height:1.5rem;width:1.5rem;color:#475569}.calendar-icon.dark{color:#cbd5e1}.main-title{font-size:1.875rem;font-weight:700;background:linear-gradient(90deg,#0f172a,#475569);background-clip:text;-webkit-background-clip:text;color:transparent}.main-title.dark{background:linear-gradient(90deg,#ffffff,#cbd5e1);background-clip:text;-webkit-background-clip:text}.subtitle{font-size:.875rem;color:#64748b}.subtitle.dark{color:#94a3b8}.header-controls{display:flex;align-items:center;gap:.75rem}.nav-button{border:none;background:transparent;padding:.5rem;border-radius:50%;cursor:pointer;transition:all .2s}.nav-button:hover{background:#f1f5f9}.nav-button.dark:hover{background:#1e293b}.nav-button-icon{height:1rem;width:1rem}.today-button{border:none;background:transparent;padding:.5rem 1rem;border-radius:50px;cursor:pointer;transition:all .2s}.today-button:hover{background:#f1f5f9}.today-button.dark:hover{background:#1e293b}.month-display{margin-left:1rem;padding:.5rem 1rem;background:rgba(255,255,255,.6);border-radius:.75rem;backdrop-filter:blur(4px);border:1px solid rgba(226,232,240,.5)}.month-display.dark{background:rgba(30,41,59,.6);border:1px solid rgba(51,65,85,.5)}.month-title{font-size:1.125rem;font-weight:600;color:#1e293b}.month-title.dark{color:#e2e8f0}.calendar-content{flex:1;padding:1.5rem}.calendar-wrapper{max-width:80rem;margin:0 auto}.day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1rem}.day-header{padding:1rem;text-align:center}.day-header-text{font-size:.75rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.day-header-text.dark{color:#94a3b8}.calendar-grid-container{background:rgba(255,255,255,.6);border-radius:1rem;backdrop-filter:blur(4px);border:1px solid rgba(226,232,240,.5);box-shadow:0 25px 50px -12px rgba(0,0,0,.25);overflow:hidden}.calendar-grid-container.dark{background:rgba(30,41,59,.6);border:1px solid rgba(51,65,85,.5)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0}.calendar-day{height:150px;width:150px;padding:.75rem;border-right:1px solid rgba(241,245,249,.5);border-bottom:1px solid rgba(241,245,249,.5);transition:all .2s}.calendar-day.dark{border-right:1px solid rgba(51,65,85,.3);border-bottom:1px solid rgba(51,65,85,.3)}.calendar-day:nth-child(7n){border-right:0}.calendar-day.last-row{border-bottom:0}.calendar-day.other-month{background:rgba(248,250,252,.5);color:#94a3b8}.calendar-day.other-month.dark{background:rgba(15,23,42,.3);color:#475569}.calendar-day.today{background:linear-gradient(180deg,rgba(239,246,255,.8),rgba(243,232,255,.8))}.calendar-day.today.dark{background:linear-gradient(180deg,rgba(30,58,138,.3),rgba(88,28,135,.3))}.calendar-day.weekend{background:rgba(248,250,252,.3)}.calendar-day.weekend.dark{background:rgba(30,41,59,.2)}.calendar-day.current-month:hover{background:rgba(248,250,252,.5)}.calendar-day.current-month.dark:hover{background:rgba(51,65,85,.3)}.day-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.day-number{font-size:.875rem;font-weight:600;transition:all .2s;color:#1e293b}.day-number.dark{color:#e2e8f0}.day-number.other-month{color:#94a3b8}.day-number.other-month.dark{color:#475569}.day-number.today{color:white;background:linear-gradient(90deg,#3b82f6,#9333ea);width:1.75rem;height:1.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05)}.event-overflow{font-size:.75rem;color:#64748b;background:rgba(241,245,249,.8);padding:.25rem .5rem;border-radius:50px;backdrop-filter:blur(4px)}.event-overflow.dark{color:#94a3b8;background:rgba(51,65,85,.8)}.events-list{display:flex;flex-direction:column;gap:.25rem}.event-item{color:white;border-radius:.5rem;padding:.25rem .5rem;box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);transition:all .2s;cursor:pointer;font-size:9px}.event-item:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.event-content{display:flex;align-items:center;gap:.25rem}.event-dot{width:.25rem;height:.25rem;background:rgba(255,255,255,.6);border-radius:50%}.event-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-color-0{background:linear-gradient(90deg,#3b82f6,#2563eb)}.event-color-1{background:linear-gradient(90deg,#10b981,#059669)}.event-color-2{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.event-color-3{background:linear-gradient(90deg,#f97316,#ea580c)}.event-color-4{background:linear-gradient(90deg,#ec4899,#db2777)}.event-color-5{background:linear-gradient(90deg,#6366f1,#4f46e5)}.event-color-6{background:linear-gradient(90deg,#14b8a6,#0d9488)}.event-color-7{background:linear-gradient(90deg,#ef4444,#dc2626)}.event-color-8{background:linear-gradient(90deg,#06b6d4,#0891b2)}.event-color-9{background:linear-gradient(90deg,#eab308,#ca8a04)}.event-color-10{background:linear-gradient(90deg,#6b7280,#4b5563)}.calendar-legend{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#475569}.legend-item.dark{color:#94a3b8}.legend-dot{width:.75rem;height:.75rem;border-radius:50%}.legend-dot.today{background:linear-gradient(90deg,#3b82f6,#9333ea);box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06)}.legend-dot.weekend{background:#f1f5f9;border:1px solid #e2e8f0}.legend-dot.weekend.dark{background:#334155;border:1px solid #475569}.legend-dot.other-month{background:#cbd5e1}.legend-dot.other-month.dark{background:#475569}.tooltip-content{padding:.75rem;max-width:20rem}.tooltip-title{font-size:.875rem;font-weight:700;color:white;margin-bottom:.25rem}.tooltip-time{font-size:.75rem;color:#e2e8f0;margin-bottom:.5rem}.tooltip-description{font-size:.75rem;color:#e2e8f0;margin-bottom:.25rem}.tooltip-location{font-size:.75rem;color:#e2e8f0;display:flex;align-items:center;gap:.25rem}.tooltip-location-icon{width:.75rem;height:.75rem}