@import"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600&display=swap";.calendar-header-redesigned{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:16px;padding:24px;margin:0 auto 32px;max-width:1200px;box-shadow:0 8px 25px -5px #0000001a,0 4px 10px -3px #0000000d;border:1px solid #e2e8f0}.header-top-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:20px}.calendar-nav{display:flex;gap:8px;flex-shrink:0}.month-year-container-redesigned{display:flex;flex-direction:column;align-items:center;flex:1;text-align:center}.month-year-container-redesigned .month-year{margin:0;font-size:1.75rem;font-weight:700;color:#003d7a;text-transform:capitalize}.month-year-container-redesigned .month-badge{display:inline-block;background:#003d7a;color:#fff;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:500;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.header-controls{flex-shrink:0}.header-bottom-row{display:flex;justify-content:space-between;align-items:center;gap:20px}.calendar-search-section-redesigned{flex:1;display:flex;align-items:center;gap:12px}.events-stats-redesigned{display:flex;align-items:center;gap:8px;background:#fff;padding:8px 16px;border-radius:8px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.stats-total{font-weight:600;color:#374151;font-size:.875rem}.stats-found{color:#059669;font-weight:500;font-size:.875rem}@media (max-width: 768px){.calendar-header-redesigned{padding:16px}.header-top-row{flex-direction:column;gap:16px;margin-bottom:16px}.calendar-nav{order:2;width:100%;justify-content:center}.month-year-container-redesigned{order:1}.header-controls{order:3}.header-bottom-row{flex-direction:column;gap:12px}.calendar-search-section-redesigned{width:100%}.events-stats-redesigned{align-self:center}.month-year-container-redesigned .month-year{font-size:1.5rem}}@media (max-width: 480px){.calendar-nav{flex-direction:column;gap:8px}.nav-button{width:100%;text-align:center}.month-year-container-redesigned .month-year{font-size:1.25rem}}.nav-button{background:#fff;border:1px solid #d1d5db;color:#374151;padding:8px 16px;border-radius:8px;font-weight:500;transition:all .2s ease;cursor:pointer;font-size:.875rem}.nav-button:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.nav-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.calendar-search-section-redesigned .search-bar-container{flex:1}.scroll-to-results-btn{background:#10b981;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.scroll-to-results-btn:hover{background:#059669}.no-results-message-inline{color:#6b7280;font-size:.875rem;font-style:italic;white-space:nowrap}.footer-version{margin-top:8px;padding-top:8px;border-top:1px solid #e5e7eb}.footer-version p{font-size:.75rem;color:#6b7280;margin:0;text-align:center}/ * Optimisation de la disposition générale */ .calendar-container{max-width:1400px;margin:0 auto;padding:20px}.calendar-main-header-compact{max-width:1200px;margin:0 auto 24px;background:#003d7a;border-radius:16px;padding:20px 24px;box-shadow:0 8px 25px -5px #003d7a4d}.calendar-layout-full{max-width:1200px;margin:0 auto}.calendar-content{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px -2px #0000001a;border:1px solid #e2e8f0;margin-bottom:24px}.month-view{width:100%}.calendar-grid{width:100%;max-width:none;margin:0 auto}.upcoming-events-section,.search-results-section{max-width:1200px;margin:0 auto 24px;background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px -2px #0000001a;border:1px solid #e2e8f0}.calendar-footer{max-width:1200px;margin:40px auto 0;border-radius:16px 16px 0 0}@media (max-width: 1440px){.calendar-container{max-width:95%;padding:16px}.calendar-header-redesigned,.calendar-main-header-compact,.calendar-layout-full,.upcoming-events-section,.search-results-section,.calendar-footer{max-width:95%}}@media (max-width: 768px){.calendar-container{padding:12px}.calendar-header-redesigned{padding:20px;margin-bottom:20px}.calendar-main-header-compact{padding:16px 20px;margin-bottom:20px}.calendar-content,.upcoming-events-section,.search-results-section{padding:20px;margin-bottom:20px}}.visit-stats{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#6b7280}.visit-stats.loading{opacity:.7}.stats-icon{font-size:1rem}.stats-text{font-weight:500}.visit-stats.compact{justify-content:center;padding:4px 0}.visit-stats.compact .today-badge{margin-left:8px;background:#10b981;color:#fff;padding:2px 6px;border-radius:10px;font-size:.75rem;font-weight:600}.visit-stats.detailed{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb;flex-direction:column;align-items:stretch;gap:16px}.stats-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.stats-header h4{margin:0;font-size:1.125rem;font-weight:600;color:#374151}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.stat-number{font-size:1.5rem;font-weight:700;color:#003d7a;margin-bottom:4px}.stat-label{font-size:.75rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-item{padding:8px}.stat-number{font-size:1.25rem}.visit-stats.compact{font-size:.8rem}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.visit-stats.compact .stats-text{text-align:center}.visit-stats.compact .today-badge{display:block;margin-left:0;margin-top:2px}}.stat-number{transition:all .3s ease}.stat-item:hover .stat-number{transform:scale(1.05);color:#1d4ed8}.visit-stats.loading .stats-text{animation:pulse 2s infinite}@media (max-width: 768px){.calendar-header{flex-direction:column;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-md)}.calendar-nav{order:2;width:100%;justify-content:space-between}.nav-button{min-height:44px;padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);font-size:var(--ucl-font-size-base)}.month-year{order:1;text-align:center;font-size:1.2rem}.header-controls{order:3;width:100%;justify-content:center}.header-actions{order:4;width:100%;justify-content:space-around}.calendar-day{min-height:100px;height:100px;padding:4px}.day-number{font-size:14px;margin-bottom:2px}.event-item{font-size:10px;padding:2px 4px;min-height:18px;margin-bottom:1px}.calendar-layout{flex-direction:column}.calendar-sidebar{order:2;width:100%;max-height:300px;overflow-y:auto}.calendar-filters-section{padding:var(--ucl-spacing-sm)}.filters-row{flex-direction:column;gap:var(--ucl-spacing-sm)}.filter-group-compact{width:100%}.filter-select-compact{width:100%;min-height:44px}}.calendar-day,.event-item{touch-action:manipulation}@media (hover: none) and (pointer: coarse){.nav-button,.event-item,.view-button{min-height:44px;min-width:44px}}*:focus{outline:2px solid var(--ucl-primary);outline-offset:2px;border-radius:var(--ucl-border-radius-sm)}.calendar-day:focus{background:#003d7a1a;transform:scale(1.02);z-index:10}.event-item:focus{transform:translateY(-1px) scale(1.05);box-shadow:0 4px 12px #0000004d;z-index:20}.event-item{text-shadow:0 1px 2px rgba(0,0,0,.7);font-weight:600}.nav-button:disabled{opacity:.5;cursor:not-allowed;background:var(--ucl-gray-400)}.loading-state{position:relative}.loading-state:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--ucl-gray-300);border-top:2px solid var(--ucl-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background:#ef44441a;border:1px solid var(--ucl-danger);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-md);color:var(--ucl-danger);margin:var(--ucl-spacing-md) 0;display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.error-message:before{content:"⚠️";font-size:1.2em}.success-message{background:#10b9811a;border:1px solid var(--ucl-success);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-md);color:var(--ucl-success);margin:var(--ucl-spacing-md) 0;display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.success-message:before{content:"✅";font-size:1.2em}.event-tooltip{background:#000000e6;color:#fff;padding:var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);max-width:300px;white-space:pre-line;z-index:1000;position:fixed;pointer-events:none;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.2)}@media (prefers-color-scheme: dark){:root{--ucl-bg-primary: #1e293b;--ucl-bg-secondary: #334155;--ucl-text-primary: #f1f5f9;--ucl-text-secondary: #cbd5e1;--ucl-border: #475569}.calendar-container{background:var(--ucl-bg-primary);color:var(--ucl-text-primary)}.calendar-grid,.calendar-day{background:var(--ucl-bg-secondary);border-color:var(--ucl-border)}.calendar-day:hover{background:#475569}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.event-item{border-width:2px;font-weight:700}.nav-button{border-width:2px}}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.calendar-header{animation:slideInFromTop .4s ease-out}.calendar-grid{animation:fadeInScale .5s ease-out}.sidebar-event-card{animation:slideInFromBottom .3s ease-out;animation-fill-mode:both}.sidebar-event-card:nth-child(1){animation-delay:.1s}.sidebar-event-card:nth-child(2){animation-delay:.2s}.sidebar-event-card:nth-child(3){animation-delay:.3s}.sidebar-event-card:nth-child(4){animation-delay:.4s}.sidebar-event-card:nth-child(5){animation-delay:.5s}.nav-button{position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.nav-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #003d7a4d}.nav-button:active{transform:translateY(-1px);transition:transform .1s}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.today .day-number{animation:pulse 2s ease-in-out infinite}.event-item{transition:all .3s cubic-bezier(.4,0,.2,1)}.event-item:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 20px #00000040}@keyframes shimmer{0%{background-position:-468px 0}to{background-position:468px 0}}.skeleton-day,.skeleton-event,.skeleton-button{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite}.calendar-day{transition:all .2s ease}.calendar-day:hover{background:#003d7a0d;transform:scale(1.02);box-shadow:0 4px 12px #0000001a}.calendar-day:active{transform:scale(.98);transition:transform .1s}.event-modal-backdrop{animation:fadeIn .3s ease-out}.event-modal{animation:slideInFromTop .4s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes typing{0%{width:0}to{width:100%}}.loading-message{overflow:hidden;white-space:nowrap;animation:typing 2s steps(40,end) infinite}.filter-select-compact{transition:all .2s ease}.filter-select-compact:focus{transform:scale(1.02);box-shadow:0 0 0 3px #003d7a1a}@keyframes bounceIn{0%{opacity:0;transform:scale(.3) translateY(-50px)}50%{opacity:1;transform:scale(1.05) translateY(0)}70%{transform:scale(.9)}to{transform:scale(1)}}.toast-notification{animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55)}.advanced-search-panel{animation:slideDown .3s ease-out;transform-origin:top}@keyframes slideDown{0%{opacity:0;transform:scaleY(0)}to{opacity:1;transform:scaleY(1)}}.sidebar-event-card{transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.sidebar-event-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #00000026}.sidebar-event-card:hover .sidebar-event-title{color:var(--ucl-primary)}.sidebar-event-card:focus-within{outline:2px solid var(--ucl-primary);outline-offset:2px;transform:translateY(-2px)}.live-indicator{animation:pulse 1.5s ease-in-out infinite}.calendar-content{transition:opacity .3s ease-in-out}.view-transition-enter{opacity:0;transform:translate(20px)}.view-transition-enter-active{opacity:1;transform:translate(0);transition:all .3s ease-out}.view-transition-exit{opacity:1;transform:translate(0)}.view-transition-exit-active{opacity:0;transform:translate(-20px);transition:all .3s ease-out}.nav-button{position:relative;overflow:hidden}.nav-button:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.nav-button:active:after{width:300px;height:300px}.event-item{transition:all .3s ease,background-color .2s ease,color .2s ease}.search-input:focus{box-shadow:0 0 0 3px #003d7a1a,0 0 20px #003d7a1a}.nav-button.loading{pointer-events:none;position:relative}.nav-button.loading:before{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.nav-button.loading span{opacity:0}.improved-skeleton-container{padding:var(--ucl-spacing-lg);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg)}.skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--ucl-spacing-xl)}.skeleton-title{width:300px;height:32px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite;border-radius:var(--ucl-border-radius)}.skeleton-nav{display:flex;gap:var(--ucl-spacing-md)}.skeleton-button{width:100px;height:40px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite;border-radius:var(--ucl-border-radius)}.skeleton-calendar{border-radius:var(--ucl-border-radius-lg);overflow:hidden;border:1px solid var(--ucl-gray-200)}.skeleton-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--ucl-gray-200)}.skeleton-weekday{height:40px;background:linear-gradient(90deg,#e0e0e0 25%,#d0d0d0,#e0e0e0 75%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite;border-right:1px solid var(--ucl-gray-300)}.skeleton-days{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,1fr)}.skeleton-day{height:120px;padding:8px;border-right:1px solid var(--ucl-gray-200);border-bottom:1px solid var(--ucl-gray-200);background:var(--ucl-white)}.skeleton-day-number{width:20px;height:20px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite;border-radius:50%;margin-bottom:8px}.skeleton-events{display:flex;flex-direction:column;gap:4px}.skeleton-event{height:16px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite;border-radius:var(--ucl-border-radius-sm)}.realtime-loading{position:fixed;top:20px;right:20px;background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-md);box-shadow:var(--ucl-shadow-lg);display:flex;align-items:center;gap:var(--ucl-spacing-sm);z-index:1000}.loading-spinner{width:16px;height:16px;border:2px solid var(--ucl-gray-300);border-top:2px solid var(--ucl-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-message{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary)}.toast-notification{position:fixed;bottom:20px;right:20px;background:var(--ucl-white);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-md);box-shadow:var(--ucl-shadow-lg);display:flex;align-items:center;gap:var(--ucl-spacing-sm);z-index:1100;min-width:300px;border-left:4px solid}.toast-success{border-left-color:var(--ucl-success);background:#10b9810d}.toast-error{border-left-color:var(--ucl-danger);background:#ef44440d}.toast-info{border-left-color:var(--ucl-info);background:#06b6d40d}.toast-icon{font-size:1.2em}.toast-message{flex:1;font-weight:var(--ucl-font-weight-medium)}.toast-close{background:none;border:none;font-size:1.2em;cursor:pointer;color:var(--ucl-gray-500);padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius-sm)}.toast-close:hover{background:var(--ucl-gray-100)}.network-status{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--ucl-warning);color:var(--ucl-white);padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius);display:flex;align-items:center;gap:var(--ucl-spacing-sm);z-index:1000;font-weight:var(--ucl-font-weight-medium);box-shadow:var(--ucl-shadow-lg)}.network-icon{font-size:1.2em}.help-button{position:fixed;bottom:20px;right:20px;width:56px;height:56px;background:var(--ucl-primary);color:var(--ucl-white);border:none;border-radius:50%;cursor:pointer;box-shadow:var(--ucl-shadow-lg);display:flex;align-items:center;justify-content:center;font-size:1.5em;z-index:999;transition:all var(--ucl-transition);position:relative}.help-button:hover{background:var(--ucl-secondary);transform:scale(1.1)}.help-button.pulse{animation:pulse 2s ease-in-out infinite}.help-badge{position:absolute;top:-8px;right:-8px;background:var(--ucl-danger);color:var(--ucl-white);font-size:10px;padding:2px 6px;border-radius:10px;font-weight:var(--ucl-font-weight-bold)}.help-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--ucl-spacing-lg)}.help-tooltip{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);max-width:500px;width:100%;box-shadow:var(--ucl-shadow-xl);overflow:hidden}.help-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg);background:var(--ucl-primary);color:var(--ucl-white)}.help-header h3{margin:0;font-weight:var(--ucl-font-weight-semibold)}.help-close{background:none;border:none;color:var(--ucl-white);font-size:1.5em;cursor:pointer;padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius)}.help-close:hover{background:#fff3}.help-content{padding:var(--ucl-spacing-lg)}.help-content p{margin:0;line-height:1.6;color:var(--ucl-text-primary)}.help-footer{padding:var(--ucl-spacing-lg);border-top:1px solid var(--ucl-gray-200);display:flex;justify-content:space-between;align-items:center}.help-progress{display:flex;align-items:center;gap:var(--ucl-spacing-md)}.progress-bar{width:100px;height:4px;background:var(--ucl-gray-200);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--ucl-primary);transition:width var(--ucl-transition)}.help-actions{display:flex;gap:var(--ucl-spacing-sm)}.help-btn{padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition)}.help-btn.primary{background:var(--ucl-primary);color:var(--ucl-white);border:1px solid var(--ucl-primary)}.help-btn.primary:hover{background:var(--ucl-secondary)}.help-btn.secondary{background:var(--ucl-white);color:var(--ucl-text-secondary);border:1px solid var(--ucl-gray-300)}.help-btn.secondary:hover{background:var(--ucl-gray-50)}.help-btn:disabled{opacity:.5;cursor:not-allowed}.tooltip-container{position:relative;display:inline-block}.contextual-tooltip{position:absolute;background:#000000e6;color:var(--ucl-white);padding:var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);white-space:nowrap;z-index:1000;pointer-events:none}.contextual-tooltip.top{bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px}.contextual-tooltip.bottom{top:100%;left:50%;transform:translate(-50%);margin-top:8px}.contextual-tooltip.left{right:100%;top:50%;transform:translateY(-50%);margin-right:8px}.contextual-tooltip.right{left:100%;top:50%;transform:translateY(-50%);margin-left:8px}.faq-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--ucl-spacing-lg)}.faq-modal{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);max-width:600px;width:100%;max-height:80vh;overflow:hidden;box-shadow:var(--ucl-shadow-xl)}.faq-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg);background:var(--ucl-primary);color:var(--ucl-white)}.faq-close{background:none;border:none;color:var(--ucl-white);font-size:1.5em;cursor:pointer;padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius)}.faq-close:hover{background:#fff3}.faq-content{padding:var(--ucl-spacing-lg);max-height:60vh;overflow-y:auto}.faq-item{border-bottom:1px solid var(--ucl-gray-200)}.faq-item:last-child{border-bottom:none}.faq-question{width:100%;background:none;border:none;padding:var(--ucl-spacing-md) 0;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-primary);transition:all var(--ucl-transition)}.faq-question:hover,.faq-question.active{color:var(--ucl-primary)}.faq-toggle{font-size:1.2em;font-weight:var(--ucl-font-weight-bold)}.faq-answer{padding-bottom:var(--ucl-spacing-md);animation:slideDown .3s ease-out}.faq-answer p{margin:0;line-height:1.6;color:var(--ucl-text-secondary)}@media (max-width: 768px){.help-overlay{padding:var(--ucl-spacing-md)}.help-tooltip{max-width:none}.help-footer{flex-direction:column;gap:var(--ucl-spacing-md);align-items:stretch}.help-actions{justify-content:space-between}.faq-modal-backdrop{padding:var(--ucl-spacing-md)}}.export-button{background:var(--ucl-success);border-color:var(--ucl-success)}.export-button:hover{background:#059669;border-color:#059669}.export-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1200;padding:var(--ucl-spacing-lg)}.export-modal{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);max-width:600px;width:100%;max-height:90vh;overflow:hidden;box-shadow:var(--ucl-shadow-xl);border:2px solid var(--ucl-primary);animation:modalSlideIn .3s ease-out}.export-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg);background:var(--ucl-primary);color:var(--ucl-white)}.export-modal-header h3{margin:0;font-weight:var(--ucl-font-weight-semibold)}.export-modal-close{background:none;border:none;color:var(--ucl-white);font-size:1.5em;cursor:pointer;padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius)}.export-modal-close:hover{background:#fff3}.export-modal-content{padding:var(--ucl-spacing-lg);max-height:60vh;overflow-y:auto;background:var(--ucl-white);position:relative}.export-option-group{margin-bottom:var(--ucl-spacing-lg)}.export-option-group>label{display:block;font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);margin-bottom:var(--ucl-spacing-sm);text-align:left;font-size:var(--ucl-font-size-base)}.export-format-options{display:flex;flex-direction:column;gap:var(--ucl-spacing-sm);text-align:left}.export-radio-option,.export-checkbox-option{display:flex;align-items:flex-start;gap:var(--ucl-spacing-sm);cursor:pointer;padding:var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);transition:all var(--ucl-transition);background:var(--ucl-white);border:1px solid var(--ucl-gray-300);margin-bottom:var(--ucl-spacing-sm);text-align:left;color:var(--ucl-text-primary)}.export-radio-option:hover,.export-checkbox-option:hover{background:var(--ucl-gray-50);border-color:var(--ucl-primary);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.export-radio-option input,.export-checkbox-option input{width:18px;height:18px;accent-color:var(--ucl-primary);margin-top:2px;flex-shrink:0}.export-date-range{display:grid;grid-template-columns:1fr 1fr;gap:var(--ucl-spacing-md);margin-top:var(--ucl-spacing-md);padding:var(--ucl-spacing-md);background:var(--ucl-gray-50);border-radius:var(--ucl-border-radius)}.export-date-field{display:flex;flex-direction:column;gap:var(--ucl-spacing-xs)}.export-date-field label{font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-primary);font-size:var(--ucl-font-size-sm);text-align:left}.export-date-field input{padding:var(--ucl-spacing-sm);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);font-family:var(--ucl-font-family)}.export-date-field input:focus{outline:none;border-color:var(--ucl-primary);box-shadow:0 0 0 2px #003d7a1a}.export-checkboxes{display:flex;flex-direction:column;gap:var(--ucl-spacing-sm);text-align:left}.export-preview{background:var(--ucl-gray-50);padding:var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);border-left:3px solid var(--ucl-primary);text-align:left}.export-preview p{margin:0;color:var(--ucl-text-primary);font-weight:var(--ucl-font-weight-medium)}.export-modal-footer{display:flex;justify-content:flex-end;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-lg);border-top:1px solid var(--ucl-gray-200);background:var(--ucl-gray-50)}.export-btn-cancel,.export-btn-confirm{padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition)}.export-btn-cancel{background:var(--ucl-white);color:var(--ucl-text-secondary);border:1px solid var(--ucl-gray-300)}.export-btn-cancel:hover{background:var(--ucl-gray-50);border-color:var(--ucl-gray-400)}.export-btn-confirm{background:var(--ucl-primary);color:var(--ucl-white);border:1px solid var(--ucl-primary)}.export-btn-confirm:hover{background:var(--ucl-secondary);border-color:var(--ucl-secondary)}@media (max-width: 768px){.export-modal-backdrop{padding:var(--ucl-spacing-md)}.export-date-range{grid-template-columns:1fr}.export-modal-footer{flex-direction:column}.export-btn-cancel,.export-btn-confirm{width:100%}}.export-option-description{font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600);margin-top:4px;font-style:italic;line-height:1.4;text-align:left}.export-option-group>label{font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-bold)}.help-overlay,.faq-modal-backdrop{z-index:1150}.export-modal-backdrop{z-index:1200}@media (max-width: 768px){.export-modal{margin:var(--ucl-spacing-md);max-width:calc(100vw - 2 * var(--ucl-spacing-md))}.export-modal-content{padding:var(--ucl-spacing-md)}.toast-notification{top:60px;right:10px;left:10px;min-width:auto}}.export-option-content{display:flex;flex-direction:column;text-align:left;width:100%}.export-option-title{font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-text-primary);font-size:var(--ucl-font-size-base);margin-bottom:4px}.export-modal *{color:var(--ucl-text-primary)}.export-modal label,.export-modal span:not(.export-option-description){color:var(--ucl-text-primary)!important}.export-radio-option:hover .export-option-title,.export-checkbox-option:hover span{color:var(--ucl-primary)}.export-date-field input{color:var(--ucl-text-primary);background:var(--ucl-white)}.export-option-group{margin-bottom:var(--ucl-spacing-xl);text-align:left}.export-option-group:last-child{margin-bottom:var(--ucl-spacing-lg)}.export-preview-events{margin-top:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm);background:var(--ucl-gray-100);border-radius:var(--ucl-border-radius-sm)}.export-preview-events ul{margin:var(--ucl-spacing-xs) 0 0 var(--ucl-spacing-md);padding:0}.export-preview-events li{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);margin-bottom:2px}.export-preview-empty{margin-top:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm);background:#ef44441a;border-radius:var(--ucl-border-radius-sm);border:1px solid rgba(239,68,68,.2)}.loading-screen{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#003d7a,#06c);display:flex;align-items:center;justify-content:center;z-index:9999;color:#fff}.loading-content{text-align:center;max-width:500px;width:90%;padding:var(--ucl-spacing-xl)}.loading-logo{margin-bottom:var(--ucl-spacing-xl)}.ucl-logo{font-size:4rem;margin-bottom:var(--ucl-spacing-md);animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.loading-title{font-size:2.5rem;font-weight:700;margin:0 0 var(--ucl-spacing-sm) 0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.loading-subtitle{font-size:1.1rem;margin:0 0 var(--ucl-spacing-xl) 0;opacity:.9;font-weight:400}.loading-progress-container{margin-bottom:var(--ucl-spacing-xl)}.loading-progress-bar{width:100%;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:var(--ucl-spacing-sm)}.loading-progress-fill{height:100%;background:linear-gradient(90deg,#fff,#e0f2fe);border-radius:4px;transition:width .3s ease;animation:progressShimmer 2s ease-in-out infinite}@keyframes progressShimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.loading-percentage{font-size:var(--ucl-font-size-sm);font-weight:600;opacity:.8}.loading-message{display:flex;align-items:center;justify-content:center;gap:var(--ucl-spacing-sm);margin-bottom:var(--ucl-spacing-xl)}.loading-text{font-size:var(--ucl-font-size-base);font-weight:500}.loading-dots{display:flex;gap:4px}.loading-dots span{width:6px;height:6px;background:#fff;border-radius:50%;animation:loadingDots 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes loadingDots{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.loading-tips{margin-bottom:var(--ucl-spacing-xl)}.loading-tip{display:flex;align-items:center;justify-content:flex-start;gap:var(--ucl-spacing-sm);margin-bottom:var(--ucl-spacing-md);padding:var(--ucl-spacing-sm);background:#ffffff1a;border-radius:var(--ucl-border-radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:tipSlideIn .5s ease-out;animation-fill-mode:both}.loading-tip:nth-child(1){animation-delay:1s}.loading-tip:nth-child(2){animation-delay:1.5s}.loading-tip:nth-child(3){animation-delay:2s}@keyframes tipSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.tip-icon{font-size:1.2em;flex-shrink:0}.loading-tip span:last-child{font-size:var(--ucl-font-size-sm);line-height:1.4;text-align:left}.loading-footer{opacity:.7;font-size:var(--ucl-font-size-sm);animation:fadeInUp 1s ease-out 2.5s both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:.7;transform:translateY(0)}}@media (max-width: 768px){.loading-content{padding:var(--ucl-spacing-lg)}.loading-title{font-size:2rem}.ucl-logo{font-size:3rem}.loading-tip{flex-direction:column;text-align:center;gap:var(--ucl-spacing-xs)}}.loading-screen{animation:loadingScreenFadeIn .5s ease-out}@keyframes loadingScreenFadeIn{0%{opacity:0}to{opacity:1}}.loading-screen.fade-out{animation:loadingScreenFadeOut .5s ease-out forwards}@keyframes loadingScreenFadeOut{0%{opacity:1}to{opacity:0}}.text-formatter-url{color:var(--typography-url-color);text-decoration:underline;text-decoration-color:#2563eb66;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease;cursor:pointer;font-weight:500}.text-formatter-url:hover{color:var(--typography-url-hover-color);text-decoration-color:var(--typography-url-hover-color);text-decoration-thickness:2px;transform:translateY(-1px)}.text-formatter-url:focus{outline:2px solid var(--typography-url-color);outline-offset:2px;border-radius:2px}.text-formatter-email{color:var(--typography-email-color);text-decoration:underline;text-decoration-color:#05966966;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease;cursor:pointer;font-weight:500}.text-formatter-email:hover{color:var(--typography-email-hover-color);text-decoration-color:var(--typography-email-hover-color);text-decoration-thickness:2px;transform:translateY(-1px)}.text-formatter-email:focus{outline:2px solid var(--typography-email-color);outline-offset:2px;border-radius:2px}.text-formatter-phone{color:var(--typography-phone-color);text-decoration:underline;text-decoration-color:#7c3aed66;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease;cursor:pointer;font-weight:500}.text-formatter-phone:hover{color:var(--typography-phone-hover-color);text-decoration-color:var(--typography-phone-hover-color);text-decoration-thickness:2px;transform:translateY(-1px)}.text-formatter-phone:focus{outline:2px solid var(--typography-phone-color);outline-offset:2px;border-radius:2px}.text-formatter-date{background-color:var(--typography-date-bg);color:var(--typography-date-color);padding:2px 6px;border-radius:4px;font-weight:600;font-size:.9em;border:1px solid rgba(251,191,36,.3);display:inline-block;line-height:1.2}.text-formatter-time{background-color:var(--typography-time-bg);color:var(--typography-time-color);padding:2px 6px;border-radius:4px;font-weight:600;font-size:.9em;border:1px solid rgba(139,92,246,.3);display:inline-block;line-height:1.2}.text-formatter-important{background-color:var(--typography-important-bg);color:var(--typography-important-color);padding:2px 8px;border-radius:4px;font-weight:700;text-transform:uppercase;font-size:.85em;letter-spacing:.05em;border:1px solid rgba(239,68,68,.3);display:inline-block;line-height:1.2;animation:pulse 2s infinite}@media (prefers-color-scheme: dark){.text-formatter-url{color:var(--typography-dark-url-color)}.text-formatter-url:hover{color:var(--typography-dark-url-hover-color)}.text-formatter-email{color:var(--typography-dark-email-color)}.text-formatter-email:hover{color:var(--typography-dark-email-hover-color)}.text-formatter-phone{color:var(--typography-dark-phone-color)}.text-formatter-phone:hover{color:var(--typography-dark-phone-hover-color)}.text-formatter-date{background-color:var(--typography-dark-date-bg);color:var(--typography-dark-date-color);border-color:#fbbf2466}.text-formatter-time{background-color:var(--typography-dark-time-bg);color:var(--typography-dark-time-color);border-color:#8b5cf666}.text-formatter-important{background-color:var(--typography-dark-important-bg);color:var(--typography-dark-important-color);border-color:#ef444466}}@media (prefers-contrast: high){.text-formatter-url,.text-formatter-email,.text-formatter-phone{text-decoration-thickness:2px;font-weight:600}.text-formatter-date,.text-formatter-time,.text-formatter-important{border-width:2px;font-weight:700}}@media (prefers-reduced-motion: reduce){.text-formatter-url,.text-formatter-email,.text-formatter-phone{transition:none}.text-formatter-url:hover,.text-formatter-email:hover,.text-formatter-phone:hover{transform:none}.text-formatter-important{animation:none}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi),(min-resolution: 2dppx){.text-formatter-url,.text-formatter-email,.text-formatter-phone{text-decoration-thickness:.5px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.text-formatter-url:hover,.text-formatter-email:hover,.text-formatter-phone:hover{text-decoration-thickness:1px}.text-formatter-date,.text-formatter-time,.text-formatter-important{border-width:.5px}}@media (-webkit-min-device-pixel-ratio: 3),(min-resolution: 288dpi),(min-resolution: 3dppx){.text-formatter-url,.text-formatter-email,.text-formatter-phone{font-feature-settings:"kern" 1,"liga" 1,"calt" 1;font-variant-ligatures:common-ligatures}}.text-formatter-paragraph-compact{margin:.25rem 0;line-height:1.4}.text-formatter-paragraph-normal{margin:.5rem 0;line-height:1.5}.text-formatter-paragraph-spacious{margin:.75rem 0;line-height:1.6}.text-formatter-paragraph-compact:first-child,.text-formatter-paragraph-normal:first-child,.text-formatter-paragraph-spacious:first-child{margin-top:0}.text-formatter-paragraph-compact:last-child,.text-formatter-paragraph-normal:last-child,.text-formatter-paragraph-spacious:last-child{margin-bottom:0}.text-formatter-list{display:flex;align-items:flex-start;margin:.25rem 0;line-height:1.4}.text-formatter-list:first-child{margin-top:0}.text-formatter-list:last-child{margin-bottom:0}.text-formatter-bullet{color:#6b7280;font-weight:700;margin-right:.5rem;flex-shrink:0;-webkit-user-select:none;user-select:none}.text-formatter-list-content{flex:1;min-width:0}.text-formatter-list-level-0{padding-left:0}.text-formatter-list-level-1{padding-left:1rem}.text-formatter-list-level-2{padding-left:2rem}.text-formatter-list-level-3{padding-left:3rem}.text-formatter-list-level-4{padding-left:4rem}.text-formatter-list-bullets .text-formatter-bullet{color:#3b82f6}.text-formatter-list-numbers .text-formatter-bullet{color:#059669;font-variant-numeric:tabular-nums}.text-formatter-list-dashes .text-formatter-bullet{color:#6b7280}@media (prefers-color-scheme: dark){.text-formatter-bullet{color:#9ca3af}.text-formatter-list-bullets .text-formatter-bullet{color:#60a5fa}.text-formatter-list-numbers .text-formatter-bullet{color:#34d399}.text-formatter-list-dashes .text-formatter-bullet{color:#9ca3af}}@media (prefers-contrast: high){.text-formatter-bullet{font-weight:900}.text-formatter-list{border-left:2px solid transparent}.text-formatter-list-level-1,.text-formatter-list-level-2,.text-formatter-list-level-3,.text-formatter-list-level-4{border-left-color:currentColor;border-left-width:1px}}@media (max-width: 640px){.text-formatter-list-level-1{padding-left:.75rem}.text-formatter-list-level-2{padding-left:1.5rem}.text-formatter-list-level-3{padding-left:2.25rem}.text-formatter-list-level-4{padding-left:3rem}.text-formatter-bullet{margin-right:.375rem}}@media print{.text-formatter-paragraph-compact,.text-formatter-paragraph-normal,.text-formatter-paragraph-spacious{margin:.25rem 0}.text-formatter-list{break-inside:avoid}.text-formatter-bullet{color:#000!important}}.responsive-text{font-family:var(--typography-font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto}.responsive-text--title{font-size:var(--typography-mobile-title-size);line-height:var(--typography-mobile-title-height);font-weight:var(--typography-mobile-title-weight);letter-spacing:var(--typography-mobile-title-spacing);color:var(--ucl-text-primary, #1a1a1a);font-family:var(--typography-font-family)}.responsive-text--description{font-size:var(--typography-mobile-description-size);line-height:var(--typography-mobile-description-height);font-weight:var(--typography-mobile-description-weight);letter-spacing:var(--typography-mobile-description-spacing);color:var(--ucl-text-secondary, #4a4a4a);font-family:var(--typography-font-family)}.responsive-text--metadata{font-size:var(--typography-mobile-metadata-size);line-height:var(--typography-mobile-metadata-height);font-weight:var(--typography-mobile-metadata-weight);letter-spacing:var(--typography-mobile-metadata-spacing);color:var(--ucl-text-muted, #6a6a6a);font-family:var(--typography-font-family);text-transform:uppercase}@media (min-width: 768px){.responsive-text--title{font-size:var(--typography-tablet-title-size);line-height:var(--typography-tablet-title-height);font-weight:var(--typography-tablet-title-weight);letter-spacing:var(--typography-tablet-title-spacing)}}@media (min-width: 1024px){.responsive-text--title{font-size:var(--typography-desktop-title-size);line-height:var(--typography-desktop-title-height);font-weight:var(--typography-desktop-title-weight);letter-spacing:var(--typography-desktop-title-spacing)}}@media (min-width: 1440px){.responsive-text--title{font-size:var(--typography-tv-title-size);line-height:var(--typography-tv-title-height);font-weight:var(--typography-tv-title-weight);letter-spacing:var(--typography-tv-title-spacing)}}@media (min-width: 768px){.responsive-text--description{font-size:var(--typography-tablet-description-size);line-height:var(--typography-tablet-description-height);font-weight:var(--typography-tablet-description-weight);letter-spacing:var(--typography-tablet-description-spacing)}}@media (min-width: 1024px){.responsive-text--description{font-size:var(--typography-desktop-description-size);line-height:var(--typography-desktop-description-height);font-weight:var(--typography-desktop-description-weight);letter-spacing:var(--typography-desktop-description-spacing)}}@media (min-width: 1440px){.responsive-text--description{font-size:var(--typography-tv-description-size);line-height:var(--typography-tv-description-height);font-weight:var(--typography-tv-description-weight);letter-spacing:var(--typography-tv-description-spacing)}}@media (min-width: 768px){.responsive-text--metadata{font-size:var(--typography-tablet-metadata-size);line-height:var(--typography-tablet-metadata-height);font-weight:var(--typography-tablet-metadata-weight);letter-spacing:var(--typography-tablet-metadata-spacing)}}@media (min-width: 1024px){.responsive-text--metadata{font-size:var(--typography-desktop-metadata-size);line-height:var(--typography-desktop-metadata-height);font-weight:var(--typography-desktop-metadata-weight);letter-spacing:var(--typography-desktop-metadata-spacing)}}@media (min-width: 1440px){.responsive-text--metadata{font-size:var(--typography-tv-metadata-size);line-height:var(--typography-tv-metadata-height);font-weight:var(--typography-tv-metadata-weight);letter-spacing:var(--typography-tv-metadata-spacing)}}.responsive-text--mobile,.responsive-text--tablet{-webkit-text-size-adjust:100%;text-size-adjust:100%}.responsive-text--desktop{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.responsive-text--tv{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.responsive-text{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (prefers-reduced-motion: reduce){.responsive-text{transition:none}}@media (prefers-contrast: high){.responsive-text--title{color:var(--text-primary-high-contrast, #000000)}.responsive-text--description{color:var(--text-secondary-high-contrast, #000000)}.responsive-text--metadata{color:var(--text-tertiary-high-contrast, #000000)}}@media print{.responsive-text{color:#000!important;-webkit-print-color-adjust:exact;color-adjust:exact}.responsive-text--title{font-size:14pt!important;line-height:1.2!important}.responsive-text--description{font-size:11pt!important;line-height:1.4!important}.responsive-text--metadata{font-size:9pt!important;line-height:1.3!important}}.expandable-text{position:relative;width:100%}.expandable-text__content{position:relative;overflow:hidden}.expandable-text__text{transition:max-height .3s ease-in-out}.expandable-text--collapsed .expandable-text__text{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.expandable-text--expanded .expandable-text__text{display:block;-webkit-line-clamp:unset;-webkit-box-orient:unset;overflow:visible;text-overflow:unset}.expandable-text__overflow-indicator{position:absolute;bottom:0;right:0;pointer-events:none;z-index:1}.expandable-text__fade-gradient{position:absolute;bottom:0;right:0;width:60px;height:1.5em;background:linear-gradient(to right,transparent 0%,var(--background-color, #ffffff) 70%,var(--background-color, #ffffff) 100%);pointer-events:none}.expandable-text__overflow-dots{position:absolute;bottom:0;right:0;padding:0 4px;background:var(--background-color, #ffffff);color:var(--text-secondary, #6b7280);font-weight:600;font-size:.9em;line-height:1.5}.expandable-text__toggle-button{display:inline-flex;align-items:center;gap:.25rem;margin-top:.5rem;padding:.25rem .5rem;background:transparent;border:1px solid var(--border-color, #d1d5db);border-radius:.375rem;color:var(--text-primary, #374151);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.expandable-text__toggle-button:hover{background:var(--hover-background, #f9fafb);border-color:var(--hover-border, #9ca3af);color:var(--hover-text, #111827)}.expandable-text__toggle-button:focus{outline:2px solid var(--focus-color, #3b82f6);outline-offset:2px}.expandable-text__toggle-button:active{background:var(--active-background, #f3f4f6);transform:translateY(1px)}.expandable-text__toggle-text{font-size:inherit;line-height:1}.expandable-text__toggle-icon{font-size:.75rem;line-height:1;transition:transform .2s ease}.expandable-text__toggle-button:hover .expandable-text__toggle-icon{transform:scale(1.1)}.expandable-text--title .expandable-text__toggle-button{font-size:.8rem;margin-top:.375rem}.expandable-text--description .expandable-text__toggle-button{font-size:.875rem;margin-top:.5rem}.expandable-text--metadata .expandable-text__toggle-button{font-size:.75rem;margin-top:.25rem;padding:.125rem .375rem}@media (max-width: 768px){.expandable-text__toggle-button{font-size:.8rem;padding:.375rem .75rem;margin-top:.75rem}.expandable-text__fade-gradient{width:50px}}@media (min-width: 1920px){.expandable-text__toggle-button{font-size:1rem;padding:.5rem 1rem;margin-top:.75rem}.expandable-text__fade-gradient{width:80px;height:2em}}@media (prefers-color-scheme: dark){.expandable-text__fade-gradient{background:linear-gradient(to right,transparent 0%,var(--background-color, #1f2937) 70%,var(--background-color, #1f2937) 100%)}.expandable-text__overflow-dots{background:var(--background-color, #1f2937);color:var(--text-secondary, #9ca3af)}.expandable-text__toggle-button{border-color:var(--border-color, #4b5563);color:var(--text-primary, #f9fafb)}.expandable-text__toggle-button:hover{background:var(--hover-background, #374151);border-color:var(--hover-border, #6b7280);color:var(--hover-text, #ffffff)}.expandable-text__toggle-button:active{background:var(--active-background, #4b5563)}}@media (prefers-contrast: high){.expandable-text__toggle-button{border-width:2px;font-weight:600}.expandable-text__overflow-dots{font-weight:900;text-shadow:0 0 1px currentColor}.expandable-text__fade-gradient{background:linear-gradient(to right,transparent 0%,var(--background-color, #ffffff) 50%,var(--background-color, #ffffff) 100%)}}@media (prefers-reduced-motion: reduce){.expandable-text__text,.expandable-text__toggle-icon,.expandable-text__toggle-button{transition:none}.expandable-text__toggle-button:active{transform:none}}@media print{.expandable-text__toggle-button,.expandable-text__overflow-indicator{display:none}.expandable-text--collapsed .expandable-text__text{display:block;-webkit-line-clamp:unset;-webkit-box-orient:unset;overflow:visible;text-overflow:unset}}@keyframes expandText{0%{max-height:0;opacity:0}to{max-height:1000px;opacity:1}}@keyframes collapseText{0%{max-height:1000px;opacity:1}to{max-height:0;opacity:0}}.expandable-text--expanded .expandable-text__text{animation:expandText .3s ease-out}.expandable-text--collapsed .expandable-text__text{animation:collapseText .3s ease-in}.expandable-text__toggle-button:focus-visible{outline:2px solid var(--focus-color, #3b82f6);outline-offset:2px;border-color:var(--focus-color, #3b82f6)}.expandable-text--loading .expandable-text__text{opacity:.6;pointer-events:none}.expandable-text--loading .expandable-text__toggle-button{opacity:.5;cursor:not-allowed}.expandable-text--error .expandable-text__text{color:var(--error-color, #dc2626);border-left:3px solid var(--error-color, #dc2626);padding-left:.5rem}.expandable-text__text{word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto}.expandable-text__text .text-formatter-url,.expandable-text__text .text-formatter-email{word-break:break-all;overflow-wrap:break-word}.expandable-text__text{word-break:break-word}.expandable-text--mobile .expandable-text__toggle-button{font-size:.875rem;padding:.5rem .75rem;border-radius:.5rem}.expandable-text--tablet .expandable-text__toggle-button{font-size:.875rem;padding:.375rem .625rem}.expandable-text--desktop .expandable-text__toggle-button{font-size:.875rem;padding:.25rem .5rem}.expandable-text--tv .expandable-text__toggle-button{font-size:1.125rem;padding:.625rem 1rem;border-radius:.5rem}:root{--typography-font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--typography-font-family-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--typography-mobile-title-size: 16px;--typography-mobile-title-height: 1.3;--typography-mobile-title-weight: 600;--typography-mobile-title-spacing: -.01em;--typography-mobile-description-size: 13px;--typography-mobile-description-height: 1.4;--typography-mobile-description-weight: 400;--typography-mobile-description-spacing: 0;--typography-mobile-metadata-size: 11px;--typography-mobile-metadata-height: 1.3;--typography-mobile-metadata-weight: 500;--typography-mobile-metadata-spacing: .025em;--typography-tablet-title-size: 18px;--typography-tablet-title-height: 1.3;--typography-tablet-title-weight: 600;--typography-tablet-title-spacing: -.01em;--typography-tablet-description-size: 14px;--typography-tablet-description-height: 1.5;--typography-tablet-description-weight: 400;--typography-tablet-description-spacing: 0;--typography-tablet-metadata-size: 12px;--typography-tablet-metadata-height: 1.3;--typography-tablet-metadata-weight: 500;--typography-tablet-metadata-spacing: .025em;--typography-desktop-title-size: 20px;--typography-desktop-title-height: 1.3;--typography-desktop-title-weight: 600;--typography-desktop-title-spacing: -.015em;--typography-desktop-description-size: 15px;--typography-desktop-description-height: 1.5;--typography-desktop-description-weight: 400;--typography-desktop-description-spacing: 0;--typography-desktop-metadata-size: 13px;--typography-desktop-metadata-height: 1.3;--typography-desktop-metadata-weight: 500;--typography-desktop-metadata-spacing: .025em;--typography-tv-title-size: 28px;--typography-tv-title-height: 1.2;--typography-tv-title-weight: 700;--typography-tv-title-spacing: -.02em;--typography-tv-description-size: 18px;--typography-tv-description-height: 1.4;--typography-tv-description-weight: 400;--typography-tv-description-spacing: 0;--typography-tv-metadata-size: 16px;--typography-tv-metadata-height: 1.3;--typography-tv-metadata-weight: 500;--typography-tv-metadata-spacing: .025em;--typography-url-color: #2563eb;--typography-url-hover-color: #1d4ed8;--typography-email-color: #059669;--typography-email-hover-color: #047857;--typography-phone-color: #7c3aed;--typography-phone-hover-color: #6d28d9;--typography-date-bg: rgba(251, 191, 36, .2);--typography-date-color: #92400e;--typography-time-bg: rgba(139, 92, 246, .2);--typography-time-color: #6b21a8;--typography-important-bg: rgba(239, 68, 68, .15);--typography-important-color: #dc2626;--typography-dark-url-color: #60a5fa;--typography-dark-url-hover-color: #93c5fd;--typography-dark-email-color: #34d399;--typography-dark-email-hover-color: #6ee7b7;--typography-dark-phone-color: #a78bfa;--typography-dark-phone-hover-color: #c4b5fd;--typography-dark-date-bg: rgba(251, 191, 36, .3);--typography-dark-date-color: #fbbf24;--typography-dark-time-bg: rgba(139, 92, 246, .3);--typography-dark-time-color: #a78bfa;--typography-dark-important-bg: rgba(239, 68, 68, .25);--typography-dark-important-color: #f87171}.adaptive-typography{font-family:var(--typography-font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;-moz-hyphens:auto;-ms-hyphens:auto}.adaptive-typography--title{font-size:var(--typography-mobile-title-size);line-height:var(--typography-mobile-title-height);font-weight:var(--typography-mobile-title-weight);letter-spacing:var(--typography-mobile-title-spacing);color:var(--ucl-text-primary)}.adaptive-typography--description{font-size:var(--typography-mobile-description-size);line-height:var(--typography-mobile-description-height);font-weight:var(--typography-mobile-description-weight);letter-spacing:var(--typography-mobile-description-spacing);color:var(--ucl-text-secondary)}.adaptive-typography--metadata{font-size:var(--typography-mobile-metadata-size);line-height:var(--typography-mobile-metadata-height);font-weight:var(--typography-mobile-metadata-weight);letter-spacing:var(--typography-mobile-metadata-spacing);color:var(--ucl-text-muted);text-transform:uppercase}@media (min-width: 768px){.adaptive-typography--title{font-size:var(--typography-tablet-title-size);line-height:var(--typography-tablet-title-height);font-weight:var(--typography-tablet-title-weight);letter-spacing:var(--typography-tablet-title-spacing)}.adaptive-typography--description{font-size:var(--typography-tablet-description-size);line-height:var(--typography-tablet-description-height);font-weight:var(--typography-tablet-description-weight);letter-spacing:var(--typography-tablet-description-spacing)}.adaptive-typography--metadata{font-size:var(--typography-tablet-metadata-size);line-height:var(--typography-tablet-metadata-height);font-weight:var(--typography-tablet-metadata-weight);letter-spacing:var(--typography-tablet-metadata-spacing)}}@media (min-width: 1024px){.adaptive-typography--title{font-size:var(--typography-desktop-title-size);line-height:var(--typography-desktop-title-height);font-weight:var(--typography-desktop-title-weight);letter-spacing:var(--typography-desktop-title-spacing)}.adaptive-typography--description{font-size:var(--typography-desktop-description-size);line-height:var(--typography-desktop-description-height);font-weight:var(--typography-desktop-description-weight);letter-spacing:var(--typography-desktop-description-spacing)}.adaptive-typography--metadata{font-size:var(--typography-desktop-metadata-size);line-height:var(--typography-desktop-metadata-height);font-weight:var(--typography-desktop-metadata-weight);letter-spacing:var(--typography-desktop-metadata-spacing)}}@media (min-width: 1440px){.adaptive-typography--title{font-size:var(--typography-tv-title-size);line-height:var(--typography-tv-title-height);font-weight:var(--typography-tv-title-weight);letter-spacing:var(--typography-tv-title-spacing)}.adaptive-typography--description{font-size:var(--typography-tv-description-size);line-height:var(--typography-tv-description-height);font-weight:var(--typography-tv-description-weight);letter-spacing:var(--typography-tv-description-spacing)}.adaptive-typography--metadata{font-size:var(--typography-tv-metadata-size);line-height:var(--typography-tv-metadata-height);font-weight:var(--typography-tv-metadata-weight);letter-spacing:var(--typography-tv-metadata-spacing)}}.adaptive-typography-url{color:var(--typography-url-color);text-decoration:underline;text-decoration-color:#2563eb66;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease;cursor:pointer;font-weight:500}.adaptive-typography-url:hover{color:var(--typography-url-hover-color);text-decoration-color:var(--typography-url-hover-color);text-decoration-thickness:2px;transform:translateY(-1px)}.adaptive-typography-url:focus{outline:2px solid var(--typography-url-color);outline-offset:2px;border-radius:2px}.adaptive-typography-email{color:var(--typography-email-color);text-decoration:underline;text-decoration-color:#05966966;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease;cursor:pointer;font-weight:500}.adaptive-typography-email:hover{color:var(--typography-email-hover-color);text-decoration-color:var(--typography-email-hover-color);text-decoration-thickness:2px;transform:translateY(-1px)}.adaptive-typography-email:focus{outline:2px solid var(--typography-email-color);outline-offset:2px;border-radius:2px}.adaptive-typography-phone{color:var(--typography-phone-color);text-decoration:underline;text-decoration-color:#7c3aed66;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease;cursor:pointer;font-weight:500}.adaptive-typography-phone:hover{color:var(--typography-phone-hover-color);text-decoration-color:var(--typography-phone-hover-color);text-decoration-thickness:2px;transform:translateY(-1px)}.adaptive-typography-phone:focus{outline:2px solid var(--typography-phone-color);outline-offset:2px;border-radius:2px}.adaptive-typography-date{background-color:var(--typography-date-bg);color:var(--typography-date-color);padding:2px 6px;border-radius:4px;font-weight:600;font-size:.9em;border:1px solid rgba(251,191,36,.3);display:inline-block;line-height:1.2}.adaptive-typography-time{background-color:var(--typography-time-bg);color:var(--typography-time-color);padding:2px 6px;border-radius:4px;font-weight:600;font-size:.9em;border:1px solid rgba(139,92,246,.3);display:inline-block;line-height:1.2}.adaptive-typography-important{background-color:var(--typography-important-bg);color:var(--typography-important-color);padding:2px 8px;border-radius:4px;font-weight:700;text-transform:uppercase;font-size:.85em;letter-spacing:.05em;border:1px solid rgba(239,68,68,.3);display:inline-block;line-height:1.2;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi),(min-resolution: 2dppx){.adaptive-typography{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.adaptive-typography--title{font-weight:500}.adaptive-typography-url,.adaptive-typography-email,.adaptive-typography-phone{text-decoration-thickness:.5px}.adaptive-typography-url:hover,.adaptive-typography-email:hover,.adaptive-typography-phone:hover{text-decoration-thickness:1px}}@media (-webkit-min-device-pixel-ratio: 3),(min-resolution: 288dpi),(min-resolution: 3dppx){.adaptive-typography{font-feature-settings:"kern" 1,"liga" 1,"calt" 1;font-variant-ligatures:common-ligatures}.adaptive-typography--title{font-weight:400}}@media (prefers-color-scheme: dark){.adaptive-typography-url{color:var(--typography-dark-url-color)}.adaptive-typography-url:hover{color:var(--typography-dark-url-hover-color)}.adaptive-typography-email{color:var(--typography-dark-email-color)}.adaptive-typography-email:hover{color:var(--typography-dark-email-hover-color)}.adaptive-typography-phone{color:var(--typography-dark-phone-color)}.adaptive-typography-phone:hover{color:var(--typography-dark-phone-hover-color)}.adaptive-typography-date{background-color:var(--typography-dark-date-bg);color:var(--typography-dark-date-color);border-color:#fbbf2466}.adaptive-typography-time{background-color:var(--typography-dark-time-bg);color:var(--typography-dark-time-color);border-color:#8b5cf666}.adaptive-typography-important{background-color:var(--typography-dark-important-bg);color:var(--typography-dark-important-color);border-color:#ef444466}}@media (prefers-contrast: high){.adaptive-typography-url,.adaptive-typography-email,.adaptive-typography-phone{text-decoration-thickness:2px;font-weight:600}.adaptive-typography-date,.adaptive-typography-time,.adaptive-typography-important{border-width:2px;font-weight:700}.adaptive-typography--title{font-weight:700}.adaptive-typography--description{font-weight:500}}@media (prefers-reduced-motion: reduce){.adaptive-typography-url,.adaptive-typography-email,.adaptive-typography-phone{transition:none}.adaptive-typography-url:hover,.adaptive-typography-email:hover,.adaptive-typography-phone:hover{transform:none}.adaptive-typography-important{animation:none}}@media print{.adaptive-typography{color:#000!important;-webkit-print-color-adjust:exact;color-adjust:exact}.adaptive-typography--title{font-size:14pt!important;line-height:1.2!important;font-weight:600!important}.adaptive-typography--description{font-size:11pt!important;line-height:1.4!important;font-weight:400!important}.adaptive-typography--metadata{font-size:9pt!important;line-height:1.3!important;font-weight:500!important}.adaptive-typography-url,.adaptive-typography-email,.adaptive-typography-phone{color:#000!important;text-decoration:underline!important}.adaptive-typography-date,.adaptive-typography-time,.adaptive-typography-important{background:transparent!important;color:#000!important;border:1px solid black!important}}@media (max-width: 479px){.adaptive-typography--title{font-size:14px;line-height:1.25}.adaptive-typography--description{font-size:12px;line-height:1.4}.adaptive-typography--metadata{font-size:10px;line-height:1.3}}@media (min-width: 480px) and (max-width: 767px){.adaptive-typography--title{font-size:16px;line-height:1.3}.adaptive-typography--description{font-size:13px;line-height:1.4}.adaptive-typography--metadata{font-size:11px;line-height:1.3}}@media (min-width: 1200px) and (max-width: 1439px){.adaptive-typography--title{font-size:22px;line-height:1.25}.adaptive-typography--description{font-size:16px;line-height:1.5}.adaptive-typography--metadata{font-size:14px;line-height:1.3}}@media (min-width: 1920px){.adaptive-typography--title{font-size:32px;line-height:1.2;font-weight:700}.adaptive-typography--description{font-size:20px;line-height:1.4}.adaptive-typography--metadata{font-size:18px;line-height:1.3}}.adaptive-typography--truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adaptive-typography--truncate-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.adaptive-typography--truncate-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.adaptive-typography--light{font-weight:300}.adaptive-typography--normal{font-weight:400}.adaptive-typography--medium{font-weight:500}.adaptive-typography--semibold{font-weight:600}.adaptive-typography--bold{font-weight:700}.adaptive-typography--xs{font-size:.75em}.adaptive-typography--sm{font-size:.875em}.adaptive-typography--base{font-size:1em}.adaptive-typography--lg{font-size:1.125em}.adaptive-typography--xl{font-size:1.25em}.adaptive-typography--2xl{font-size:1.5em}.upcoming-events-section{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);margin:var(--ucl-spacing-lg) 0;overflow:hidden;border:1px solid var(--ucl-gray-200)}.upcoming-events-header{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);display:flex;justify-content:space-between;align-items:center}.upcoming-events-title{margin:0;font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold)}.events-pagination-info{font-size:var(--ucl-font-size-sm);opacity:.9;background:#fff3;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius)}.upcoming-events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-lg);max-width:100%}@media (min-width: 1200px){.upcoming-events-grid{grid-template-columns:repeat(3,1fr);max-width:1200px;margin:0 auto}}@media (min-width: 900px) and (max-width: 1199px){.upcoming-events-grid{grid-template-columns:repeat(2,1fr)}}.upcoming-event-card{background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-md);transition:all var(--ucl-transition);display:flex;flex-direction:column;gap:var(--ucl-spacing-sm)}.upcoming-event-card:hover{box-shadow:var(--ucl-shadow-md);transform:translateY(-2px);border-color:var(--ucl-primary)}.upcoming-event-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--ucl-spacing-sm);padding-bottom:var(--ucl-spacing-sm);border-bottom:1px solid var(--ucl-gray-100)}.upcoming-event-date-time{flex:1}.upcoming-event-date{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);text-transform:capitalize;margin-bottom:2px}.upcoming-event-time{font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600);font-weight:var(--ucl-font-weight-medium)}.upcoming-event-source{font-size:var(--ucl-font-size-xs);font-weight:var(--ucl-font-weight-bold);padding:4px 8px;border-radius:var(--ucl-border-radius-sm);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.upcoming-event-source-icloud{background:#ff6b6b1a;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.upcoming-event-source-outlook{background:#003d7a1a;color:var(--ucl-primary);border:1px solid rgba(0,61,122,.3)}.upcoming-event-content{flex:1;display:flex;flex-direction:column;gap:var(--ucl-spacing-xs)}.upcoming-event-title{margin:0;font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);cursor:pointer;transition:color var(--ucl-transition);line-height:1.3}.upcoming-event-title:hover{color:var(--ucl-secondary);text-decoration:underline}.upcoming-event-location{font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600);display:flex;align-items:center;gap:var(--ucl-spacing-xs)}.upcoming-event-description{font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-700);line-height:1.4;margin-top:var(--ucl-spacing-xs)}.upcoming-event-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--ucl-spacing-sm);padding-top:var(--ucl-spacing-sm);border-top:1px solid var(--ucl-gray-100)}.primary-actions{display:flex;gap:var(--ucl-spacing-xs);flex-wrap:wrap}.btn-event-details{background:var(--ucl-primary);color:var(--ucl-white);border:none;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition)}.btn-event-details:hover{background:var(--ucl-secondary);transform:translateY(-1px)}.export-buttons-compact{display:flex;gap:var(--ucl-spacing-xs)}.btn-export-compact{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-300);color:var(--ucl-gray-600);padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius);cursor:pointer;transition:all var(--ucl-transition);font-size:14px;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.btn-export-compact:hover{transform:scale(1.1)}.btn-export-compact.google:hover{background:#4285f4;color:#fff;border-color:#4285f4}.btn-export-compact.outlook:hover{background:#0078d4;color:#fff;border-color:#0078d4}.btn-export-compact.ics:hover{background:var(--ucl-primary);color:#fff;border-color:var(--ucl-primary)}.upcoming-events-pagination{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);background:var(--ucl-gray-50);border-top:1px solid var(--ucl-gray-200);gap:var(--ucl-spacing-md)}.pagination-btn{background:var(--ucl-white);border:1px solid var(--ucl-gray-300);color:var(--ucl-primary);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);cursor:pointer;transition:all var(--ucl-transition);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium)}.pagination-btn:hover:not(:disabled){background:var(--ucl-primary);color:var(--ucl-white);border-color:var(--ucl-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600);font-weight:var(--ucl-font-weight-medium)}.pagination-numbers{display:flex;gap:var(--ucl-spacing-xs)}.pagination-number{background:var(--ucl-white);border:1px solid var(--ucl-gray-300);color:var(--ucl-primary);padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius);cursor:pointer;transition:all var(--ucl-transition);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);min-width:32px;text-align:center}.pagination-number:hover{background:var(--ucl-gray-100)}.pagination-number.active{background:var(--ucl-primary);color:var(--ucl-white);border-color:var(--ucl-primary)}.no-upcoming-events{padding:var(--ucl-spacing-xxl);text-align:center;color:var(--ucl-gray-500);font-style:italic}.no-upcoming-events p{margin:0;font-size:var(--ucl-font-size-lg)}@media (max-width: 768px){.upcoming-events-grid{grid-template-columns:1fr;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-md)}.upcoming-event-header{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-xs)}.upcoming-event-source{align-self:flex-end}.upcoming-events-pagination{flex-direction:column;gap:var(--ucl-spacing-sm)}.pagination-numbers{order:-1}.primary-actions{flex-direction:column;width:100%}.btn-event-details{width:100%;text-align:center}}.event-images-preview{margin-top:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm);background:var(--ucl-gray-50);border-radius:var(--ucl-border-radius);border:1px solid var(--ucl-gray-200)}.images-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:var(--ucl-spacing-xs);margin-bottom:var(--ucl-spacing-xs)}.image-container{position:relative;aspect-ratio:1;border-radius:var(--ucl-border-radius-sm);overflow:hidden;background:var(--ucl-white);border:1px solid var(--ucl-gray-200)}.image-wrapper{position:relative;width:100%;height:100%}.event-image{width:100%;height:100%;object-fit:cover;transition:opacity var(--ucl-transition);opacity:0}.event-image.loaded{opacity:1}.event-image.loading{opacity:0}.image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;text-align:center;font-size:var(--ucl-font-size-xs);color:var(--ucl-gray-600);padding:var(--ucl-spacing-xs);box-sizing:border-box}.image-placeholder.loading{background:var(--ucl-gray-100);animation:pulse 2s ease-in-out infinite}.image-placeholder.unavailable{background:var(--ucl-gray-100);border:1px dashed var(--ucl-gray-300)}.image-placeholder span:first-child{font-size:1.2em;margin-bottom:2px}.image-placeholder small{font-size:.7em;color:var(--ucl-gray-500);margin-top:2px;line-height:1.2}.remaining-images{text-align:center;font-size:var(--ucl-font-size-xs);color:var(--ucl-gray-600);font-weight:var(--ucl-font-weight-medium);padding:var(--ucl-spacing-xs);background:var(--ucl-gray-100);border-radius:var(--ucl-border-radius-sm);margin-bottom:var(--ucl-spacing-xs)}.images-note{text-align:center;font-size:var(--ucl-font-size-xs);color:var(--ucl-primary);font-style:italic}.images-note small{display:flex;align-items:center;justify-content:center;gap:var(--ucl-spacing-xs)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.images-grid{grid-template-columns:repeat(auto-fit,minmax(60px,1fr))}.image-placeholder{font-size:.6em;padding:2px}.image-placeholder small{font-size:.6em}}.event-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--ucl-spacing-md);box-sizing:border-box;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.event-modal{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-xl);width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.event-modal-header{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);padding:var(--ucl-spacing-lg);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.event-modal-title{margin:0;font-size:var(--ucl-font-size-xl);font-weight:var(--ucl-font-weight-semibold);line-height:1.3;flex:1;padding-right:var(--ucl-spacing-md);word-wrap:break-word;overflow-wrap:break-word;color:var(--ucl-white)!important}.event-modal-close{background:#fff3;border:none;color:var(--ucl-white);width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all var(--ucl-transition);flex-shrink:0}.event-modal-content{flex:1;overflow-y:auto;padding:0}.event-modal-details{padding:var(--ucl-spacing-lg);display:flex;flex-direction:column;gap:var(--ucl-spacing-lg)}.event-detail-row{display:flex;align-items:flex-start;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);transition:background-color var(--ucl-transition);word-wrap:break-word;overflow-wrap:break-word}.event-detail-row:hover{background:var(--ucl-gray-50)}.detail-icon{font-size:20px;width:32px;text-align:center;flex-shrink:0;margin-top:2px}.detail-content{flex:1;display:flex;flex-direction:column;gap:var(--ucl-spacing-xs);min-width:0}.detail-content span{color:var(--ucl-dark);line-height:1.5;font-size:var(--ucl-font-size-base);word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.description-content{max-height:350px;overflow-y:auto;padding-right:var(--ucl-spacing-xs);word-wrap:break-word;overflow-wrap:break-word;contain:layout style}.description-content::-webkit-scrollbar-track{background:var(--ucl-gray-100);border-radius:2px}.description-content::-webkit-scrollbar-thumb{background:var(--ucl-gray-400);border-radius:2px}.btn-export-modal{display:flex;align-items:center;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);background:var(--ucl-white);color:var(--ucl-dark);cursor:pointer;transition:all var(--ucl-transition);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);text-align:left;width:100%}.btn-export-google-modal:hover{background:#4285f4;color:#fff;border-color:#4285f4}.btn-export-outlook-modal:hover{background:#0078d4;color:#fff;border-color:#0078d4}.btn-export-ics-modal:hover{background:var(--ucl-primary);color:#fff;border-color:var(--ucl-primary)}.description-content-wrapper{position:relative;max-height:350px;overflow:hidden;contain:layout}.description-content[data-has-scroll=true]{max-height:350px;overflow-y:auto;padding-right:var(--ucl-spacing-xs);word-wrap:break-word;overflow-wrap:break-word;scroll-behavior:auto;scrollbar-gutter:stable}.scroll-indicator{position:absolute;left:0;right:var(--ucl-spacing-xs);height:20px;pointer-events:none;z-index:1;opacity:0;transition:opacity .3s ease}.scroll-indicator--visible{opacity:.8}.scroll-indicator--top{top:0;background:linear-gradient(to bottom,var(--ucl-white) 0%,transparent 100%)}.scroll-indicator--bottom{bottom:0;background:linear-gradient(to top,var(--ucl-white) 0%,transparent 100%)}.description-content-wrapper:hover .scroll-indicator--visible{opacity:1}.scroll-fade{width:100%;height:100%;border-radius:var(--ucl-border-radius-sm)}.event-description-modal{line-height:1.6;color:var(--ucl-text-primary);word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;contain:layout style;white-space:normal}.event-description-modal p{margin-bottom:var(--ucl-spacing-md);line-height:1.7}.event-description-modal p:last-child{margin-bottom:0}.event-description-modal br{line-height:1.8}.event-description-modal p:has(br){margin-bottom:var(--ucl-spacing-sm)}.event-description-modal .text-formatter-paragraph-normal{margin-bottom:var(--ucl-spacing-md);line-height:1.6}.event-description-modal .text-formatter-paragraph-compact{margin-bottom:var(--ucl-spacing-sm);line-height:1.5}.event-description-modal .text-formatter-paragraph-spacious{margin-bottom:var(--ucl-spacing-lg);line-height:1.7}.event-description-modal .text-formatter-list{display:flex;align-items:flex-start;margin-bottom:var(--ucl-spacing-xs);line-height:1.5}.event-description-modal .text-formatter-bullet{color:var(--ucl-primary);font-weight:700;margin-right:var(--ucl-spacing-sm);flex-shrink:0;width:12px;text-align:center}.event-description-modal .text-formatter-list-content{flex:1}.event-description-modal .text-formatter-list-level-0{margin-left:0}.event-description-modal .text-formatter-list-level-1{margin-left:var(--ucl-spacing-md)}.event-description-modal .text-formatter-list-level-2{margin-left:calc(var(--ucl-spacing-md) * 2)}.event-description-modal .text-formatter-url{color:var(--ucl-primary);text-decoration:underline;font-weight:500}.event-description-modal .text-formatter-url:hover{color:var(--ucl-secondary);text-decoration:none}.event-description-modal .text-formatter-email{color:var(--ucl-accent);text-decoration:underline;font-weight:500}.event-description-modal .text-formatter-email:hover{color:var(--ucl-primary);text-decoration:none}.event-description-modal .text-formatter-phone{color:var(--ucl-success);text-decoration:underline;font-weight:500}.event-description-modal .text-formatter-phone:hover{color:var(--ucl-primary);text-decoration:none}.event-description-modal .text-formatter-date{background:rgba(var(--ucl-primary-rgb),.1);color:var(--ucl-primary);padding:2px 4px;border-radius:3px;font-weight:500}.event-description-modal .text-formatter-time{background:rgba(var(--ucl-secondary-rgb),.1);color:var(--ucl-secondary);padding:2px 4px;border-radius:3px;font-weight:500}.event-description-modal .text-formatter-important{background:rgba(var(--ucl-warning-rgb),.2);color:var(--ucl-warning-dark);padding:2px 4px;border-radius:3px;font-weight:600;text-transform:uppercase;font-size:.9em}.extracted-links{display:flex;flex-direction:column;gap:var(--ucl-spacing-sm);margin-top:var(--ucl-spacing-sm)}.extracted-link{background:var(--ucl-gray-50);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);overflow:hidden;transition:all var(--ucl-transition)}.extracted-link:hover{background:var(--ucl-gray-100);border-color:var(--ucl-primary);transform:translateY(-1px);box-shadow:var(--ucl-shadow-sm)}.extracted-link-anchor{display:flex;align-items:center;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);text-decoration:none;color:var(--ucl-dark);width:100%}.extracted-link-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}.extracted-link-text{flex:1;font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);word-break:break-all;line-height:1.4}.extracted-link--url .extracted-link-anchor:hover{color:var(--ucl-primary)}.extracted-link--email .extracted-link-anchor:hover{color:var(--ucl-accent)}.extracted-link--phone .extracted-link-anchor:hover{color:var(--ucl-success)}@media (max-width: 768px){.event-modal-backdrop{padding:var(--ucl-spacing-sm)}.event-modal{max-height:95vh}.event-modal-header{padding:var(--ucl-spacing-md)}.event-modal-details{padding:var(--ucl-spacing-md);gap:var(--ucl-spacing-md)}.event-detail-row{flex-direction:column;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm)}.detail-icon{align-self:flex-start}.export-buttons-modal{gap:var(--ucl-spacing-xs)}.btn-export-modal{padding:var(--ucl-spacing-sm);font-size:var(--ucl-font-size-xs)}.description-content-wrapper,.description-content[data-has-scroll=true]{max-height:300px}.extracted-links{gap:var(--ucl-spacing-xs)}.extracted-link-anchor{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm)}.extracted-link-text{font-size:var(--ucl-font-size-xs)}.event-description-modal .text-formatter-list{margin-bottom:var(--ucl-spacing-xs)}.event-description-modal .text-formatter-bullet{margin-right:var(--ucl-spacing-xs);width:10px}}@media (max-width: 480px){.event-modal-backdrop{padding:var(--ucl-spacing-xs)}.event-modal{max-height:98vh}.event-modal-header{padding:var(--ucl-spacing-sm)}.event-modal-title{font-size:var(--ucl-font-size-base)}.event-modal-details{padding:var(--ucl-spacing-sm)}}.detail-content span{word-break:break-word;overflow-wrap:anywhere}.event-modal-content{scroll-behavior:smooth}.event-modal:focus{outline:none}:root{--ucl-primary: #003d7a;--ucl-secondary: #0066cc;--ucl-accent: #4a90e2;--ucl-success: #10b981;--ucl-warning: #f59e0b;--ucl-danger: #ef4444;--ucl-info: #06b6d4;--ucl-light: #f8fafc;--ucl-white: #ffffff;--ucl-dark: #1e293b;--ucl-muted: #64748b;--ucl-gray-50: #f8fafc;--ucl-gray-100: #f1f5f9;--ucl-gray-200: #e2e8f0;--ucl-gray-300: #cbd5e1;--ucl-gray-400: #94a3b8;--ucl-gray-500: #64748b;--ucl-gray-600: #475569;--ucl-gray-700: #334155;--ucl-gray-800: #1e293b;--ucl-gray-900: #0f172a;--ucl-event-personal: #0066cc;--ucl-event-academic: #003d7a;--ucl-event-courses: #4a90e2;--ucl-event-exams: #ff6b35;--ucl-event-meetings: #7b68ee;--ucl-event-events: #e74c3c;--ucl-event-default: #6c757d;--ucl-color-1: #003d7a;--ucl-color-2: #0066cc;--ucl-color-3: #4a90e2;--ucl-color-4: #ff6b35;--ucl-color-5: #7b68ee;--ucl-color-6: #e74c3c;--ucl-color-7: #27ae60;--ucl-color-8: #f39c12;--ucl-color-9: #9b59b6;--ucl-color-10: #16a085;--ucl-font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--ucl-font-size-base: 16px;--ucl-font-size-sm: 14px;--ucl-font-size-lg: 18px;--ucl-font-size-xl: 24px;--ucl-font-weight-normal: 400;--ucl-font-weight-medium: 500;--ucl-font-weight-semibold: 600;--ucl-font-weight-bold: 700;--ucl-spacing-xs: .25rem;--ucl-spacing-sm: .5rem;--ucl-spacing-md: 1rem;--ucl-spacing-lg: 1.5rem;--ucl-spacing-xl: 2rem;--ucl-spacing-xxl: 3rem;--ucl-border-radius-sm: .25rem;--ucl-border-radius: .375rem;--ucl-border-radius-lg: .5rem;--ucl-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .03);--ucl-shadow: 0 1px 3px 0 rgba(0, 0, 0, .08), 0 1px 2px 0 rgba(0, 0, 0, .04);--ucl-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -1px rgba(0, 0, 0, .04);--ucl-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .03);--ucl-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 10px 10px -5px rgba(0, 0, 0, .02);--ucl-transition-fast: .15s ease-out;--ucl-transition: .2s ease-out;--ucl-transition-slow: .3s ease-out;--ucl-bg-primary: #ffffff;--ucl-bg-secondary: #f8fafc;--ucl-bg-tertiary: #f1f5f9;--ucl-bg-hover: #e2e8f0;--ucl-text-primary: #1e293b;--ucl-text-secondary: #475569;--ucl-text-muted: #64748b;--ucl-border: #e2e8f0;--ucl-border-light: #f1f5f9}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;background:#fff;margin:0;padding:0}#root{display:flex;justify-content:center}body{font-family:var(--ucl-font-family);font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-normal);line-height:1.6;background:#fff;color:var(--ucl-text-primary);margin:0;padding:0;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}.calendar-container{max-width:1200px;width:100%;margin:0 auto;padding:0;animation:fadeIn var(--ucl-transition-slow);min-height:100vh;background:#f8fafc}.calendar-grid{width:100%;max-width:1400px;margin:0 auto}.calendar-layout-full{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--ucl-spacing-md)}.calendar-main-full{width:100%}.calendar-main-header{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:#fff;padding:var(--ucl-spacing-xl) 0;text-align:center;box-shadow:0 4px 20px #003d7a4d;position:relative;overflow:hidden}.calendar-main-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.3}.calendar-main-title{font-size:2.5rem;font-weight:700;margin:0 0 var(--ucl-spacing-sm) 0;position:relative;z-index:1;text-shadow:0 2px 4px rgba(0,0,0,.2)}.calendar-main-subtitle{font-size:1.1rem;font-weight:400;margin:0;opacity:.9;position:relative;z-index:1}.calendar-main-header-compact{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:#fff;padding:var(--ucl-spacing-sm) 0;text-align:center;box-shadow:0 2px 8px #003d7a33;position:relative}.calendar-main-title-compact{font-size:1.4rem;font-weight:600;margin:0;position:relative;z-index:1}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg) var(--ucl-spacing-lg);background:linear-gradient(135deg,#fff,#f8fafc);border-bottom:2px solid var(--ucl-gray-200);box-shadow:0 4px 12px #00000014;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.calendar-nav{display:flex;align-items:center;gap:var(--ucl-spacing-md)}.nav-button{background:var(--ucl-primary);color:var(--ucl-white);border:1px solid var(--ucl-primary);padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius);cursor:pointer;font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);font-family:var(--ucl-font-family);transition:all var(--ucl-transition);display:inline-flex;align-items:center;justify-content:center;text-decoration:none;min-height:40px;position:relative;overflow:hidden;box-shadow:0 2px 4px #003d7a33}.nav-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left var(--ucl-transition)}.nav-button:hover{background:var(--ucl-secondary);border-color:var(--ucl-secondary);transform:translateY(-1px);box-shadow:0 4px 12px #0066cc4d}.nav-button:hover:before{left:100%}.nav-button:active{transform:translateY(-1px);box-shadow:var(--ucl-shadow-md)}.nav-button:focus{outline:2px solid var(--ucl-accent);outline-offset:2px}.month-year{font-size:1.8rem;font-weight:var(--ucl-font-weight-bold);color:var(--ucl-primary);text-transform:capitalize;margin:0;text-shadow:0 2px 4px rgba(0,61,122,.2);background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.month-year:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--ucl-primary),var(--ucl-secondary));border-radius:2px}.calendar-grid{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-lg);overflow:hidden;border:1px solid var(--ucl-gray-200);position:relative;width:100%;max-width:1200px;margin:0 auto;min-width:800px}.calendar-grid:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#3b82f605,#8b5cf605);pointer-events:none}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%)}.weekday{padding:var(--ucl-spacing-md) var(--ucl-spacing-sm);text-align:center;font-weight:var(--ucl-font-weight-semibold);font-size:var(--ucl-font-size-sm);color:var(--ucl-white);border-right:1px solid rgba(255,255,255,.2);text-transform:uppercase;letter-spacing:.5px}.weekday:last-child{border-right:none}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,minmax(100px,120px));gap:0;width:100%}.calendar-day{min-height:100px;max-height:120px;border-right:1px solid var(--ucl-gray-200);border-bottom:1px solid var(--ucl-gray-200);padding:3px;position:relative;background:var(--ucl-white);transition:all var(--ucl-transition);display:flex;flex-direction:column;overflow:hidden;cursor:pointer}.calendar-day:hover{background:var(--ucl-gray-50);transform:scale(1.02);z-index:10;box-shadow:var(--ucl-shadow-md)}.calendar-day:last-child{border-right:none}.calendar-day.other-month{background:var(--ucl-light);color:var(--ucl-muted)}.calendar-day.other-month:hover{background:#6c757d0d}.calendar-day.today{background:linear-gradient(135deg,#003d7a14,#0066cc14);border:2px solid var(--ucl-primary);position:relative}.calendar-day.today:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--ucl-primary),var(--ucl-secondary))}.calendar-day.today .day-number{color:var(--ucl-white);font-weight:var(--ucl-font-weight-bold);background:var(--ucl-primary);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;position:relative;z-index:1}.day-number{font-weight:var(--ucl-font-weight-bold);margin-bottom:2px;font-size:12px;color:var(--ucl-dark);flex-shrink:0;line-height:1}.day-events{display:flex;flex-direction:column;gap:1px;flex:1;overflow:hidden;margin-top:2px;min-height:0}.event-item{padding:1px 3px;border-radius:2px;font-size:8px;font-weight:var(--ucl-font-weight-semibold);cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:all var(--ucl-transition);position:relative;text-shadow:0 1px 2px rgba(0,0,0,.3);border:1px solid rgba(0,0,0,.1);min-height:14px;max-height:16px;display:flex;align-items:center;line-height:1;margin-bottom:1px}.event-item:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:#0003;border-radius:0 var(--ucl-border-radius-sm) var(--ucl-border-radius-sm) 0}.event-item.more-events{background:var(--ucl-gray-500)!important;color:#fff!important;border:1px solid var(--ucl-gray-400)!important;font-style:italic;text-align:center;font-weight:var(--ucl-font-weight-medium)!important}.event-item:hover{transform:translateY(-1px) scale(1.01);box-shadow:0 4px 8px #0003;z-index:20;filter:brightness(1.1)}.event-item:active{transform:translateY(0)}.event-item.highlighted{animation:highlightPulse 2s ease-in-out infinite;position:relative;overflow:visible}.highlight-indicator{position:absolute;top:-8px;right:-8px;font-size:12px;background:var(--ucl-primary);color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;z-index:20;animation:bounce 1s ease-in-out infinite}@keyframes highlightPulse{0%,to{box-shadow:0 0 0 2px #003d7a4d,0 2px 8px #0003}50%{box-shadow:0 0 0 4px #003d7a80,0 4px 12px #0000004d}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}60%{transform:translateY(-2px)}}.agenda-view{padding:var(--ucl-spacing-lg);max-width:1000px;margin:0 auto}.agenda-controls{background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-lg);padding:var(--ucl-spacing-lg);margin-bottom:var(--ucl-spacing-lg);box-shadow:var(--ucl-shadow-sm)}.agenda-filters{display:flex;gap:var(--ucl-spacing-lg);align-items:center;flex-wrap:wrap;margin-bottom:var(--ucl-spacing-md)}.date-range-controls label{font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary);white-space:nowrap}.range-select{padding:var(--ucl-spacing-sm);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);font-family:var(--ucl-font-family);background:var(--ucl-white);color:var(--ucl-text-primary);min-width:150px}.range-select:focus{outline:none;border-color:var(--ucl-primary);box-shadow:0 0 0 2px #003d7a1a}.past-events-toggle label{display:flex;align-items:center;gap:var(--ucl-spacing-sm);cursor:pointer;font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary)}.agenda-summary{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--ucl-spacing-md)}.summary-stats{display:flex;gap:var(--ucl-spacing-lg);align-items:center}.total-events{font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary)}.page-info{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);background:var(--ucl-gray-100);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius)}.agenda-pagination{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.page-numbers{display:flex;gap:var(--ucl-spacing-xs)}.page-number{background:var(--ucl-white);border:1px solid var(--ucl-gray-300);color:var(--ucl-text-primary);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);cursor:pointer;font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);transition:all var(--ucl-transition);min-width:32px;text-align:center}.page-number:hover{background:var(--ucl-gray-50);border-color:var(--ucl-primary)}.page-number.active{background:var(--ucl-primary);color:var(--ucl-white);border-color:var(--ucl-primary)}.agenda-list{display:flex;flex-direction:column;gap:var(--ucl-spacing-lg)}.agenda-day-group{background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-lg);overflow:hidden;box-shadow:var(--ucl-shadow-sm)}.agenda-date-header{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);display:flex;justify-content:space-between;align-items:center}.events-count{font-size:var(--ucl-font-size-sm);background:var(--ucl-white);color:var(--ucl-primary);padding:var(--ucl-spacing-xs) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius-lg);font-weight:var(--ucl-font-weight-bold);border:2px solid var(--ucl-primary);box-shadow:0 2px 4px #003d7a33;min-width:60px;text-align:center}.agenda-events{padding:var(--ucl-spacing-md);display:flex;flex-direction:column;gap:var(--ucl-spacing-md)}.agenda-event-card{border:1px solid var(--ucl-gray-200);border-left:3px solid var(--ucl-primary);border-radius:var(--ucl-border-radius);background:var(--ucl-white);transition:all var(--ucl-transition);overflow:hidden}.agenda-event-card.highlighted{border-left-color:var(--ucl-accent);box-shadow:0 0 0 2px #003d7a33;animation:highlightPulse 2s ease-in-out infinite}.agenda-event-card.selected{border-left-color:var(--ucl-success);background:#10b9810d;box-shadow:0 0 0 2px #10b9814d}.agenda-event-card.today{background:#003d7a05;border-color:var(--ucl-primary)}.agenda-event-card.past{opacity:.8;background:var(--ucl-gray-50)}.agenda-event-header{padding:var(--ucl-spacing-md);display:flex;align-items:center;gap:var(--ucl-spacing-md);cursor:pointer;transition:background-color var(--ucl-transition)}.agenda-event-header:hover{background:var(--ucl-gray-50)}.event-time-indicator{display:flex;align-items:center;gap:var(--ucl-spacing-sm);min-width:120px}.time-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.event-time{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary);white-space:nowrap}.event-main-info{flex:1;min-width:0}.event-title{margin:0 0 var(--ucl-spacing-xs) 0;font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);line-height:1.3;word-wrap:break-word}.search-indicator{color:var(--ucl-accent);font-size:14px}.event-source-badge{font-size:var(--ucl-font-size-sm);padding:2px 8px;border-radius:var(--ucl-border-radius-sm);font-weight:var(--ucl-font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.agenda-event-card.icloud .event-source-badge{background:#ff6b6b1a;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.agenda-event-card.outlook .event-source-badge{background:#003d7a1a;color:var(--ucl-primary);border:1px solid rgba(0,61,122,.3)}.event-actions-header{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.expand-button,.btn-view-modal{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-300);color:var(--ucl-text-secondary);padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius);cursor:pointer;transition:all var(--ucl-transition);font-size:var(--ucl-font-size-sm);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.expand-button:hover,.btn-view-modal:hover{background:var(--ucl-primary);color:var(--ucl-white);border-color:var(--ucl-primary);transform:scale(1.05)}.agenda-event-details{padding:var(--ucl-spacing-md);border-top:1px solid var(--ucl-gray-100);background:var(--ucl-gray-50);animation:slideDown .3s ease-out}.detail-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;margin-top:2px}.detail-text{flex:1;line-height:1.5;color:var(--ucl-text-primary)}.no-events{text-align:center;padding:var(--ucl-spacing-xxl);color:var(--ucl-text-secondary);background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-lg);font-style:italic}@media (max-width: 1400px){.calendar-grid{max-width:1000px;min-width:700px}.calendar-days{grid-template-rows:repeat(6,minmax(90px,110px))}.calendar-day{min-height:90px;max-height:110px;padding:2px}.day-number{font-size:11px}.event-item{font-size:7px;min-height:12px;max-height:14px;padding:1px 2px}}@media (max-width: 1200px){.calendar-grid{max-width:900px;min-width:600px}.calendar-days{grid-template-rows:repeat(6,minmax(80px,100px))}.calendar-day{min-height:80px;max-height:100px;padding:2px}.day-number{font-size:10px}.event-item{font-size:7px;min-height:11px;max-height:13px}}@media (max-width: 768px){.agenda-view{padding:var(--ucl-spacing-md)}.agenda-filters{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-md)}.agenda-summary{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-sm)}.agenda-pagination{justify-content:center;flex-wrap:wrap}.agenda-event-header{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-sm)}.event-time-indicator{min-width:auto;justify-content:space-between}.event-actions-header{justify-content:flex-end}.date-title{font-size:var(--ucl-font-size-base)}.agenda-date-header{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-xs)}.events-count{align-self:flex-end}}.event-details{margin-top:var(--ucl-spacing-xl);padding:0;background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);border:1px solid rgba(0,61,122,.1);overflow:hidden;animation:slideIn .3s ease-out}.event-details-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg);background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent));color:var(--ucl-white)}.event-details-title{margin:0;font-weight:var(--ucl-font-weight-semibold);font-size:var(--ucl-font-size-lg);flex:1}.close-details-btn{background:#fff3;border:none;color:var(--ucl-white);width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease;margin-left:var(--ucl-spacing-md)}.close-details-btn:hover{background:#ffffff4d;transform:scale(1.1)}.event-details-content{padding:var(--ucl-spacing-lg)}.event-detail-row{display:flex;align-items:flex-start;margin-bottom:var(--ucl-spacing-md);padding:var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);transition:background-color .2s ease}.event-detail-row:hover{background:var(--ucl-light)}.event-detail-row:last-child{margin-bottom:0}.detail-icon{font-size:18px;margin-right:var(--ucl-spacing-md);width:24px;text-align:center;flex-shrink:0}.detail-content{display:flex;flex-direction:column;gap:var(--ucl-spacing-xs);flex:1}.detail-content strong{color:var(--ucl-primary);font-weight:var(--ucl-font-weight-semibold);font-size:var(--ucl-font-size-sm);text-transform:uppercase;letter-spacing:.5px}.detail-content span{color:var(--ucl-dark);line-height:1.5;font-size:var(--ucl-font-size-base)}.category-tag{display:inline-block!important;width:fit-content!important}.description-row{align-items:flex-start}.description-content{max-height:300px;overflow-y:auto;padding-right:var(--ucl-spacing-xs)}.description-content::-webkit-scrollbar{width:4px}.description-content::-webkit-scrollbar-track{background:var(--ucl-light);border-radius:2px}.description-content::-webkit-scrollbar-thumb{background:var(--ucl-muted);border-radius:2px}.description-content::-webkit-scrollbar-thumb:hover{background:var(--ucl-primary)}.description-paragraph{margin-bottom:var(--ucl-spacing-sm);line-height:1.6;color:var(--ucl-dark)}.description-paragraph.important-info{background:#003d7a0d;padding:var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm);border-left:3px solid var(--ucl-primary);font-weight:var(--ucl-font-weight-medium)}.description-list{margin:var(--ucl-spacing-sm) 0;padding-left:var(--ucl-spacing-lg);color:var(--ucl-dark)}.description-list li{margin-bottom:var(--ucl-spacing-xs);line-height:1.5}.description-list li:last-child{margin-bottom:0}.event-description-formatted{line-height:1.6;color:var(--ucl-text-primary);word-wrap:break-word;overflow-wrap:break-word}.event-description-formatted .description-paragraph{margin-bottom:var(--ucl-spacing-md);line-height:1.7}.event-description-formatted .description-paragraph:last-child{margin-bottom:0}.description-link{color:var(--ucl-primary);text-decoration:none;font-weight:var(--ucl-font-weight-medium);border-bottom:1px solid transparent;transition:all var(--ucl-transition);position:relative;padding:1px 2px;border-radius:var(--ucl-border-radius-sm)}.description-link:hover{background:#3b82f61a;border-bottom-color:var(--ucl-primary);transform:translateY(-1px)}.description-link:active{transform:translateY(0)}.url-link{color:var(--ucl-primary)}.url-link:before{content:"🔗";margin-right:4px;font-size:12px;opacity:.7}.url-link:hover{background:#3b82f61a;color:var(--ucl-accent)}.email-link{color:var(--ucl-info)}.email-link:before{content:"✉️";margin-right:4px;font-size:12px;opacity:.7}.email-link:hover{background:#06b6d41a;color:var(--ucl-info);border-bottom-color:var(--ucl-info)}.phone-link{color:var(--ucl-success)}.phone-link:before{content:"📞";margin-right:4px;font-size:12px;opacity:.7}.phone-link:hover{background:#10b9811a;color:var(--ucl-success);border-bottom-color:var(--ucl-success)}.description-date{color:var(--ucl-warning);font-weight:var(--ucl-font-weight-medium);background:#f59e0b1a;padding:1px 4px;border-radius:var(--ucl-border-radius-sm);font-size:.95em}.event-description-compact{font-size:var(--ucl-font-size-sm);line-height:1.5;max-height:4.5em;overflow:hidden;position:relative}.event-description-compact:after{content:"";position:absolute;bottom:0;right:0;width:30px;height:1.5em;background:linear-gradient(to right,transparent,var(--ucl-white))}.event-description-tooltip{font-size:var(--ucl-font-size-sm);line-height:1.4;max-width:300px;white-space:normal}.event-description-tooltip .description-link{color:#ffffffe6;border-bottom-color:#ffffff80}.event-description-tooltip .description-link:hover{background:#fff3;color:var(--ucl-white)}.event-preview{padding:var(--ucl-spacing-md);background:var(--ucl-white);border-radius:var(--ucl-border-radius);border:1px solid var(--ucl-gray-200);transition:all var(--ucl-transition)}.event-preview:hover{box-shadow:var(--ucl-shadow-md);transform:translateY(-1px)}.event-preview-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--ucl-spacing-sm);gap:var(--ucl-spacing-sm)}.event-preview-title{margin:0;font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);line-height:1.3;flex:1}.event-preview-time{font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600);font-weight:var(--ucl-font-weight-medium);white-space:nowrap;background:var(--ucl-gray-100);padding:2px 8px;border-radius:var(--ucl-border-radius-sm)}.event-preview-location{display:flex;align-items:center;gap:var(--ucl-spacing-xs);font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600);margin-bottom:var(--ucl-spacing-sm)}.event-preview-location .location-icon{font-size:12px;opacity:.8}.event-preview-description{margin-bottom:var(--ucl-spacing-sm)}.event-description-preview{font-size:var(--ucl-font-size-sm);line-height:1.5;color:var(--ucl-text-secondary)}.event-description-preview .description-paragraph{margin-bottom:var(--ucl-spacing-xs)}.event-description-preview .description-link{font-size:var(--ucl-font-size-sm)}.event-preview-meta{display:flex;justify-content:flex-end;align-items:center}.event-preview-category{display:inline-block;padding:2px 8px;border-radius:var(--ucl-border-radius-sm);font-size:11px;font-weight:var(--ucl-font-weight-medium);text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.event-description-formatted{font-size:var(--ucl-font-size-sm)}.description-link:before{font-size:10px}.event-description-compact{max-height:3em}.event-preview{padding:var(--ucl-spacing-sm)}.event-preview-header{flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-xs)}.event-preview-time{align-self:flex-end}.event-preview-title{font-size:var(--ucl-font-size-sm)}}.event-tooltip{position:fixed;background:var(--ucl-dark);color:var(--ucl-white);padding:var(--ucl-spacing-md);border-radius:var(--ucl-border-radius-lg);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-normal);font-family:var(--ucl-font-family);box-shadow:var(--ucl-shadow-xl);z-index:1000;pointer-events:none;transform:translate(-50%) translateY(-100%);white-space:pre-line;max-width:350px;min-width:200px;line-height:1.4;animation:tooltipFadeIn .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.event-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:var(--ucl-dark)}.event-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--ucl-spacing-md);animation:modalBackdropFadeIn .3s ease-out}.event-modal{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-xl);max-width:600px;width:100%;max-height:90vh;overflow:hidden;animation:modalSlideIn .3s ease-out;border:1px solid var(--ucl-gray-200)}.event-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg);background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent));color:var(--ucl-white);position:relative}.event-modal-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ucl-accent),var(--ucl-info),var(--ucl-accent))}.event-modal-title{margin:0;font-weight:var(--ucl-font-weight-semibold);font-size:var(--ucl-font-size-lg);flex:1;line-height:1.3;padding-right:var(--ucl-spacing-md)}.event-modal-close{background:#fff3;border:none;color:var(--ucl-white);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all var(--ucl-transition);flex-shrink:0}.event-modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.event-modal-close:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.event-modal-content{padding:var(--ucl-spacing-lg);max-height:calc(90vh - 120px);overflow-y:auto}.event-modal-content::-webkit-scrollbar{width:6px}.event-modal-content::-webkit-scrollbar-track{background:var(--ucl-gray-100);border-radius:3px}.event-modal-content::-webkit-scrollbar-thumb{background:var(--ucl-gray-300);border-radius:3px}.event-modal-content::-webkit-scrollbar-thumb:hover{background:var(--ucl-gray-400)}.event-modal-details{display:flex;flex-direction:column;gap:var(--ucl-spacing-md)}.event-description-modal{font-size:var(--ucl-font-size-base);line-height:1.7;color:var(--ucl-text-primary)}.event-description-modal .description-paragraph{margin-bottom:var(--ucl-spacing-md)}.event-description-modal .description-link{font-weight:var(--ucl-font-weight-medium);padding:2px 4px;border-radius:var(--ucl-border-radius-sm)}.event-description-modal .description-link:hover{transform:none;box-shadow:var(--ucl-shadow-sm)}@keyframes modalBackdropFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.event-modal-backdrop{padding:var(--ucl-spacing-sm)}.event-modal{max-height:95vh}.event-modal-header{padding:var(--ucl-spacing-md)}.event-modal-title{font-size:var(--ucl-font-size-base);padding-right:var(--ucl-spacing-sm)}.event-modal-close{width:32px;height:32px;font-size:16px}.event-modal-content{padding:var(--ucl-spacing-md);max-height:calc(95vh - 100px)}.event-detail-row{flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-xs)}.detail-icon{margin-right:0;margin-bottom:var(--ucl-spacing-xs)}.event-description-modal{font-size:var(--ucl-font-size-sm)}}.loading{text-align:center;padding:var(--ucl-spacing-xxl);color:var(--ucl-muted);font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-medium)}.error{text-align:center;padding:var(--ucl-spacing-xxl);color:var(--ucl-danger);background:#dc35451a;border:1px solid rgba(220,53,69,.2);border-radius:var(--ucl-border-radius-lg);margin:var(--ucl-spacing-xl) 0;border-left:4px solid var(--ucl-danger)}.skeleton-loader{padding:var(--ucl-spacing-lg);animation:fadeIn var(--ucl-transition-slow)}.skeleton-calendar-grid{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-lg);overflow:hidden;margin-bottom:var(--ucl-spacing-lg)}.skeleton-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--ucl-gray-50);border-bottom:1px solid var(--ucl-gray-200)}.skeleton-weekday{height:40px;background:linear-gradient(90deg,var(--ucl-gray-100) 25%,var(--ucl-gray-50) 50%,var(--ucl-gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-right:1px solid var(--ucl-gray-200)}.skeleton-days{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--ucl-gray-200)}.skeleton-day{background:var(--ucl-white);min-height:120px;padding:var(--ucl-spacing-sm);display:flex;flex-direction:column;gap:var(--ucl-spacing-xs)}.skeleton-day-number{width:24px;height:20px;background:linear-gradient(90deg,var(--ucl-gray-200) 25%,var(--ucl-gray-100) 50%,var(--ucl-gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--ucl-border-radius-sm)}.skeleton-event{height:16px;background:linear-gradient(90deg,var(--ucl-primary) 25%,var(--ucl-secondary) 50%,var(--ucl-primary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--ucl-border-radius-sm);opacity:.3}.skeleton-loading-text{text-align:center;color:var(--ucl-muted);font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-medium);display:flex;align-items:center;justify-content:center;gap:var(--ucl-spacing-sm)}.skeleton-pulse{width:20px;height:20px;background:var(--ucl-primary);border-radius:50%;animation:pulse 1.5s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.progress-container{padding:var(--ucl-spacing-lg);text-align:center;background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);margin:var(--ucl-spacing-lg);max-width:500px;margin-left:auto;margin-right:auto}.progress-message{color:var(--ucl-primary);font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-medium);margin-bottom:var(--ucl-spacing-md)}.progress-bar-wrapper{background:var(--ucl-gray-200);border-radius:20px;height:8px;overflow:hidden;margin-bottom:var(--ucl-spacing-sm);position:relative}.progress-bar{height:100%;background:linear-gradient(90deg,var(--ucl-primary),var(--ucl-secondary));border-radius:20px;transition:width .3s ease;position:relative;overflow:hidden}.progress-bar.indeterminate{width:100%!important;background:var(--ucl-gray-200)}.progress-bar.indeterminate .progress-bar-fill{position:absolute;top:0;left:0;height:100%;width:30%;background:linear-gradient(90deg,var(--ucl-primary),var(--ucl-secondary));border-radius:20px;animation:indeterminate 2s infinite}.progress-bar:not(.indeterminate) .progress-bar-fill{display:none}.progress-percentage{color:var(--ucl-muted);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium)}@keyframes indeterminate{0%{left:-30%}to{left:100%}}.error h3{color:var(--ucl-danger);font-weight:var(--ucl-font-weight-semibold);margin-bottom:var(--ucl-spacing-md)}.error p{margin-bottom:var(--ucl-spacing-md);line-height:1.6}.debug-section{margin-top:var(--ucl-spacing-xl);padding:var(--ucl-spacing-md);background:var(--ucl-light);border:1px solid rgba(0,61,122,.1);border-radius:var(--ucl-border-radius);font-family:Consolas,Monaco,Courier New,monospace;font-size:12px}.debug-section h4{margin-bottom:var(--ucl-spacing-sm);color:var(--ucl-primary);font-weight:var(--ucl-font-weight-semibold);font-family:var(--ucl-font-family)}.debug-section pre{white-space:pre-wrap;word-break:break-word;color:var(--ucl-dark);line-height:1.4}@media (max-width: 768px){.calendar-container{padding:var(--ucl-spacing-md)}.calendar-header{flex-direction:column;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-md)}.calendar-nav{flex-wrap:wrap;justify-content:center}.nav-button{font-size:12px;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm)}.month-year{font-size:var(--ucl-font-size-lg);text-align:center}.calendar-day{min-height:80px;padding:var(--ucl-spacing-xs)}.weekday{padding:var(--ucl-spacing-sm) var(--ucl-spacing-xs);font-size:12px}.event-item{font-size:10px;padding:1px var(--ucl-spacing-xs)}}@media (min-width: 769px) and (max-width: 1024px){.calendar-container{padding:var(--ucl-spacing-lg)}.calendar-day{min-height:100px}}*:focus{outline:2px solid var(--ucl-accent);outline-offset:2px;border-radius:var(--ucl-border-radius-sm)}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:2px solid var(--ucl-accent);outline-offset:2px;box-shadow:0 0 0 4px #3b82f61a}.high-contrast{--ucl-primary: #000080;--ucl-accent: #0066cc;--ucl-gray-500: #333333;--ucl-gray-600: #222222}.nav-button.secondary{background:var(--ucl-white);color:var(--ucl-primary);border-color:var(--ucl-primary)}.nav-button.secondary:hover{background:var(--ucl-primary);color:var(--ucl-white)}.nav-button.outline{background:transparent;color:var(--ucl-primary);border-color:var(--ucl-primary)}.nav-button.outline:hover{background:var(--ucl-primary);color:var(--ucl-white)}.fade-in{animation:fadeIn var(--ucl-transition-slow)}.slide-in{animation:slideIn var(--ucl-transition-slow)}@keyframes slideIn{0%{transform:translate(-30px);opacity:0}to{transform:translate(0);opacity:1}}.scale-in{animation:scaleIn var(--ucl-transition)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.bounce-in{animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.search-bar-container{position:relative;width:100%;max-width:500px}.search-bar{position:relative;transition:all var(--ucl-transition)}.search-bar.active{transform:scale(1.02)}.search-input-wrapper{position:relative;display:flex;align-items:center;background:var(--ucl-white);border:2px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius-lg);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);transition:all var(--ucl-transition);box-shadow:var(--ucl-shadow-sm)}.search-bar.active .search-input-wrapper{border-color:var(--ucl-primary);box-shadow:0 0 0 3px #003d7a1a}.search-icon{font-size:18px;margin-right:var(--ucl-spacing-sm);color:var(--ucl-gray-500);transition:color var(--ucl-transition)}.search-bar.active .search-icon{color:var(--ucl-primary)}.search-input{flex:1;border:none;outline:none;font-size:var(--ucl-font-size-base);font-family:var(--ucl-font-family);color:var(--ucl-text-primary);background:transparent;padding:0}.search-input::placeholder{color:var(--ucl-gray-400);font-style:italic}.search-clear{background:none;border:none;color:var(--ucl-gray-400);cursor:pointer;padding:var(--ucl-spacing-xs);border-radius:50%;transition:all var(--ucl-transition);display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin-left:var(--ucl-spacing-sm)}.search-clear:hover{background:var(--ucl-gray-100);color:var(--ucl-danger)}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);box-shadow:var(--ucl-shadow-lg);z-index:1000;margin-top:4px;overflow:hidden;animation:slideDown .2s ease-out}.search-suggestion{display:flex;align-items:center;padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);cursor:pointer;transition:background-color var(--ucl-transition);border-bottom:1px solid var(--ucl-gray-100)}.search-suggestion:last-child{border-bottom:none}.search-suggestion:hover{background:var(--ucl-gray-50)}.suggestion-icon{margin-right:var(--ucl-spacing-sm);font-size:14px;opacity:.7}.suggestion-text{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-primary)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.universal-sidebar{width:350px;background:var(--ucl-white);border-left:1px solid var(--ucl-gray-200);display:flex;flex-direction:column;height:100%;overflow:hidden}.sidebar-section{padding:var(--ucl-spacing-lg);border-bottom:1px solid var(--ucl-gray-100)}.sidebar-section:last-child{border-bottom:none;flex:1;overflow:hidden;display:flex;flex-direction:column}.sidebar-section-title{margin:0 0 var(--ucl-spacing-md) 0;font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.results-count{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-normal);color:var(--ucl-gray-600);margin-left:var(--ucl-spacing-sm)}.filters-section{background:linear-gradient(135deg,var(--ucl-gray-50) 0%,var(--ucl-white) 100%)}.filter-group{margin-bottom:var(--ucl-spacing-md)}.filter-label{display:block;font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary);margin-bottom:var(--ucl-spacing-xs);text-transform:uppercase;letter-spacing:.5px}.filter-select{width:100%;padding:var(--ucl-spacing-sm);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-family:var(--ucl-font-family);background:var(--ucl-white);color:var(--ucl-text-primary);transition:all var(--ucl-transition)}.search-stats{margin-top:var(--ucl-spacing-md);padding:var(--ucl-spacing-sm);background:#003d7a0d;border-radius:var(--ucl-border-radius);border-left:3px solid var(--ucl-primary)}.stats-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--ucl-spacing-xs);font-size:var(--ucl-font-size-sm)}.stats-item:last-child{margin-bottom:0}.stats-item.highlight{font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary)}.stats-label{color:var(--ucl-text-secondary)}.stats-value{font-weight:var(--ucl-font-weight-medium);color:var(--ucl-primary)}.events-section{flex:1;overflow:hidden;display:flex;flex-direction:column}.sidebar-events-list{flex:1;overflow-y:auto;padding-right:var(--ucl-spacing-xs)}.sidebar-events-list::-webkit-scrollbar{width:4px}.sidebar-events-list::-webkit-scrollbar-track{background:var(--ucl-gray-100);border-radius:2px}.sidebar-events-list::-webkit-scrollbar-thumb{background:var(--ucl-gray-300);border-radius:2px}.sidebar-events-list::-webkit-scrollbar-thumb:hover{background:var(--ucl-gray-400)}.sidebar-event-card{margin-bottom:var(--ucl-spacing-md);background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);overflow:hidden;transition:all var(--ucl-transition);position:relative}.sidebar-event-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--event-color, var(--ucl-primary))}.sidebar-event-card:hover{box-shadow:var(--ucl-shadow-md);transform:translateY(-1px)}.sidebar-event-title{margin:0;font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);line-height:1.3;flex:1}.source-badge{font-size:10px;padding:2px 6px;border-radius:var(--ucl-border-radius-sm);font-weight:var(--ucl-font-weight-medium);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.sidebar-event-description{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);line-height:1.4;margin-bottom:var(--ucl-spacing-md);background:var(--ucl-gray-50);padding:var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm);border-left:2px solid var(--event-color, var(--ucl-primary))}.btn-sidebar-info{background:var(--ucl-primary);color:var(--ucl-white);border:none;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition);display:flex;align-items:center;gap:var(--ucl-spacing-xs)}.btn-sidebar-info:hover{background:var(--ucl-secondary);transform:translateY(-1px)}.btn-sidebar-export{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-300);color:var(--ucl-text-secondary);padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius-sm);cursor:pointer;transition:all var(--ucl-transition);font-size:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.no-events-message{text-align:center;padding:var(--ucl-spacing-xl);color:var(--ucl-text-secondary)}.no-events-icon{font-size:3rem;margin-bottom:var(--ucl-spacing-md);opacity:.5}.no-events-suggestion{font-size:var(--ucl-font-size-sm);font-style:italic;margin-top:var(--ucl-spacing-sm)}.sidebar-footer{padding:var(--ucl-spacing-md);text-align:center;border-top:1px solid var(--ucl-gray-100);background:var(--ucl-gray-50)}.more-events-info{margin:0;font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);font-style:italic}.calendar-layout{display:flex;min-height:calc(100vh - 200px);gap:0}.calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.calendar-content{flex:1;padding:var(--ucl-spacing-lg);overflow:auto}.calendar-sidebar{width:350px;flex-shrink:0}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg) var(--ucl-spacing-xl);background:var(--ucl-white);border-bottom:1px solid var(--ucl-gray-200);box-shadow:0 2px 8px #0000000d;position:sticky;top:0;z-index:100;gap:var(--ucl-spacing-lg)}.calendar-search-section{flex:1;max-width:500px;margin:0 var(--ucl-spacing-lg)}@media (max-width: 1200px){.universal-sidebar{width:300px}.calendar-layout{flex-direction:column}.calendar-sidebar{width:100%;max-height:400px;border-left:none;border-top:1px solid var(--ucl-gray-200)}.sidebar-events-list{max-height:300px}}@media (max-width: 768px){.calendar-header{flex-direction:column;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-md)}.header-controls{flex-wrap:wrap;justify-content:center;width:100%}.calendar-search-section{width:100%;max-width:none;margin:0;order:-1}.universal-sidebar{width:100%}.sidebar-section{padding:var(--ucl-spacing-md)}.sidebar-event-card{margin-bottom:var(--ucl-spacing-sm)}.sidebar-event-content{padding:var(--ucl-spacing-sm)}.sidebar-event-actions{flex-direction:column;gap:var(--ucl-spacing-sm)}.sidebar-export-buttons{justify-content:center}}.text-primary{color:var(--ucl-primary)!important}.text-secondary{color:var(--ucl-secondary)!important}.text-muted{color:var(--ucl-muted)!important}.bg-primary{background-color:var(--ucl-primary)!important}.bg-light{background-color:var(--ucl-light)!important}.border-primary{border-color:var(--ucl-primary)!important}.shadow-sm{box-shadow:var(--ucl-shadow-sm)!important}.shadow{box-shadow:var(--ucl-shadow)!important}.shadow-md{box-shadow:var(--ucl-shadow-md)!important}.rounded{border-radius:var(--ucl-border-radius)!important}.rounded-lg{border-radius:var(--ucl-border-radius-lg)!important}.upcoming-events{margin:var(--ucl-spacing-xl) var(--ucl-spacing-lg) 0;padding:var(--ucl-spacing-xl);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-lg);border:1px solid var(--ucl-gray-200)}.upcoming-events h2{color:var(--ucl-primary);font-weight:var(--ucl-font-weight-bold);font-size:1.5rem;margin-bottom:var(--ucl-spacing-lg);text-align:center;position:relative;padding-bottom:var(--ucl-spacing-sm)}.upcoming-events h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--ucl-primary),var(--ucl-secondary));border-radius:2px}.no-events{text-align:center;color:var(--ucl-muted);font-style:italic;padding:var(--ucl-spacing-xl)}.events-list{display:flex;flex-direction:column;gap:var(--ucl-spacing-md)}.event-card{background:var(--ucl-white);border:1px solid rgba(0,61,122,.1);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-md);cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.event-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;transition:all .2s ease;background:var(--event-color, var(--ucl-primary))}.event-card.icloud:before{background:var(--event-color, #ff6b6b)}.event-card.outlook:before{background:var(--event-color, #4ecdc4)}.event-card.deduve:before{background:var(--event-color, #ff6b6b)}.event-card.secteur-sss:before{background:var(--event-color, #4ecdc4)}.event-card:hover{transform:translateY(-2px);box-shadow:var(--ucl-shadow-lg);border-color:var(--ucl-primary)}.event-card:hover:before{width:6px}.event-card-header{margin-bottom:var(--ucl-spacing-sm)}.event-title{color:var(--ucl-primary);font-weight:var(--ucl-font-weight-semibold);font-size:var(--ucl-font-size-lg);margin:0;line-height:1.3}.event-card-body{display:flex;flex-direction:column;gap:var(--ucl-spacing-xs)}.event-date{color:var(--ucl-primary);font-weight:var(--ucl-font-weight-medium);margin:0}.event-time{color:var(--ucl-secondary);font-size:var(--ucl-font-size-sm);margin:0}.event-location{color:var(--ucl-muted);font-size:var(--ucl-font-size-sm);margin:0}.event-category{margin:0}.category-badge{display:inline-block;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm);color:var(--ucl-white);font-size:12px;font-weight:var(--ucl-font-weight-medium)}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--ucl-spacing-md);margin-top:var(--ucl-spacing-lg);padding-top:var(--ucl-spacing-lg);border-top:1px solid rgba(0,61,122,.1)}.page-info{color:var(--ucl-muted);font-weight:var(--ucl-font-weight-medium);font-size:var(--ucl-font-size-sm)}.nav-button:disabled{background:var(--ucl-light);color:var(--ucl-muted);border-color:var(--ucl-light);cursor:not-allowed;transform:none}.nav-button:disabled:hover{background:var(--ucl-light);color:var(--ucl-muted);border-color:var(--ucl-light);transform:none;box-shadow:none}@media (max-width: 768px){.upcoming-events{padding:var(--ucl-spacing-md);margin-top:var(--ucl-spacing-lg)}.upcoming-events h2{font-size:var(--ucl-font-size-lg);margin-bottom:var(--ucl-spacing-md)}.event-card{padding:var(--ucl-spacing-sm)}.event-title{font-size:var(--ucl-font-size-base)}.pagination{flex-direction:column;gap:var(--ucl-spacing-sm)}.pagination .nav-button{width:100%;max-width:200px}.event-details-header{padding:var(--ucl-spacing-md)}.event-details-title{font-size:var(--ucl-font-size-base)}.event-details-content{padding:var(--ucl-spacing-md)}.event-detail-row{flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-xs)}.detail-icon{margin-right:0;margin-bottom:var(--ucl-spacing-xs)}.description-content{max-height:200px}.description-paragraph.important-info{padding:var(--ucl-spacing-xs)}.event-tooltip{max-width:250px;font-size:12px;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm)}}@media (min-width: 769px) and (max-width: 1024px){.event-card-header{align-items:center}}.view-buttons{display:flex;background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);padding:var(--ucl-spacing-xs);border:1px solid var(--ucl-gray-200);box-shadow:var(--ucl-shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.view-button{display:flex;align-items:center;gap:var(--ucl-spacing-xs);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border:none;background:transparent;color:var(--ucl-gray-500);border-radius:var(--ucl-border-radius);cursor:pointer;font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);font-family:var(--ucl-font-family);transition:all var(--ucl-transition);white-space:nowrap;position:relative;overflow:hidden}.view-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(59,130,246,.1),transparent);transition:left var(--ucl-transition)}.view-button:hover{background:var(--ucl-gray-50);color:var(--ucl-primary);transform:translateY(-1px)}.view-button:hover:before{left:100%}.view-button.active{background:var(--ucl-primary);color:var(--ucl-white);box-shadow:0 2px 8px #003d7a4d;transform:translateY(-1px)}.view-button.active:before{display:none}.view-icon{font-size:16px}.view-label{font-size:var(--ucl-font-size-sm)}.header-controls{display:flex;align-items:center;gap:var(--ucl-spacing-md)}.source-filter{position:relative}.filter-select{background:var(--ucl-white);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);font-size:var(--ucl-font-size-sm);font-family:var(--ucl-font-family);color:var(--ucl-text-primary);cursor:pointer;transition:all var(--ucl-transition);min-width:180px}.filter-select:hover{border-color:var(--ucl-primary);box-shadow:0 2px 4px #003d7a1a}.filter-select:focus{outline:none;border-color:var(--ucl-primary);box-shadow:0 0 0 3px #003d7a1a}.calendar-content{background:var(--ucl-white);margin:0 var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-lg);border:1px solid var(--ucl-gray-200);overflow:hidden;margin-bottom:var(--ucl-spacing-xl)}.week-view{display:flex;flex-direction:column;height:800px;background:var(--ucl-white);overflow:hidden}.week-header{display:grid;grid-template-columns:120px repeat(7,1fr);background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-secondary));color:var(--ucl-white);border-bottom:1px solid rgba(255,255,255,.2);position:relative}.week-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ucl-accent),var(--ucl-info),var(--ucl-accent))}.time-column-header{background:transparent;border-right:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-weight:var(--ucl-font-weight-semibold);font-size:var(--ucl-font-size-sm)}.day-header{display:flex;flex-direction:column;align-items:center;padding:var(--ucl-spacing-md) var(--ucl-spacing-sm);border-right:1px solid rgba(255,255,255,.2);transition:all var(--ucl-transition);position:relative}.day-header:last-child{border-right:none}.day-header.today{background:#ffffff26;font-weight:var(--ucl-font-weight-bold)}.day-header.today:before{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:30px;height:3px;background:var(--ucl-white);border-radius:var(--ucl-border-radius-sm)}.day-name{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--ucl-spacing-xs)}.day-number{font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold)}.week-grid{display:grid;grid-template-columns:120px repeat(7,1fr);flex:1;overflow-y:auto;background:var(--ucl-gray-50)}.week-grid::-webkit-scrollbar{width:8px}.week-grid::-webkit-scrollbar-track{background:var(--ucl-gray-100)}.week-grid::-webkit-scrollbar-thumb{background:var(--ucl-gray-300);border-radius:var(--ucl-border-radius)}.week-grid::-webkit-scrollbar-thumb:hover{background:var(--ucl-gray-400)}.time-column{background:var(--ucl-white);border-right:2px solid var(--ucl-gray-200);position:sticky;left:0;z-index:10}.time-slot{height:60px;display:flex;align-items:flex-start;padding:var(--ucl-spacing-xs);border-bottom:1px solid var(--ucl-gray-200);position:relative}.time-slot:nth-child(2n){background:#3b82f605}.time-label{font-size:11px;color:var(--ucl-gray-500);font-weight:var(--ucl-font-weight-semibold);background:var(--ucl-white);padding:2px 6px;border-radius:var(--ucl-border-radius-sm);box-shadow:var(--ucl-shadow-sm)}.day-column{position:relative;border-right:1px solid var(--ucl-gray-200);background:var(--ucl-white);transition:background-color var(--ucl-transition)}.day-column:hover{background:#3b82f605}.day-column:last-child{border-right:none}.day-events-container{position:absolute;top:0;left:0;right:0;bottom:0;z-index:10;padding:0 2px}.hour-slot{height:60px;border-bottom:1px solid var(--ucl-gray-200);position:relative}.hour-slot:nth-child(2n){background:#3b82f603}.hour-line{position:absolute;top:0;left:0;right:0;height:1px;background:var(--ucl-gray-300)}.hour-slot:nth-child(4n) .hour-line{background:var(--ucl-gray-400);height:2px}.week-event{border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);cursor:pointer;transition:all var(--ucl-transition);color:var(--ucl-white);font-size:11px;overflow:hidden;box-shadow:var(--ucl-shadow-md);border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;margin:1px 0}.week-event:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#fff6;border-radius:var(--ucl-border-radius-sm)}.week-event:hover{transform:scale(1.03) translate(2px);box-shadow:var(--ucl-shadow-lg);z-index:20;border-color:#fff6}.week-event.icloud{background:linear-gradient(135deg,var(--ucl-event-personal),rgba(236,72,153,.9))}.week-event.outlook{background:linear-gradient(135deg,var(--ucl-event-academic),rgba(6,182,212,.9))}.week-event.deduve{background:linear-gradient(135deg,var(--ucl-event-personal),rgba(236,72,153,.9))}.week-event.secteur-sss{background:linear-gradient(135deg,var(--ucl-event-academic),rgba(6,182,212,.9))}.event-time{font-weight:var(--ucl-font-weight-bold);font-size:11px;margin-bottom:2px;opacity:.9}.event-title{font-weight:var(--ucl-font-weight-medium);line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.agenda-view{padding:var(--ucl-spacing-lg)}.agenda-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--ucl-spacing-lg);padding:var(--ucl-spacing-lg);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);border:1px solid var(--ucl-gray-200);box-shadow:var(--ucl-shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.date-range-controls label{font-weight:var(--ucl-font-weight-medium);color:var(--ucl-primary);font-size:var(--ucl-font-size-sm)}.range-select{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border:1px solid rgba(0,61,122,.2);border-radius:var(--ucl-border-radius-sm);background:var(--ucl-white);color:var(--ucl-dark);font-family:var(--ucl-font-family);font-size:var(--ucl-font-size-sm);cursor:pointer}.range-select:focus{outline:2px solid var(--ucl-accent);outline-offset:2px;border-color:var(--ucl-primary)}.past-events-toggle{display:flex;align-items:center;gap:var(--ucl-spacing-xs)}.past-events-toggle label{display:flex;align-items:center;gap:var(--ucl-spacing-xs);font-size:var(--ucl-font-size-sm);color:var(--ucl-primary);cursor:pointer}.past-events-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--ucl-primary)}.agenda-summary{text-align:center;margin-bottom:var(--ucl-spacing-lg);padding:var(--ucl-spacing-sm);background:#003d7a0d;border-radius:var(--ucl-border-radius-sm);color:var(--ucl-primary);font-weight:var(--ucl-font-weight-medium)}.agenda-list{display:flex;flex-direction:column;gap:var(--ucl-spacing-xl)}.agenda-day-group{border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-lg);overflow:hidden;background:var(--ucl-white);box-shadow:var(--ucl-shadow-lg);transition:all var(--ucl-transition);position:relative}.agenda-day-group:hover{transform:translateY(-2px);box-shadow:var(--ucl-shadow-xl)}.agenda-date-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-md);background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent));color:var(--ucl-white)}.date-title{margin:0;font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);text-transform:capitalize}.events-count{font-size:var(--ucl-font-size-sm);background:var(--ucl-white);color:var(--ucl-primary);padding:var(--ucl-spacing-xs) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius-lg);font-weight:var(--ucl-font-weight-bold);border:2px solid var(--ucl-primary);box-shadow:0 2px 4px #003d7a33;min-width:60px;text-align:center;background:#fff3;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm)}.agenda-events{display:flex;flex-direction:column}.agenda-event{display:flex;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-lg);border-bottom:1px solid var(--ucl-gray-100);cursor:pointer;transition:all var(--ucl-transition);position:relative}.agenda-event:hover{background:linear-gradient(135deg,#3b82f608,#8b5cf608);transform:translate(8px)}.agenda-event:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent));transition:width var(--ucl-transition)}.agenda-event:hover:before{width:4px}.agenda-event.today{background:#003d7a0d;border-left:4px solid var(--ucl-primary)}.agenda-event.past{opacity:.7}.agenda-event.past .event-title{text-decoration:line-through;color:var(--ucl-muted)}.event-time-indicator{display:flex;flex-direction:column;align-items:center;gap:var(--ucl-spacing-xs);min-width:80px;flex-shrink:0}.time-dot{width:12px;height:12px;border-radius:50%;box-shadow:var(--ucl-shadow-sm)}.event-time{font-size:12px;font-weight:var(--ucl-font-weight-medium);color:var(--ucl-muted);text-align:center;line-height:1.2}.event-content{flex:1;display:flex;flex-direction:column;gap:var(--ucl-spacing-xs)}.event-title{margin:0;font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);line-height:1.3}.event-location{margin:0;font-size:var(--ucl-font-size-sm);color:var(--ucl-muted);display:flex;align-items:center;gap:var(--ucl-spacing-xs)}.location-icon{font-size:14px}.event-meta{display:flex;align-items:center;gap:var(--ucl-spacing-sm);margin-top:var(--ucl-spacing-xs)}.event-category{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm);font-size:11px;font-weight:var(--ucl-font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.event-source{font-size:11px;color:var(--ucl-muted);text-transform:uppercase;letter-spacing:.5px;background:var(--ucl-light);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm)}.event-description{margin:var(--ucl-spacing-xs) 0 0 0;font-size:var(--ucl-font-size-sm);color:var(--ucl-secondary);line-height:1.4;font-style:italic}.compact-view{padding:var(--ucl-spacing-lg)}.compact-header{text-align:center;margin-bottom:var(--ucl-spacing-lg)}.compact-title{color:var(--ucl-primary);font-weight:var(--ucl-font-weight-semibold);font-size:var(--ucl-font-size-xl);margin:0;text-transform:capitalize}.compact-calendar{max-width:400px;margin:0 auto}.compact-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px}.compact-weekday{text-align:center;padding:var(--ucl-spacing-sm);font-weight:var(--ucl-font-weight-semibold);font-size:12px;color:var(--ucl-primary);background:var(--ucl-light);border-radius:var(--ucl-border-radius-sm)}.compact-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.compact-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);cursor:pointer;transition:all var(--ucl-transition);position:relative;min-height:50px}.compact-day:hover{background:var(--ucl-gray-50);transform:scale(1.05);box-shadow:var(--ucl-shadow-md);z-index:10}.compact-day.other-month{background:var(--ucl-gray-100);color:var(--ucl-gray-400)}.compact-day.today{background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent));color:var(--ucl-white);font-weight:var(--ucl-font-weight-bold);box-shadow:var(--ucl-shadow-lg)}.compact-day.has-events{border-color:var(--ucl-primary);background:#3b82f60d}.compact-day-number{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);margin-bottom:var(--ucl-spacing-xs)}.compact-events-indicator{display:flex;flex-direction:column;align-items:center;gap:2px}.event-dot{width:6px;height:6px;border-radius:50%;cursor:pointer;transition:all var(--ucl-transition-fast);box-shadow:var(--ucl-shadow-sm)}.event-dot:hover{transform:scale(1.5);box-shadow:var(--ucl-shadow)}.events-count{background:var(--ucl-primary);color:var(--ucl-white);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:var(--ucl-font-weight-bold);box-shadow:var(--ucl-shadow-sm)}.count-number{font-size:10px}.source-indicators{display:flex;gap:2px;margin-top:2px}.compact-legend{display:flex;justify-content:center;gap:var(--ucl-spacing-lg);margin-top:var(--ucl-spacing-lg);padding:var(--ucl-spacing-md);background:var(--ucl-white);border-radius:var(--ucl-border-radius);box-shadow:var(--ucl-shadow-sm);border:1px solid var(--ucl-gray-200)}.legend-item{display:flex;align-items:center;gap:var(--ucl-spacing-xs);font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600)}.legend-dot{width:12px;height:12px;border-radius:50%;box-shadow:var(--ucl-shadow-sm)}.today-indicator{background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent))}.has-events-indicator{background:#3b82f64d;border:2px solid var(--ucl-primary)}.compact-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--ucl-white);border:1px solid rgba(0,61,122,.1);border-radius:var(--ucl-border-radius-sm);cursor:pointer;transition:all .2s ease;position:relative;padding:var(--ucl-spacing-xs);min-height:50px}.compact-day:hover{background:#003d7a0d;transform:scale(1.05);box-shadow:var(--ucl-shadow-sm);z-index:10}.compact-day.other-month{background:var(--ucl-light);color:var(--ucl-muted);opacity:.6}.compact-day.today{background:var(--ucl-primary);color:var(--ucl-white);font-weight:var(--ucl-font-weight-bold);box-shadow:var(--ucl-shadow-md)}.compact-day.has-events{border-color:var(--ucl-primary);border-width:2px}.compact-day-number{font-size:14px;font-weight:var(--ucl-font-weight-medium);margin-bottom:2px}.compact-events-indicator{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%}.event-dot{width:6px;height:6px;border-radius:50%;box-shadow:0 1px 2px #0003;cursor:pointer;transition:transform .2s ease}.events-count{background:var(--ucl-primary);color:var(--ucl-white);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:var(--ucl-font-weight-bold)}.count-number{line-height:1}.source-indicators{display:flex;gap:1px;margin-top:1px}.source-indicator{font-size:8px;opacity:.7}.compact-legend{display:flex;justify-content:center;gap:var(--ucl-spacing-lg);margin-top:var(--ucl-spacing-lg);padding:var(--ucl-spacing-md);background:var(--ucl-light);border-radius:var(--ucl-border-radius);border:1px solid rgba(0,61,122,.1)}.legend-item{display:flex;align-items:center;gap:var(--ucl-spacing-xs);font-size:var(--ucl-font-size-sm);color:var(--ucl-muted)}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.today-indicator{background:var(--ucl-primary)}.has-events-indicator{background:var(--ucl-accent)}.legend-icon{font-size:14px}.month-view .calendar-grid{background:transparent;border:none;box-shadow:none}@media (max-width: 768px){.view-buttons{flex-wrap:wrap;gap:var(--ucl-spacing-xs)}.view-button{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);font-size:12px}.view-label{display:none}.header-controls{flex-direction:column;gap:var(--ucl-spacing-sm);align-items:stretch}.week-view{height:500px}.week-header,.week-grid{grid-template-columns:60px repeat(7,1fr)}.day-header{padding:var(--ucl-spacing-sm) var(--ucl-spacing-xs)}.day-name{font-size:10px}.day-number{font-size:var(--ucl-font-size-sm)}.time-slot,.hour-slot{height:50px}.week-event{font-size:10px;padding:2px}.event-time{font-size:9px}.agenda-controls{flex-direction:column;gap:var(--ucl-spacing-sm);align-items:stretch}.agenda-event{flex-direction:column;gap:var(--ucl-spacing-sm)}.event-time-indicator{flex-direction:row;min-width:auto;align-items:center}.event-meta{flex-wrap:wrap}.compact-calendar{max-width:100%}.compact-day{min-height:40px;padding:2px}.compact-day-number{font-size:12px}.compact-legend{flex-wrap:wrap;gap:var(--ucl-spacing-sm)}.legend-item{font-size:12px}}@media (min-width: 769px) and (max-width: 1024px){.week-view{height:550px}.agenda-controls{flex-wrap:wrap;gap:var(--ucl-spacing-md)}}.calendar-content{animation:viewTransition .3s ease-out}@keyframes viewTransition{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.agenda-day-group{animation:slideInUp .3s ease-out}.compact-day{animation:fadeInScale .2s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.calendar-container{padding:var(--ucl-spacing-md)}.calendar-header{flex-direction:column;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-md)}.calendar-nav{flex-wrap:wrap;justify-content:center;gap:var(--ucl-spacing-sm)}.nav-button{font-size:12px;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);min-height:36px}.month-year{font-size:var(--ucl-font-size-lg);text-align:center;order:-1}.header-controls{flex-direction:column;gap:var(--ucl-spacing-sm);width:100%}.view-buttons{width:100%;justify-content:center}.view-button{flex:1;justify-content:center;padding:var(--ucl-spacing-sm)}.view-label{display:none}.calendar-day{min-height:90px;padding:var(--ucl-spacing-xs)}.weekday{padding:var(--ucl-spacing-sm) var(--ucl-spacing-xs);font-size:11px}.event-item{font-size:9px;padding:2px var(--ucl-spacing-xs)}.week-view{height:500px}.week-header,.week-grid{grid-template-columns:60px repeat(7,1fr)}.time-column-header,.day-name{font-size:10px}.day-number{font-size:var(--ucl-font-size-sm)}.time-label{font-size:9px}.week-event{font-size:9px;padding:2px 4px}.agenda-controls{flex-direction:column;gap:var(--ucl-spacing-sm);align-items:stretch}.agenda-event{flex-direction:column;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-md)}.event-time-indicator{flex-direction:row;align-items:center;min-width:auto}.compact-calendar{max-width:100%}.compact-day{min-height:40px}.compact-legend{flex-wrap:wrap;gap:var(--ucl-spacing-sm)}}@media (min-width: 769px) and (max-width: 1024px){.calendar-container{padding:var(--ucl-spacing-lg)}.calendar-day{min-height:110px}.week-view{height:650px}}@media (min-width: 1025px){.calendar-container{padding:var(--ucl-spacing-xl)}.calendar-header{padding:var(--ucl-spacing-xl) var(--ucl-spacing-xxl)}.calendar-day{min-height:140px}.week-view{height:750px}}@media (prefers-color-scheme: dark){:root{--ucl-white: #1e293b;--ucl-light: #0f172a;--ucl-dark: #f8fafc;--ucl-gray-50: #0f172a;--ucl-gray-100: #1e293b;--ucl-gray-200: #334155;--ucl-gray-300: #475569;--ucl-gray-400: #64748b;--ucl-gray-500: #94a3b8;--ucl-gray-600: #cbd5e1;--ucl-gray-700: #e2e8f0;--ucl-gray-800: #f1f5f9;--ucl-gray-900: #f8fafc}body{background:linear-gradient(135deg,var(--ucl-gray-50) 0%,var(--ucl-gray-100) 100%)}.calendar-grid:before{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d)}}@media print{.calendar-header{box-shadow:none;border:1px solid #ccc}.nav-button,.view-selector{display:none}.calendar-grid{box-shadow:none;border:1px solid #ccc}.event-item{background:#f0f0f0!important;color:#000!important;border:1px solid #ccc}.upcoming-events{page-break-before:always}}.source-indicator.icloud:before{content:"🧬"}.source-indicator.outlook:before{content:"🏥"}.source-indicator[title*="de Duve"]{color:var(--ucl-event-personal)}.source-indicator[title*="Secteur SSS"]{color:var(--ucl-event-academic)}.event-source{background:var(--ucl-gray-100);color:var(--ucl-gray-600);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm);font-size:10px;font-weight:var(--ucl-font-weight-semibold);text-transform:uppercase;letter-spacing:.5px;transition:all var(--ucl-transition-fast)}.agenda-event.icloud .event-source{background:#ec48991a;color:var(--ucl-event-personal)}.agenda-event.outlook .event-source{background:#06b6d41a;color:var(--ucl-event-academic)}.legend-icon{display:inline-block;transition:transform var(--ucl-transition-fast)}.legend-item:hover .legend-icon{transform:scale(1.2)}.source-indicator{transition:all var(--ucl-transition-fast);cursor:help}.source-indicator:hover{transform:scale(1.3);filter:brightness(1.2)}.event-tooltip{position:fixed;background:#000000e6;color:#fff;padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;max-width:300px;word-wrap:break-word;z-index:1000;pointer-events:none;transform:translate(-50%) translateY(-100%);box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:tooltipFadeIn .2s ease-out}.event-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#000000e6}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-100%) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(-100%) scale(1)}}.event-item{cursor:pointer;transition:all var(--ucl-transition-fast)}.event-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000004d!important}.source-filter{margin-right:16px}.filter-select{background:linear-gradient(145deg,#fff,#f8f9fa);border:2px solid #e9ecef;border-radius:12px;padding:10px 16px;font-size:14px;color:#495057;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:180px;font-weight:500;box-shadow:0 2px 8px #00000014}.filter-select:hover{border-color:#007bff;background:linear-gradient(145deg,#f8f9fa,#fff);box-shadow:0 4px 16px #007bff26;transform:translateY(-1px)}.filter-select:focus{outline:none;border-color:#007bff;background:#fff;box-shadow:0 0 0 4px #007bff1a,0 4px 16px #007bff26}.filter-select option{background:#fff;color:#495057;padding:12px;font-weight:500}.source-badge,.source-tag{display:inline-block;font-weight:500;letter-spacing:.3px;transition:all .2s ease}.source-badge:hover,.source-tag:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.event-source{margin-top:10px}.event-item.icloud{background:linear-gradient(135deg,#ffe6e6,#fff0f0)!important;border-left:4px solid #ff9999!important;color:#8b0000!important;box-shadow:0 2px 8px #ff999940}.event-item.outlook{background:linear-gradient(135deg,#e6f3ff,#f0f8ff)!important;border-left:4px solid #87ceeb!important;color:#1e3a8a!important;box-shadow:0 2px 8px #87ceeb40}.event-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026!important}.event-card{transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:12px;overflow:hidden}.event-card.icloud{border-left:4px solid #ff9999;background:linear-gradient(135deg,#ffe6e699,#fff0f04d);box-shadow:0 2px 12px #ff999926}.event-card.outlook{border-left:4px solid #87ceeb;background:linear-gradient(135deg,#e6f3ff99,#f0f8ff4d);box-shadow:0 2px 12px #87ceeb26}.event-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001f}.event-title{color:#2c3e50!important;font-weight:600;line-height:1.4}.event-date,.event-time,.event-location{color:#6c757d!important;font-weight:400}.event-date strong{color:#495057!important;font-weight:600}.header-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}@media (max-width: 768px){.filter-select{min-width:140px;font-size:13px;padding:8px 12px}.header-controls{gap:8px}}.calendar-container{background:#fff;margin:0 auto;padding:20px;min-height:100vh;max-width:1200px;width:100%}.calendar-header{background:#fff;padding:24px;border-bottom:1px solid var(--ucl-border-light);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.month-year{color:var(--ucl-text-primary);font-size:28px;font-weight:700;margin:0;text-align:center;flex:1}.calendar-nav{display:flex;gap:12px}.nav-button{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid var(--ucl-border);border-radius:12px;padding:10px 16px;font-size:14px;font-weight:500;color:var(--ucl-text-primary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000f}.nav-button:hover{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-color:var(--ucl-primary);transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.nav-button:active{transform:translateY(0)}.nav-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.calendar-content{background:#fff;padding:20px;width:100%}.calendar-grid{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a;border:1px solid var(--ucl-border-light)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-bottom:2px solid var(--ucl-border)}.weekday{padding:16px 8px;text-align:center;font-weight:600;color:var(--ucl-text-secondary);font-size:14px;text-transform:uppercase;letter-spacing:.5px}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);background:var(--ucl-bg-primary)}.calendar-day{min-height:120px;padding:12px 8px;border-right:1px solid var(--ucl-border-light);border-bottom:1px solid var(--ucl-border-light);background:var(--ucl-bg-primary);transition:all .2s ease;position:relative}.calendar-day:hover{background:var(--ucl-bg-secondary)}.calendar-day.other-month{background:var(--ucl-bg-tertiary);color:var(--ucl-text-muted)}.calendar-day.today{background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border:2px solid var(--ucl-primary)}.day-number{font-weight:600;font-size:16px;color:var(--ucl-text-primary);margin-bottom:8px}.calendar-day.other-month .day-number{color:var(--ucl-text-muted)}.calendar-day.today .day-number{color:var(--ucl-primary);font-weight:700}.day-events{display:flex;flex-direction:column;gap:4px}.event-item{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;line-height:1.3}.more-events{background:var(--ucl-gray-200)!important;color:var(--ucl-text-secondary)!important;text-align:center;font-style:italic}.upcoming-events{background:var(--ucl-bg-primary);border-radius:16px;padding:24px;margin-top:24px;box-shadow:0 4px 24px #0000000f;border:1px solid var(--ucl-border-light)}.upcoming-events h2{color:var(--ucl-text-primary);font-size:24px;font-weight:700;margin-bottom:20px;text-align:center}.events-list{display:grid;gap:16px}.event-card{background:var(--ucl-bg-primary);border-radius:12px;padding:20px;box-shadow:0 2px 12px #0000000f;border:1px solid var(--ucl-border-light);cursor:pointer}.event-card-header{margin-bottom:12px}.event-card-body{display:flex;flex-direction:column;gap:8px}.event-details-inline{background:#fff;border-radius:12px;padding:24px;margin:20px 0;box-shadow:0 4px 20px #0000001a;border:1px solid var(--ucl-border-light);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.event-details-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding:20px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;border:1px solid var(--ucl-border-light)}.event-details-title{color:#2c3e50;font-size:24px;font-weight:700;margin:0 16px 0 0;flex:1;line-height:1.3}.close-details-btn{background:#fff;border:2px solid #e2e8f0;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;font-size:18px;font-weight:700;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.close-details-btn:hover{background:#ef4444;border-color:#dc2626;color:#fff;transform:scale(1.05)}.event-details-content{display:flex;flex-direction:column;gap:20px}.event-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.event-description-section{margin-top:20px;padding-top:20px;border-top:2px solid var(--ucl-border-light)}.description-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.description-header strong{color:var(--ucl-text-primary);font-weight:600;font-size:16px;text-transform:uppercase;letter-spacing:.5px}.description-content{background:#fff;padding:20px;border-radius:8px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000d}.description-paragraph{margin-bottom:16px;line-height:1.7;color:#374151;font-size:15px;text-align:justify}.description-paragraph:last-child{margin-bottom:0}.description-paragraph.important-info{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:16px 20px;border-radius:8px;border-left:4px solid #f59e0b;font-weight:500;color:#92400e;margin:20px 0}.description-paragraph.paragraph-title{font-weight:600;color:#1e293b;font-size:16px;margin-bottom:8px;margin-top:20px;text-transform:uppercase;letter-spacing:.5px}.description-paragraph.paragraph-title:first-child{margin-top:0}.description-line{margin-bottom:8px;line-height:1.7;color:#374151;font-size:15px}.description-line:last-child{margin-bottom:0}.description-paragraph{margin-bottom:12px;line-height:1.7;color:#374151;font-size:15px}.description-list{margin:12px 0;padding-left:20px}.description-list li{margin-bottom:8px;line-height:1.5;color:var(--ucl-text-secondary)}.event-detail-row{display:flex;align-items:flex-start;gap:12px}.detail-icon{font-size:18px;width:24px;text-align:center;margin-top:2px}.detail-content{flex:1;display:flex;flex-direction:column;gap:4px}.detail-content strong{color:var(--ucl-text-primary);font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.detail-content span{color:var(--ucl-text-secondary);font-size:16px}.loading,.error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:var(--ucl-bg-primary);border-radius:16px;margin:20px;box-shadow:0 4px 24px #0000000f}.loading{color:var(--ucl-text-secondary);font-size:18px}.error{color:var(--ucl-danger)}.error h3{margin-bottom:12px;font-size:24px}.no-events{color:var(--ucl-text-muted);font-style:italic;text-align:center;padding:40px}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding-top:20px;border-top:1px solid var(--ucl-border-light)}.page-info{color:var(--ucl-text-secondary);font-weight:500}.fade-in{animation:fadeIn .5s ease-out}.scale-in{animation:scaleIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.calendar-container{margin:0;padding:10px;border-radius:0;max-width:100%}.calendar-header{padding:16px;flex-direction:column;gap:12px}.month-year{font-size:24px}.calendar-content{padding:12px}.calendar-day{min-height:80px;padding:8px 4px}.day-number{font-size:14px}.event-item{font-size:11px;padding:2px 6px}.upcoming-events{padding:16px;margin-top:16px;margin-left:0;margin-right:0;border-radius:0}.event-details-inline{padding:16px;margin:16px 0}.event-details-grid{grid-template-columns:1fr;gap:12px}.description-content{padding:16px}}.compact-view{background:#fff;padding:20px}.compact-header{text-align:center;margin-bottom:20px}.compact-title{color:#2c3e50;font-size:24px;font-weight:700;margin:0}.compact-calendar{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px #00000014;border:1px solid #e2e8f0}.compact-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-bottom:2px solid #e2e8f0}.compact-weekday{padding:12px 8px;text-align:center;font-weight:600;color:#475569;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.compact-days{display:grid;grid-template-columns:repeat(7,1fr);background:#fff}.compact-day{min-height:60px;padding:8px;border-right:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;background:#fff;cursor:pointer;transition:all .2s ease;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.compact-day:hover{background:#f8fafc}.compact-day.other-month{background:#f8fafc;color:#94a3b8}.compact-day.today{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6}.compact-day.has-events{background:linear-gradient(135deg,#fef3c7,#fde68a)}.compact-day-number{font-weight:600;font-size:16px;color:#1e293b;margin-bottom:4px}.compact-day.other-month .compact-day-number{color:#94a3b8}.compact-day.today .compact-day-number{color:#1e40af;font-weight:700}.compact-events-indicator{display:flex;flex-direction:column;align-items:center;gap:4px}.event-dots{display:flex;gap:2px;flex-wrap:wrap;justify-content:center}.event-dot{width:8px;height:8px;border-radius:50%;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.8)}.events-count{background:#3b82f6;color:#fff;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600}.source-indicators{display:flex;gap:2px}.source-indicator{font-size:10px;padding:2px 4px;border-radius:4px;background:#ffffffe6;border:1px solid #e2e8f0}.compact-legend{display:flex;justify-content:center;gap:20px;margin-top:16px;padding:16px;background:#f8fafc;border-radius:8px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#475569}.legend-dot{width:12px;height:12px;border-radius:50%}.today-indicator{background:#3b82f6}.has-events-indicator{background:#f59e0b}.legend-icon{font-size:16px}.agenda-view{background:#fff;padding:20px}.agenda-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;flex-wrap:wrap;gap:16px}.date-range-controls{display:flex;align-items:center;gap:12px}.date-range-controls label{font-weight:500;color:#374151}.range-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:8px 12px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s ease}.range-select:hover,.range-select:focus{border-color:#3b82f6;outline:none}.past-events-toggle{display:flex;align-items:center}.past-events-toggle label{display:flex;align-items:center;gap:8px;font-weight:500;color:#374151;cursor:pointer}.past-events-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#3b82f6}.agenda-summary{text-align:center;margin-bottom:20px;padding:12px;background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border-radius:8px;color:#0f172a;font-weight:500}.agenda-list{display:flex;flex-direction:column;gap:20px}.agenda-day-group{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px #00000014;border:1px solid #e2e8f0}.agenda-date-header{background:linear-gradient(135deg,#f8fafc,#e2e8f0);color:#1e293b;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #e2e8f0}.date-title{margin:0;font-size:18px;font-weight:600}.events-count{background:#3b82f6;color:#fff;padding:4px 12px;border-radius:16px;font-size:14px;font-weight:500}.agenda-events{padding:0}.agenda-event{padding:16px 20px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:all .2s ease;display:flex;gap:16px;background:#fff}.agenda-event:last-child{border-bottom:none}.agenda-event:hover{background:#f8fafc;transform:translate(4px)}.agenda-event.today{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b}.agenda-event.past{opacity:.7;background:#f8fafc}.event-time-indicator{display:flex;flex-direction:column;align-items:center;min-width:80px}.time-dot{width:12px;height:12px;border-radius:50%;margin-bottom:8px;border:2px solid white;box-shadow:0 2px 4px #0003}.event-time{font-size:14px;font-weight:600;color:#475569;text-align:center}.event-content{flex:1}.event-content .event-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#1e293b;line-height:1.4}.event-location{margin:8px 0;color:#6b7280;font-size:14px;display:flex;align-items:center;gap:6px}.event-meta{display:flex;gap:12px;margin:12px 0;align-items:center;flex-wrap:wrap}.event-category{padding:4px 12px;border-radius:16px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.event-source{color:#6b7280;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.event-description{margin:12px 0 0;color:#6b7280;font-size:14px;line-height:1.5;font-style:italic}.no-events{text-align:center;padding:60px 20px;color:#6b7280;font-style:italic}.week-view{background:#fff;padding:20px;overflow-x:auto}.week-header{display:grid;grid-template-columns:80px repeat(7,1fr);background:#fff;border-bottom:2px solid #e2e8f0;margin-bottom:0;position:sticky;top:0;z-index:10}.time-column-header{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:16px 8px;text-align:center;font-weight:600;color:#475569;font-size:14px;border-right:2px solid #e2e8f0}.day-header{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:16px 8px;text-align:center;border-right:1px solid #e2e8f0;transition:all .2s ease}.day-header.today{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;font-weight:700}.day-name{font-size:14px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.day-header.today .day-name{color:#1e40af}.day-number{font-size:18px;font-weight:700;color:#1e293b}.day-header.today .day-number{color:#1e40af}.week-grid{display:grid;grid-template-columns:80px repeat(7,1fr);background:#fff;border:1px solid #e2e8f0;border-top:none}.time-column{background:linear-gradient(135deg,#fafbfc,#f1f5f9);border-right:2px solid #e2e8f0}.time-slot{height:60px;padding:8px;border-bottom:1px solid #f1f5f9;display:flex;align-items:flex-start;justify-content:center}.time-label{font-size:12px;color:#6b7280;font-weight:500}.day-column{position:relative;border-right:1px solid #f1f5f9;background:#fff}.day-events-container{position:relative;height:100%}.hour-slot{height:60px;border-bottom:1px solid #f1f5f9;position:relative}.hour-line{position:absolute;top:0;left:0;right:0;height:1px;background:#f1f5f9}.week-event{border-radius:6px;padding:4px 8px;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 4px #0000001a;overflow:hidden;color:#fff;font-weight:500}.week-event:hover{transform:scale(1.02);box-shadow:0 4px 12px #0003;z-index:20!important}.week-event .event-time{font-size:11px;font-weight:600;margin-bottom:2px;opacity:.9}.week-event .event-title{font-size:12px;font-weight:500;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.week-event.icloud{background:linear-gradient(135deg,#f99,#ffb3b3)!important;color:#8b0000!important;border:1px solid #ff6666}.week-event.outlook{background:linear-gradient(135deg,#87ceeb,#a6d8f0)!important;color:#1e3a8a!important;border:1px solid #5dade2}@media (max-width: 768px){.week-view{padding:10px}.week-header,.week-grid{grid-template-columns:60px repeat(7,minmax(80px,1fr))}.time-column-header{padding:12px 4px;font-size:12px}.day-header{padding:12px 4px}.day-name{font-size:12px}.day-number{font-size:16px}.time-slot{padding:4px}.time-label,.week-event .event-title{font-size:10px}.week-event .event-time{font-size:9px}}.app-header{background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent));color:var(--ucl-white);padding:var(--ucl-spacing-xl) 0;text-align:center;box-shadow:var(--ucl-shadow-lg);position:relative;overflow:hidden}.app-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(255,255,255,.1) 25%,transparent 25%,transparent 75%,rgba(255,255,255,.1) 75%);background-size:20px 20px;opacity:.3}.header-content{max-width:1400px;margin:0 auto;padding:0 var(--ucl-spacing-xl);position:relative;z-index:1}.app-header h1{font-size:2.5rem;font-weight:var(--ucl-font-weight-bold);margin:0 0 var(--ucl-spacing-sm) 0;text-shadow:0 2px 4px rgba(0,0,0,.2)}.app-header p{font-size:var(--ucl-font-size-lg);margin:0;opacity:.9;font-weight:var(--ucl-font-weight-medium)}.app-main{flex:1;min-height:calc(100vh - 200px)}.app-footer{background:var(--ucl-gray-800);color:var(--ucl-white);padding:var(--ucl-spacing-lg) 0;text-align:center;margin-top:var(--ucl-spacing-xxl)}.footer-content{max-width:1400px;margin:0 auto;padding:0 var(--ucl-spacing-xl)}.app-footer p{margin:0;font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-300)}.app-footer a{color:var(--ucl-accent);text-decoration:none;font-weight:var(--ucl-font-weight-medium);transition:color var(--ucl-transition)}.app-footer a:hover{color:var(--ucl-info);text-decoration:underline}.calendar-layout{display:grid;grid-template-columns:1fr 350px;gap:var(--ucl-spacing-xl);align-items:start}.calendar-main{min-width:0;display:flex;flex-direction:column;gap:var(--ucl-spacing-lg)}.calendar-sidebar{position:sticky;top:var(--ucl-spacing-xl);max-height:calc(100vh - 200px);overflow-y:auto}.upcoming-events-sidebar{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);border:1px solid var(--ucl-gray-200);overflow:hidden}.upcoming-events-sidebar h3{background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-accent));color:var(--ucl-white);margin:0;padding:var(--ucl-spacing-lg);font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);text-align:center}.events-list-sidebar{max-height:calc(100vh - 300px);overflow-y:auto;padding:var(--ucl-spacing-sm)}.events-list-sidebar::-webkit-scrollbar{width:6px}.events-list-sidebar::-webkit-scrollbar-track{background:var(--ucl-gray-100);border-radius:3px}.events-list-sidebar::-webkit-scrollbar-thumb{background:var(--ucl-gray-300);border-radius:3px}.events-list-sidebar::-webkit-scrollbar-thumb:hover{background:var(--ucl-gray-400)}.event-card-compact{background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);margin-bottom:var(--ucl-spacing-sm);transition:all var(--ucl-transition);overflow:hidden;position:relative}.event-card-compact:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--event-color, var(--ucl-primary))}.event-card-compact:hover{box-shadow:var(--ucl-shadow-md);transform:translateY(-1px)}.event-card-compact.icloud:before{background:var(--ucl-event-personal)}.event-card-compact.outlook:before{background:var(--ucl-event-academic)}.event-compact-content{padding:var(--ucl-spacing-md);padding-left:calc(var(--ucl-spacing-md) + 8px)}.event-compact-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--ucl-spacing-sm);gap:var(--ucl-spacing-sm)}.event-compact-title{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);margin:0;line-height:1.3;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-compact-datetime{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.event-compact-date{font-size:11px;font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-gray-600);background:var(--ucl-gray-100);padding:2px 6px;border-radius:var(--ucl-border-radius-sm);text-transform:uppercase}.event-compact-time{font-size:10px;color:var(--ucl-gray-500);font-weight:var(--ucl-font-weight-medium)}.event-compact-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--ucl-spacing-sm)}.btn-more-info{background:var(--ucl-primary);color:var(--ucl-white);border:none;padding:4px 8px;border-radius:var(--ucl-border-radius-sm);font-size:11px;font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition);flex-shrink:0}.btn-more-info:hover{background:var(--ucl-accent);transform:translateY(-1px);box-shadow:var(--ucl-shadow-sm)}.calendar-export-buttons{display:flex;gap:4px}.btn-export-google,.btn-export-outlook,.btn-export-ics{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-sm);width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ucl-transition);font-size:12px}.btn-export-google:hover{background:#4285f4;border-color:#4285f4;color:#fff;transform:translateY(-1px)}.btn-export-outlook:hover{background:#0078d4;border-color:#0078d4;color:#fff;transform:translateY(-1px)}.btn-export-ics:hover{background:var(--ucl-success);border-color:var(--ucl-success);color:#fff;transform:translateY(-1px)}.pagination-sidebar{display:flex;justify-content:center;align-items:center;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-md);background:var(--ucl-gray-50);border-top:1px solid var(--ucl-gray-200)}.nav-button-small{background:var(--ucl-primary);color:var(--ucl-white);border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:12px;font-weight:var(--ucl-font-weight-medium);transition:all var(--ucl-transition);display:flex;align-items:center;justify-content:center}.nav-button-small:hover:not(:disabled){background:var(--ucl-accent);transform:translateY(-1px);box-shadow:var(--ucl-shadow-sm)}.nav-button-small:disabled{background:var(--ucl-gray-300);cursor:not-allowed;opacity:.5}.page-info-small{font-size:11px;color:var(--ucl-gray-600);font-weight:var(--ucl-font-weight-medium);min-width:40px;text-align:center}.upcoming-events-sidebar .no-events{text-align:center;color:var(--ucl-gray-500);font-style:italic;padding:var(--ucl-spacing-xl);font-size:var(--ucl-font-size-sm)}@media (max-width: 1200px){.calendar-layout{grid-template-columns:1fr 300px;gap:var(--ucl-spacing-lg)}}@media (max-width: 1024px){.calendar-layout{grid-template-columns:1fr;gap:var(--ucl-spacing-lg)}.calendar-sidebar{position:static;max-height:none;order:-1}.upcoming-events-sidebar{max-height:400px}.events-list-sidebar{max-height:300px}}@media (max-width: 768px){.app-header h1{font-size:2rem}.app-header p{font-size:var(--ucl-font-size-base)}.header-content,.footer-content{padding:0 var(--ucl-spacing-md)}.calendar-container{padding:var(--ucl-spacing-md)}.upcoming-events-sidebar{max-height:300px}.events-list-sidebar{max-height:200px}.event-compact-header{flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-xs)}.event-compact-datetime{align-self:flex-end;flex-direction:row;gap:var(--ucl-spacing-xs)}.event-compact-actions{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-xs)}.calendar-export-buttons{justify-content:center}}.event-card-compact{animation:slideInRight .3s ease-out}.btn-export-google:focus,.btn-export-outlook:focus,.btn-export-ics:focus,.btn-more-info:focus,.nav-button-small:focus{outline:2px solid var(--ucl-accent);outline-offset:2px}.btn-export-google[title]:hover:after,.btn-export-outlook[title]:hover:after,.btn-export-ics[title]:hover:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--ucl-dark);color:var(--ucl-white);padding:4px 8px;border-radius:var(--ucl-border-radius-sm);font-size:10px;white-space:nowrap;z-index:1000;margin-bottom:4px}.export-buttons-modal{display:flex;flex-direction:column;gap:var(--ucl-spacing-sm);margin-top:var(--ucl-spacing-sm)}.btn-export-modal{display:flex;align-items:center;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);background:var(--ucl-white);color:var(--ucl-text-primary);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition);text-align:left;width:100%}.btn-export-modal:hover{transform:translateY(-1px);box-shadow:var(--ucl-shadow-md)}.btn-export-google-modal:hover{background:#4285f4;border-color:#4285f4;color:#fff}.btn-export-outlook-modal:hover{background:#0078d4;border-color:#0078d4;color:#fff}.btn-export-ics-modal:hover{background:var(--ucl-success);border-color:var(--ucl-success);color:#fff}@media (max-width: 768px){.export-buttons-modal{flex-direction:column}.btn-export-modal{justify-content:center;text-align:center}}@media (max-width: 768px){.calendar-container{padding:0}.calendar-main-title{font-size:1.8rem}.calendar-main-subtitle{font-size:1rem}.calendar-header{flex-direction:column;gap:var(--ucl-spacing-md);padding:var(--ucl-spacing-md)}.header-controls{flex-direction:column;width:100%;gap:var(--ucl-spacing-sm)}.filter-select{width:100%}.calendar-nav{flex-wrap:wrap;justify-content:center;gap:var(--ucl-spacing-sm)}.nav-button{font-size:12px;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);min-height:36px}.month-year{font-size:1.25rem;text-align:center}.calendar-content{margin:0 var(--ucl-spacing-sm)}.calendar-day{min-height:80px;padding:var(--ucl-spacing-xs)}.weekday{padding:var(--ucl-spacing-sm) var(--ucl-spacing-xs);font-size:12px}.event-item{font-size:10px;padding:1px var(--ucl-spacing-xs)}.week-view{height:600px}.week-header,.week-grid{grid-template-columns:80px repeat(7,1fr)}.upcoming-events{margin:var(--ucl-spacing-lg) var(--ucl-spacing-sm) 0;padding:var(--ucl-spacing-md)}}@media (min-width: 769px) and (max-width: 1024px){.calendar-container{padding:0}.calendar-content{margin:0 var(--ucl-spacing-md)}.calendar-day{min-height:100px}.upcoming-events{margin:var(--ucl-spacing-xl) var(--ucl-spacing-md) 0}}@media (min-width: 1025px){.calendar-container{max-width:1800px}.calendar-main-title{font-size:3rem}.calendar-main-subtitle{font-size:1.25rem}.calendar-day{min-height:140px}.week-view{height:900px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (prefers-color-scheme: dark){:root{--ucl-bg-primary: #1e293b;--ucl-bg-secondary: #334155;--ucl-text-primary: #f1f5f9;--ucl-text-secondary: #cbd5e1;--ucl-border: #475569}}.calendar-footer{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:#fff;margin-top:var(--ucl-spacing-xxl);padding:var(--ucl-spacing-xxl) 0 var(--ucl-spacing-lg)}.footer-content{max-width:1600px;margin:0 auto;padding:0 var(--ucl-spacing-lg);display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--ucl-spacing-xl)}.footer-section h4{color:#fff;font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);margin-bottom:var(--ucl-spacing-md);border-bottom:2px solid rgba(255,255,255,.2);padding-bottom:var(--ucl-spacing-xs)}.footer-section p{margin-bottom:var(--ucl-spacing-sm);line-height:1.6;color:#ffffffe6}.footer-link{color:#ffffffe6;text-decoration:none;transition:all var(--ucl-transition);border-bottom:1px solid transparent}.footer-link:hover{color:#fff;border-bottom-color:#ffffff80}.footer-bottom{border-top:1px solid rgba(255,255,255,.2);margin-top:var(--ucl-spacing-xl);padding-top:var(--ucl-spacing-lg);text-align:center}.footer-bottom p{margin:0;color:#fffc;font-size:var(--ucl-font-size-sm)}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:var(--ucl-spacing-lg);padding:0 var(--ucl-spacing-md)}.calendar-footer{padding:var(--ucl-spacing-xl) 0 var(--ucl-spacing-md)}}.week-event{border-radius:var(--ucl-border-radius-sm);padding:var(--ucl-spacing-xs);margin:1px;cursor:pointer;transition:all var(--ucl-transition);overflow:hidden;text-overflow:ellipsis;font-size:11px;line-height:1.2;color:var(--ucl-white);text-shadow:0 1px 2px rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.week-event:hover{transform:scale(1.02);box-shadow:0 2px 8px #0003;z-index:100}.week-event.icloud{background:linear-gradient(135deg,var(--ucl-color-1),var(--ucl-color-3))}.week-event.outlook{background:linear-gradient(135deg,var(--ucl-color-2),var(--ucl-color-4))}.week-event .event-time{font-weight:var(--ucl-font-weight-semibold);font-size:10px;opacity:.9}.week-event .event-title{font-weight:var(--ucl-font-weight-medium);margin-top:2px}.day-number{font-weight:var(--ucl-font-weight-semibold);margin-bottom:var(--ucl-spacing-xs);font-size:var(--ucl-font-size-sm);color:var(--ucl-dark);flex-shrink:0;position:relative;z-index:1}.calendar-day.today .day-number{color:var(--ucl-white)!important;background:var(--ucl-primary)!important;font-weight:var(--ucl-font-weight-bold)!important;width:28px!important;height:28px!important;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:13px!important;margin-bottom:var(--ucl-spacing-xs)!important;position:relative!important;z-index:10!important;box-shadow:0 2px 4px #003d7a4d!important}.calendar-day .day-number{text-shadow:none;background:transparent}.calendar-day.other-month .day-number{color:var(--ucl-gray-400)}.legend-title{color:var(--ucl-primary);font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);margin-bottom:var(--ucl-spacing-md);text-align:center;position:relative;padding-bottom:var(--ucl-spacing-sm)}.legend-title:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40px;height:2px;background:var(--ucl-primary);border-radius:1px}.legend-sections{display:grid;grid-template-columns:1fr 1fr;gap:var(--ucl-spacing-xl)}.legend-section{display:flex;flex-direction:column}.legend-section-title{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);margin-bottom:var(--ucl-spacing-sm);text-transform:uppercase;letter-spacing:.5px}.legend-items{display:flex;flex-direction:column;gap:var(--ucl-spacing-sm)}.legend-item{display:flex;align-items:center;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);transition:all var(--ucl-transition)}.legend-item:hover{background:var(--ucl-gray-50)}.legend-color{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.3);box-shadow:0 1px 2px #0000001a}.legend-icon{font-size:14px;flex-shrink:0}.legend-label{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-primary);font-weight:var(--ucl-font-weight-medium);flex:1}.legend-code{font-size:11px;color:var(--ucl-gray-500);font-weight:var(--ucl-font-weight-medium);background:var(--ucl-gray-100);padding:2px 6px;border-radius:var(--ucl-border-radius-sm);font-family:Consolas,Monaco,Courier New,monospace}.category-filter{position:relative}.category-filter-select{background:var(--ucl-white);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);font-size:var(--ucl-font-size-sm);font-family:var(--ucl-font-family);color:var(--ucl-text-primary);cursor:pointer;transition:all var(--ucl-transition);min-width:160px}.category-filter-select:hover{border-color:var(--ucl-primary);box-shadow:0 2px 4px #003d7a1a}.category-filter-select:focus{outline:none;border-color:var(--ucl-primary);box-shadow:0 0 0 3px #003d7a1a}.event-item.category-colloque{background:transparent!important;color:#003d7a!important;border:2px solid #003d7a!important;border-left:4px solid #003d7a!important}.event-item.category-these{background:transparent!important;color:#06c!important;border:2px solid #0066cc!important;border-left:4px solid #0066cc!important}.event-item.category-seminaire{background:transparent!important;color:#4a90e2!important;border:2px solid #4a90e2!important;border-left:4px solid #4a90e2!important}.event-item.category-other{background:transparent!important;color:#27ae60!important;border:2px solid #27ae60!important;border-left:4px solid #27ae60!important}.week-event.category-colloque{background:linear-gradient(135deg,#003d7a,#1e5aa8)}.week-event.category-these{background:linear-gradient(135deg,#06c,#3d8bfd)}.week-event.category-seminaire{background:linear-gradient(135deg,#4a90e2,#74a9f7)}.week-event.category-other{background:linear-gradient(135deg,#27ae60,#52c788)}.event-card-compact.category-colloque:before{background:#003d7a}.event-card-compact.category-these:before{background:#06c}.event-card-compact.category-seminaire:before{background:#4a90e2}.event-card-compact.category-other:before{background:#27ae60}@media (max-width: 768px){.event-legend{padding:var(--ucl-spacing-md);margin-bottom:var(--ucl-spacing-md)}.legend-sections{grid-template-columns:1fr;gap:var(--ucl-spacing-lg)}.legend-items{gap:var(--ucl-spacing-xs)}.legend-item{padding:var(--ucl-spacing-xs)}.legend-label{font-size:12px}.category-filter-select{width:100%;min-width:auto}}.agenda-event.category-colloque .time-dot{background-color:#003d7a!important}.agenda-event.category-these .time-dot{background-color:#06c!important}.agenda-event.category-seminaire .time-dot{background-color:#4a90e2!important}.agenda-event.category-other .time-dot{background-color:#27ae60!important}.agenda-event.category-colloque .event-category{background-color:#003d7a!important}.agenda-event.category-these .event-category{background-color:#06c!important}.agenda-event.category-seminaire .event-category{background-color:#4a90e2!important}.agenda-event.category-other .event-category{background-color:#27ae60!important}.calendar-legend-section{margin:var(--ucl-spacing-xl) var(--ucl-spacing-lg) 0;max-width:1600px;width:100%}.calendar-legend-section .event-legend{margin-bottom:0}.event-item.icloud,.week-event.icloud{background:transparent!important;color:#ff5252!important;border:2px solid #ff5252!important;border-left:4px solid #ff5252!important}.event-item.outlook,.week-event.outlook{background:transparent!important;color:#06c!important;border:2px solid #0066cc!important;border-left:4px solid #0066cc!important}@media (max-width: 768px){.calendar-legend-section{margin:var(--ucl-spacing-lg) var(--ucl-spacing-sm) 0}}.event-legend{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);border:1px solid var(--ucl-gray-200);padding:var(--ucl-spacing-lg);margin-bottom:var(--ucl-spacing-lg)}.legend-title{color:var(--ucl-primary);font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);margin-bottom:var(--ucl-spacing-lg);text-align:center;position:relative;padding-bottom:var(--ucl-spacing-sm)}.legend-title:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--ucl-primary),var(--ucl-secondary));border-radius:2px}.legend-sections{display:flex;justify-content:space-around;gap:var(--ucl-spacing-xl);flex-wrap:wrap}.legend-section{flex:1;min-width:250px}.legend-section-title{color:var(--ucl-secondary);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-semibold);margin-bottom:var(--ucl-spacing-md);text-transform:uppercase;letter-spacing:.5px;text-align:center}.legend-items{display:flex;flex-direction:row;justify-content:center;gap:var(--ucl-spacing-lg);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);transition:all var(--ucl-transition);background:var(--ucl-gray-50);border:1px solid var(--ucl-gray-200)}.legend-item:hover{background:var(--ucl-gray-100);transform:translateY(-1px);box-shadow:var(--ucl-shadow-sm)}.legend-color{width:16px;height:16px;border-radius:50%;flex-shrink:0;border:2px solid rgba(255,255,255,.8);box-shadow:0 1px 3px #0003}.legend-icon{font-size:16px;flex-shrink:0}.legend-label{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-primary);font-weight:var(--ucl-font-weight-medium);white-space:nowrap}.legend-code{font-size:11px;color:var(--ucl-gray-500);font-weight:var(--ucl-font-weight-medium);background:var(--ucl-gray-200);padding:2px 6px;border-radius:var(--ucl-border-radius-sm);font-family:Consolas,Monaco,Courier New,monospace}@media (max-width: 768px){.legend-sections{flex-direction:column;gap:var(--ucl-spacing-lg)}.legend-items{gap:var(--ucl-spacing-sm)}.legend-item{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm)}.legend-label{font-size:12px}}.event-item{background:var(--ucl-white)!important;font-weight:var(--ucl-font-weight-semibold)!important;font-size:11px!important;line-height:1.2!important;border:2px solid var(--ucl-gray-300)!important;border-radius:var(--ucl-border-radius)!important}.week-event{color:var(--ucl-white)!important;font-weight:var(--ucl-font-weight-semibold)!important;text-shadow:0 1px 2px rgba(0,0,0,.4)!important}.week-event.icloud{background:linear-gradient(135deg,#ff6b6b,#ff5252)!important}.week-event.outlook{background:linear-gradient(135deg,#003d7a,#06c)!important}.agenda-event-card{background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-lg);margin-bottom:var(--ucl-spacing-md);overflow:hidden;transition:all var(--ucl-transition);box-shadow:var(--ucl-shadow-sm)}.agenda-event-card:hover{box-shadow:var(--ucl-shadow-md);transform:translateY(-1px)}.agenda-event-header{display:flex;align-items:center;padding:var(--ucl-spacing-md);cursor:pointer;gap:var(--ucl-spacing-md)}.agenda-event-header .event-time-indicator{display:flex;align-items:center;gap:var(--ucl-spacing-sm);flex-shrink:0}.agenda-event-header .time-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.agenda-event-header .event-time{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);color:var(--ucl-gray-600);min-width:120px}.event-main-info{flex:1;display:flex;flex-direction:column;gap:var(--ucl-spacing-xs)}.agenda-event-header .event-title{margin:0;font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);line-height:1.3}.event-source-badge{font-size:11px;color:var(--ucl-gray-500);font-weight:var(--ucl-font-weight-medium);background:var(--ucl-gray-100);padding:2px 8px;border-radius:var(--ucl-border-radius-sm);width:fit-content}.expand-button{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-300);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ucl-transition);color:var(--ucl-gray-600);font-size:12px;flex-shrink:0}.expand-button:hover{background:var(--ucl-primary);color:var(--ucl-white);transform:scale(1.1)}.expand-button.expanded{background:var(--ucl-primary);color:var(--ucl-white)}.agenda-event-details{padding:0 var(--ucl-spacing-md) var(--ucl-spacing-md);border-top:1px solid var(--ucl-gray-200);background:var(--ucl-gray-50);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:500px;padding-top:var(--ucl-spacing-md);padding-bottom:var(--ucl-spacing-md)}}.event-detail-item{display:flex;align-items:flex-start;gap:var(--ucl-spacing-sm);margin-bottom:var(--ucl-spacing-md)}.event-detail-item:last-child{margin-bottom:0}.detail-icon{font-size:16px;flex-shrink:0;margin-top:2px}.detail-text{flex:1;color:var(--ucl-text-primary);line-height:1.5}.event-description-full{font-size:var(--ucl-font-size-sm);line-height:1.6}.event-actions{margin-top:var(--ucl-spacing-md);padding-top:var(--ucl-spacing-md);border-top:1px solid var(--ucl-gray-200)}.btn-view-details{background:var(--ucl-primary);color:var(--ucl-white);border:none;padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition)}.btn-view-details:hover{background:var(--ucl-secondary);transform:translateY(-1px);box-shadow:var(--ucl-shadow-sm)}@media (max-width: 768px){.agenda-event-header{flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-sm)}.agenda-event-header .event-time{min-width:auto}.expand-button{align-self:flex-end;margin-top:var(--ucl-spacing-sm)}}.event-item,.week-event,.agenda-event-card{border:1px solid;border-radius:var(--ucl-border-radius);font-weight:var(--ucl-font-weight-medium);transition:all var(--ucl-transition)}.event-item:hover,.week-event:hover,.agenda-event-card:hover{transform:translateY(-1px);box-shadow:var(--ucl-shadow-md)}.week-event{padding:4px 6px;border-radius:var(--ucl-border-radius-sm);font-size:var(--ucl-font-size-sm);line-height:1.2;cursor:pointer;overflow:hidden}.week-event .event-time{font-size:11px;font-weight:var(--ucl-font-weight-semibold);opacity:.9}.week-event .event-title{font-size:12px;font-weight:var(--ucl-font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-item{padding:4px 8px;margin:2px 0;border-radius:var(--ucl-border-radius);font-size:12px;font-weight:var(--ucl-font-weight-semibold);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4;min-height:20px;display:flex;align-items:center;box-shadow:0 1px 3px #00000026;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.agenda-event-card{background:var(--ucl-bg-primary);border:1px solid var(--ucl-border);border-radius:var(--ucl-border-radius);margin-bottom:var(--ucl-spacing-sm);overflow:hidden}.time-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.event-dot{width:6px;height:6px;border-radius:50%;margin:1px;cursor:pointer;transition:transform var(--ucl-transition-fast)}.event-dot:hover{transform:scale(1.3)}.event-item{position:relative}.event-item:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffff1a;pointer-events:none;border-radius:inherit}.event-item[style*="color: rgb(255, 255, 255)"],.event-item[style*="color: #ffffff"]{text-shadow:0 1px 2px rgba(0,0,0,.5)}.event-item[style*="color: rgb(0, 0, 0)"],.event-item[style*="color: #000000"]{text-shadow:0 1px 2px rgba(255,255,255,.5)}.event-item{letter-spacing:.3px}.event-item:focus{outline:2px solid var(--ucl-primary);outline-offset:2px;z-index:30}.calendar-day{border-right:1px solid var(--ucl-gray-300);border-bottom:1px solid var(--ucl-gray-300)}.calendar-day.other-month{background:#fafafa;color:#999}.calendar-day.other-month .event-item{opacity:.7}.calendar-day:hover{background:#f8f9fa;border-color:var(--ucl-primary)}.calendar-day.today{background:linear-gradient(135deg,#003d7a0d,#0066cc0d);border:2px solid var(--ucl-primary)}.calendar-day.today .day-number{background:var(--ucl-primary);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:var(--ucl-font-weight-bold)}.display-view{background:var(--ucl-white);min-height:100vh;font-family:var(--ucl-font-family)}.display-header{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);padding:var(--ucl-spacing-xl) var(--ucl-spacing-lg);text-align:center;box-shadow:0 4px 20px #003d7a4d;position:relative;overflow:hidden}.display-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.3}.display-title{font-size:2.2rem;font-weight:700;margin:0 0 var(--ucl-spacing-sm) 0;position:relative;z-index:1;text-shadow:0 2px 4px rgba(0,0,0,.2)}.display-period{font-size:1.1rem;font-weight:500;margin:0;opacity:.9;position:relative;z-index:1;background:#ffffff1a;padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius-lg);display:inline-block;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.display-content{padding:var(--ucl-spacing-xl) var(--ucl-spacing-lg);max-width:1200px;margin:0 auto}.display-day{margin-bottom:var(--ucl-spacing-xxl);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);overflow:hidden;border:1px solid var(--ucl-gray-200);transition:all var(--ucl-transition)}.display-day.current-day{border-color:var(--ucl-primary);box-shadow:0 8px 25px #003d7a26;transform:scale(1.02)}.display-day-header{background:linear-gradient(135deg,var(--ucl-gray-50) 0%,var(--ucl-gray-100) 100%);padding:var(--ucl-spacing-lg);border-bottom:2px solid var(--ucl-gray-200);display:flex;justify-content:space-between;align-items:center}.display-day.current-day .display-day-header{background:linear-gradient(135deg,#003d7a0d,#0066cc0d);border-bottom-color:var(--ucl-primary)}.display-day-title{font-size:1.4rem;font-weight:600;color:var(--ucl-primary);margin:0;text-transform:capitalize}.display-day-count{background:var(--ucl-primary);color:var(--ucl-white);padding:var(--ucl-spacing-xs) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius-lg);font-size:var(--ucl-font-size-sm);font-weight:600;box-shadow:var(--ucl-shadow-sm)}.display-events-list{padding:var(--ucl-spacing-lg)}.display-no-events{text-align:center;padding:var(--ucl-spacing-xxl);color:var(--ucl-gray-500);display:flex;flex-direction:column;align-items:center;gap:var(--ucl-spacing-sm)}.no-events-icon{font-size:3rem;opacity:.5}.no-events-text{font-size:1.1rem;font-weight:500;font-style:italic}.display-event-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--ucl-spacing-lg);margin-bottom:var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);transition:all var(--ucl-transition);cursor:pointer;position:relative;overflow:hidden}.display-event-item:last-child{margin-bottom:0}.display-event-item:hover{transform:translate(8px);box-shadow:0 4px 15px #00000026!important}.display-event-item:before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;transition:width var(--ucl-transition)}.display-event-item:hover:before{width:12px}.display-event-main{flex:1;display:flex;flex-direction:column;gap:var(--ucl-spacing-sm)}.display-event-time{display:flex;align-items:center;gap:var(--ucl-spacing-sm);font-size:var(--ucl-font-size-sm);font-weight:600;opacity:.9}.time-icon{font-size:14px}.time-text{background:#0000001a;padding:2px 8px;border-radius:var(--ucl-border-radius-sm);font-family:Consolas,Monaco,monospace}.display-event-title{font-size:1.2rem;font-weight:600;line-height:1.4;margin:var(--ucl-spacing-xs) 0}.display-event-location{display:flex;align-items:center;gap:var(--ucl-spacing-sm);font-size:var(--ucl-font-size-sm);opacity:.8;font-weight:500}.location-icon{font-size:12px}.location-text{background:#0000000d;padding:2px 6px;border-radius:var(--ucl-border-radius-sm)}.display-event-source{flex-shrink:0;margin-left:var(--ucl-spacing-md)}.source-badge{display:inline-block;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#0000001a;color:inherit;border:1px solid rgba(0,0,0,.2)}.source-badge.icloud{background:#ff6b6b33;border-color:#ff6b6b66}.source-badge.outlook{background:#003d7a33;border-color:#003d7a66}.display-footer{background:var(--ucl-gray-100);border-top:2px solid var(--ucl-gray-200);padding:var(--ucl-spacing-lg);margin-top:var(--ucl-spacing-xxl)}.display-footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--ucl-spacing-md)}.display-footer-logo{display:flex;align-items:center;gap:var(--ucl-spacing-sm);color:var(--ucl-primary);font-weight:600}.ucl-logo{font-size:1.5rem}.ucl-text{font-size:1rem}.display-footer-time{font-size:var(--ucl-font-size-sm);color:var(--ucl-gray-600);font-style:italic}@media (max-width: 768px){.display-title{font-size:1.8rem}.display-period{font-size:1rem;padding:var(--ucl-spacing-xs) var(--ucl-spacing-md)}.display-content{padding:var(--ucl-spacing-lg) var(--ucl-spacing-md)}.display-day-header{flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-sm)}.display-day-title{font-size:1.2rem}.display-event-item{flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-md)}.display-event-source{margin-left:0;align-self:flex-end}.display-footer-content{flex-direction:column;text-align:center}}@media (max-width: 480px){.display-title{font-size:1.5rem}.display-event-title{font-size:1.1rem}.display-event-item:hover{transform:none}}.display-view{animation:displayFadeIn .6s ease-out}@keyframes displayFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.display-day{animation:displaySlideIn .4s ease-out;animation-fill-mode:both}.display-day:nth-child(1){animation-delay:.1s}.display-day:nth-child(2){animation-delay:.2s}.display-day:nth-child(3){animation-delay:.3s}.display-day:nth-child(4){animation-delay:.4s}.display-day:nth-child(5){animation-delay:.5s}.display-day:nth-child(6){animation-delay:.6s}.display-day:nth-child(7){animation-delay:.7s}@keyframes displaySlideIn{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.view-selector{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.view-buttons{display:flex;background:var(--ucl-gray-100);border-radius:var(--ucl-border-radius-lg);padding:4px;box-shadow:var(--ucl-shadow-sm);border:1px solid var(--ucl-gray-200)}.view-button{display:flex;align-items:center;gap:var(--ucl-spacing-xs);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border:none;background:transparent;color:var(--ucl-gray-600);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);font-family:var(--ucl-font-family);border-radius:var(--ucl-border-radius);cursor:pointer;transition:all var(--ucl-transition);position:relative;overflow:hidden}.view-button:hover{background:var(--ucl-white);color:var(--ucl-primary);box-shadow:var(--ucl-shadow-sm)}.view-button.active{background:var(--ucl-primary);color:var(--ucl-white);box-shadow:var(--ucl-shadow-md);font-weight:var(--ucl-font-weight-semibold)}.view-button.active[title=Affichage]{background:linear-gradient(135deg,var(--ucl-success) 0%,var(--ucl-info) 100%);animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 8px #10b98100}}.view-icon{font-size:16px;line-height:1}.view-label{font-size:var(--ucl-font-size-sm);white-space:nowrap}@media (max-width: 768px){.view-buttons{flex-wrap:wrap}.view-button{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm)}.view-label{display:none}.view-icon{font-size:18px}}.calendar-layout.display-mode{display:block}.calendar-layout.display-mode .calendar-main{width:100%;max-width:none}.display-mode+.calendar-legend-section{display:none}.display-mode .calendar-main-header{display:none}.view-button[title=Affichage]{position:relative}.view-button[title=Affichage]:after{content:"🔴";position:absolute;top:-2px;right:-2px;font-size:8px;animation:blink 1.5s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.event-item{font-weight:600!important;text-shadow:0 1px 2px rgba(0,0,0,.3)!important;border:2px solid transparent!important;color:#fff!important}.event-item:hover{border-color:#ffffff80!important;transform:translateY(-1px) scale(1.02);box-shadow:0 4px 12px #0000004d!important}.event-item.icloud{background:transparent!important;color:#ff5252!important;border:2px solid #ff5252!important;border-left:4px solid #ff5252!important}.event-item.outlook{background:transparent!important;color:#06c!important;border:2px solid #0066cc!important;border-left:4px solid #0066cc!important}.display-mode-toggle{margin-top:var(--ucl-spacing-lg);position:relative;z-index:2}.display-mode-button{background:linear-gradient(135deg,var(--ucl-success) 0%,var(--ucl-info) 100%);color:var(--ucl-white);border:none;padding:var(--ucl-spacing-md) var(--ucl-spacing-xl);border-radius:var(--ucl-border-radius-lg);font-size:var(--ucl-font-size-base);font-weight:600;font-family:var(--ucl-font-family);cursor:pointer;transition:all var(--ucl-transition);box-shadow:0 4px 15px #10b9814d;position:relative;overflow:hidden}.display-mode-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left var(--ucl-transition)}.display-mode-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.display-mode-button:hover:before{left:100%}.display-mode-button:active{transform:translateY(-1px)}.display-mode-header{background:linear-gradient(135deg,var(--ucl-dark) 0%,var(--ucl-gray-800) 100%);color:var(--ucl-white);padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000004d;position:sticky;top:0;z-index:1000}.back-to-calendar-button{background:#ffffff1a;color:var(--ucl-white);border:1px solid rgba(255,255,255,.2);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:500;font-family:var(--ucl-font-family);cursor:pointer;transition:all var(--ucl-transition);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-to-calendar-button:hover{background:#fff3;border-color:#fff6;transform:translate(-2px)}.display-mode-title{display:flex;align-items:center;gap:var(--ucl-spacing-sm);font-size:1.1rem;font-weight:600}.live-indicator{animation:pulse-red 2s infinite;font-size:12px}@keyframes pulse-red{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@media (max-width: 768px){.display-mode-button{padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);font-size:var(--ucl-font-size-sm)}.display-mode-header{padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);flex-direction:column;gap:var(--ucl-spacing-sm)}.back-to-calendar-button{align-self:flex-start}.display-mode-title{font-size:1rem}}.display-no-events-global{text-align:center;padding:var(--ucl-spacing-xxl);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);margin:var(--ucl-spacing-xl) 0;border:1px solid var(--ucl-gray-200)}.display-no-events-global .no-events-icon{font-size:4rem;margin-bottom:var(--ucl-spacing-lg);opacity:.5}.display-no-events-global h3{color:var(--ucl-text-secondary);font-size:1.5rem;margin-bottom:var(--ucl-spacing-md);font-weight:600}.display-no-events-global p{color:var(--ucl-text-secondary);font-size:var(--ucl-font-size-base);margin:0;font-style:italic}.calendar-filters-section{background:linear-gradient(135deg,var(--ucl-gray-50) 0%,var(--ucl-white) 100%);border-bottom:1px solid var(--ucl-gray-200);padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);box-shadow:0 2px 4px #0000000d}.filters-container{max-width:1600px;margin:0 auto;display:flex;align-items:center;gap:var(--ucl-spacing-lg);flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.filter-label{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.filter-select{padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-family:var(--ucl-font-family);background:var(--ucl-white);color:var(--ucl-text-primary);transition:all var(--ucl-transition);min-width:150px;box-shadow:var(--ucl-shadow-sm)}.filter-select:focus{outline:none;border-color:var(--ucl-primary);box-shadow:0 0 0 2px #003d7a1a}.filter-select:hover{border-color:var(--ucl-primary)}.filter-stats{margin-left:auto;display:flex;align-items:center;gap:var(--ucl-spacing-sm);font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);background:var(--ucl-white);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);border:1px solid var(--ucl-gray-200);box-shadow:var(--ucl-shadow-sm)}.stats-total{font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary)}.sidebar-section.full-height{flex:1;display:flex;flex-direction:column;padding:var(--ucl-spacing-lg);border-bottom:none}.sidebar-event-card{margin-bottom:var(--ucl-spacing-md);background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-lg);overflow:hidden;transition:all var(--ucl-transition);position:relative;box-shadow:var(--ucl-shadow-sm)}.sidebar-event-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ucl-primary)}.sidebar-event-card:hover{box-shadow:var(--ucl-shadow-lg);transform:translateY(-2px);border-color:var(--ucl-primary)}.sidebar-event-title{margin:0;font-size:var(--ucl-font-size-base);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);line-height:1.3;flex:1}.sidebar-event-content{padding:var(--ucl-spacing-md)}.sidebar-event-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--ucl-spacing-sm);gap:var(--ucl-spacing-sm)}.sidebar-event-datetime{display:flex;flex-direction:column;gap:var(--ucl-spacing-xs);margin-bottom:var(--ucl-spacing-sm)}.sidebar-event-date,.sidebar-event-time{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);display:flex;align-items:center;gap:var(--ucl-spacing-xs)}.sidebar-event-location{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);margin-bottom:var(--ucl-spacing-sm);display:flex;align-items:center;gap:var(--ucl-spacing-xs)}.sidebar-event-description{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);line-height:1.4;margin-bottom:var(--ucl-spacing-md);background:var(--ucl-gray-50);padding:var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm);border-left:3px solid var(--ucl-primary)}.sidebar-event-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--ucl-spacing-sm)}.btn-sidebar-info{background:var(--ucl-primary);color:var(--ucl-white);border:none;padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition);display:flex;align-items:center;gap:var(--ucl-spacing-xs)}.btn-sidebar-info:hover{background:var(--ucl-secondary);transform:translateY(-1px);box-shadow:var(--ucl-shadow-md)}.sidebar-export-buttons{display:flex;gap:var(--ucl-spacing-xs)}.btn-sidebar-export{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-300);color:var(--ucl-text-secondary);padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius-sm);cursor:pointer;transition:all var(--ucl-transition);font-size:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.btn-sidebar-export:hover{transform:translateY(-1px);box-shadow:var(--ucl-shadow-sm)}.btn-sidebar-export.google:hover{background:#4285f4;color:#fff;border-color:#4285f4}.btn-sidebar-export.outlook:hover{background:#0078d4;color:#fff;border-color:#0078d4}.btn-sidebar-export.ics:hover{background:var(--ucl-success);color:#fff;border-color:var(--ucl-success)}@media (max-width: 1200px){.filters-container{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-md)}.filter-stats{margin-left:0;justify-content:center}}@media (max-width: 768px){.calendar-filters-section{padding:var(--ucl-spacing-sm) var(--ucl-spacing-md)}.filters-container{gap:var(--ucl-spacing-sm)}.filter-group{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-xs)}.filter-select{min-width:auto}.filter-stats{flex-direction:column;text-align:center;gap:var(--ucl-spacing-xs)}}.calendar-filters-section{background:var(--ucl-white);border-bottom:1px solid var(--ucl-gray-200);box-shadow:0 2px 4px #0000000d}.filters-container-inline{max-width:1600px;margin:0 auto;padding:var(--ucl-spacing-md) var(--ucl-spacing-lg)}.filters-row{display:flex;align-items:center;gap:var(--ucl-spacing-lg);flex-wrap:wrap}.filter-group-compact{display:flex;align-items:center;gap:var(--ucl-spacing-sm);white-space:nowrap}.filter-label-compact{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary);margin:0}.filter-select-compact{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-family:var(--ucl-font-family);background:var(--ucl-white);color:var(--ucl-text-primary);min-width:100px;transition:all var(--ucl-transition)}.filter-select-compact:focus{outline:none;border-color:var(--ucl-primary);box-shadow:0 0 0 2px #003d7a1a}.filter-stats-compact{margin-left:auto;display:flex;align-items:center;gap:var(--ucl-spacing-xs);font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary)}.stats-total{font-weight:var(--ucl-font-weight-medium);color:var(--ucl-primary)}.stats-filtered{color:var(--ucl-warning);font-weight:var(--ucl-font-weight-medium)}.stats-found{color:var(--ucl-success);font-weight:var(--ucl-font-weight-semibold)}.event-legend{background:var(--ucl-gray-50);border-top:1px solid var(--ucl-gray-200);padding:var(--ucl-spacing-md) var(--ucl-spacing-lg)}.legend-sections-inline{max-width:1600px;margin:0 auto;display:flex;gap:var(--ucl-spacing-xxl);flex-wrap:wrap;align-items:center}.legend-section-inline{display:flex;align-items:center;gap:var(--ucl-spacing-md)}.legend-section-title-inline{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);margin:0;white-space:nowrap}.legend-items-inline{display:flex;gap:var(--ucl-spacing-md);flex-wrap:wrap}.legend-item-inline{display:flex;align-items:center;gap:var(--ucl-spacing-xs);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);background:var(--ucl-white);border:1px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);transition:all var(--ucl-transition)}.legend-item-inline:hover{box-shadow:var(--ucl-shadow-sm);transform:translateY(-1px)}.legend-color-inline{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.1)}.legend-icon-inline{font-size:14px;flex-shrink:0}.legend-label-inline{font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-primary);white-space:nowrap}.agenda-filters{display:flex;align-items:center;gap:var(--ucl-spacing-lg);flex-wrap:wrap;margin-bottom:var(--ucl-spacing-md)}.date-range-controls{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.date-range-controls label{font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary);white-space:nowrap;font-size:var(--ucl-font-size-sm)}.range-select{padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border:1px solid var(--ucl-gray-300);border-radius:var(--ucl-border-radius);font-family:var(--ucl-font-family);background:var(--ucl-white);color:var(--ucl-text-primary);min-width:120px;font-size:var(--ucl-font-size-sm)}.past-events-toggle{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.past-events-toggle label{display:flex;align-items:center;gap:var(--ucl-spacing-sm);cursor:pointer;font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-secondary);font-size:var(--ucl-font-size-sm)}@media (max-width: 768px){.filters-row{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-md)}.filter-group-compact{justify-content:space-between}.filter-stats-compact{margin-left:0;justify-content:center;padding-top:var(--ucl-spacing-sm);border-top:1px solid var(--ucl-gray-200)}.legend-sections-inline{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-lg)}.legend-section-inline{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-sm)}.legend-items-inline{justify-content:center}.agenda-filters{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-md)}}.search-results-section{margin-top:var(--ucl-spacing-xl);padding:var(--ucl-spacing-lg);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);border:1px solid var(--ucl-gray-200)}.search-result-title{font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-text-primary);margin:0;line-height:1.3;flex:1;margin-right:var(--ucl-spacing-sm)}.search-result-datetime{display:flex;gap:var(--ucl-spacing-lg);margin-bottom:var(--ucl-spacing-sm);font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary)}.search-result-description{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);line-height:1.4;margin-bottom:var(--ucl-spacing-md);padding:var(--ucl-spacing-sm);background:var(--ucl-gray-50);border-radius:var(--ucl-border-radius);border-left:3px solid var(--ucl-primary)}.no-results-icon{font-size:4rem;margin-bottom:var(--ucl-spacing-lg)}.display-header-compact{text-align:center;padding:var(--ucl-spacing-lg) 0;background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);border-radius:var(--ucl-border-radius-lg) var(--ucl-border-radius-lg) 0 0;margin-bottom:var(--ucl-spacing-lg)}.display-title-compact{font-size:var(--ucl-font-size-xxl);font-weight:var(--ucl-font-weight-bold);margin:0 0 var(--ucl-spacing-sm) 0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.display-period-compact{font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-medium);opacity:.9}.display-content-compact{padding:0 var(--ucl-spacing-lg);min-height:60vh;display:flex;align-items:center;justify-content:center}.display-events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--ucl-spacing-lg);width:100%;max-width:1400px;margin:0 auto}.display-event-card{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);overflow:hidden;transition:all var(--ucl-transition);cursor:pointer;display:flex;min-height:200px;max-height:400px;border:3px solid transparent}.display-event-card.icloud{border-left:6px solid #ff5252}.display-event-card.outlook{border-left:6px solid #0066cc}.display-event-date-badge{background:linear-gradient(135deg,var(--ucl-primary),var(--ucl-secondary));color:var(--ucl-white);padding:var(--ucl-spacing-md);display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:80px;text-align:center}.event-day{font-size:2rem;font-weight:var(--ucl-font-weight-bold);line-height:1}.event-month{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--ucl-spacing-xs)}.display-event-content{flex:1;padding:var(--ucl-spacing-md);display:flex;flex-direction:column;justify-content:space-between}.display-event-time-compact{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);font-weight:var(--ucl-font-weight-medium);margin-bottom:var(--ucl-spacing-xs)}.display-event-title-compact{font-size:var(--ucl-font-size-md);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-text-primary);line-height:1.4;margin-bottom:var(--ucl-spacing-sm);flex:1;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.display-event-location-compact{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);margin-bottom:var(--ucl-spacing-sm)}.display-event-source-compact{align-self:flex-end}.source-badge-compact{font-size:var(--ucl-font-size-xs);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-weight:var(--ucl-font-weight-medium);background:var(--ucl-gray-100);color:var(--ucl-text-secondary)}.source-badge-compact.icloud{background:#ff6b6b1a;color:#ff5252}.source-badge-compact.outlook{background:#003d7a1a;color:var(--ucl-primary)}.display-no-events-compact{text-align:center;padding:var(--ucl-spacing-xxl);color:var(--ucl-text-secondary)}.display-footer-compact{background:var(--ucl-gray-50);border-top:1px solid var(--ucl-gray-200);padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);margin-top:var(--ucl-spacing-xl)}.ucl-logo-compact{font-size:var(--ucl-font-size-lg)}.ucl-text-compact{font-size:var(--ucl-font-size-md);font-weight:var(--ucl-font-weight-medium);color:var(--ucl-text-primary)}@media (max-width: 768px){.display-events-grid{grid-template-columns:1fr;gap:var(--ucl-spacing-md)}.display-event-card{min-height:120px}.display-event-date-badge{min-width:70px;padding:var(--ucl-spacing-sm)}.event-day{font-size:1.5rem}.display-footer-content-compact{flex-direction:column;gap:var(--ucl-spacing-sm);text-align:center}}@media (min-width: 1200px){.display-events-grid{grid-template-columns:repeat(5,1fr)}}/ * ===== STYLES POUR LES RÉSULTATS DE RECHERCHE SOUS LE CALENDRIER ===== */ .search-results-section{margin-top:var(--ucl-spacing-xl);padding:var(--ucl-spacing-lg);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);border:1px solid var(--ucl-gray-200)}.search-results-header{margin-bottom:var(--ucl-spacing-lg);padding-bottom:var(--ucl-spacing-md);border-bottom:2px solid var(--ucl-primary)}.search-results-title{font-size:var(--ucl-font-size-xl);font-weight:var(--ucl-font-weight-bold);color:var(--ucl-primary);margin:0;display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.search-results-count{font-size:var(--ucl-font-size-md);font-weight:var(--ucl-font-weight-normal);color:var(--ucl-text-secondary);background:var(--ucl-gray-100);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius)}.search-results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--ucl-spacing-lg)}.search-result-card{background:var(--ucl-white);border:2px solid var(--ucl-gray-200);border-radius:var(--ucl-border-radius-lg);padding:var(--ucl-spacing-lg);transition:all var(--ucl-transition);cursor:pointer}.search-result-card:hover{border-color:var(--ucl-primary);box-shadow:var(--ucl-shadow-lg);transform:translateY(-2px)}.search-result-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--ucl-spacing-md)}.search-result-title{font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-text-primary);margin:0;flex:1;line-height:1.3}.search-result-source .source-badge{font-size:var(--ucl-font-size-sm);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-weight:var(--ucl-font-weight-medium)}.search-result-source .source-badge.icloud{background:#ff6b6b1a;color:#ff5252;border:1px solid rgba(255,107,107,.3)}.search-result-source .source-badge.outlook{background:#003d7a1a;color:var(--ucl-primary);border:1px solid rgba(0,61,122,.3)}.search-result-datetime{display:flex;gap:var(--ucl-spacing-md);margin-bottom:var(--ucl-spacing-sm);font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary)}.search-result-location{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);margin-bottom:var(--ucl-spacing-sm)}.search-result-description{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);line-height:1.4;margin-bottom:var(--ucl-spacing-md);padding:var(--ucl-spacing-sm);background:var(--ucl-gray-50);border-radius:var(--ucl-border-radius)}.search-result-actions{display:flex;justify-content:space-between;align-items:center;margin-top:var(--ucl-spacing-md);padding-top:var(--ucl-spacing-md);border-top:1px solid var(--ucl-gray-200)}.btn-search-info{background:var(--ucl-primary);color:var(--ucl-white);border:none;padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:all var(--ucl-transition)}.btn-search-info:hover{background:var(--ucl-secondary);transform:translateY(-1px)}.search-export-buttons{display:flex;gap:var(--ucl-spacing-xs)}.btn-search-export{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-300);color:var(--ucl-text-secondary);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);cursor:pointer;transition:all var(--ucl-transition)}.btn-search-export:hover{background:var(--ucl-primary);color:var(--ucl-white);border-color:var(--ucl-primary)}.no-search-results{text-align:center;padding:var(--ucl-spacing-xxl);color:var(--ucl-text-secondary);grid-column:1 / -1}.no-results-icon{font-size:3rem;margin-bottom:var(--ucl-spacing-md)}.no-results-suggestion{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-muted);margin-top:var(--ucl-spacing-sm)}.display-view{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:var(--ucl-spacing-lg)}.display-header-compact{text-align:center;margin-bottom:var(--ucl-spacing-lg);padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-lg)}.display-title-compact{font-size:2rem;font-weight:var(--ucl-font-weight-bold);margin:0 0 var(--ucl-spacing-xs) 0;text-shadow:0 2px 4px rgba(0,0,0,.2)}.display-period-compact{font-size:var(--ucl-font-size-lg);opacity:.9;font-weight:var(--ucl-font-weight-medium)}.display-content-compact{max-width:1400px;margin:0 auto}.display-events-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--ucl-spacing-xl);margin-bottom:var(--ucl-spacing-lg);align-items:stretch}.display-event-card{background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);overflow:hidden;transition:all var(--ucl-transition);cursor:pointer;border:3px solid transparent;height:420px;display:flex;flex-direction:column}.display-event-card:hover{transform:translateY(-4px);box-shadow:var(--ucl-shadow-xl)}.display-event-card.icloud{border-color:#ff5252}.display-event-card.outlook{border-color:#06c}.display-event-card.current-day{border-color:var(--ucl-success);box-shadow:0 0 20px #10b9814d}.display-event-date-badge{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);text-align:center;padding:var(--ucl-spacing-lg) var(--ucl-spacing-md);font-weight:var(--ucl-font-weight-bold)}.event-day{font-size:2.2rem;line-height:1;margin-bottom:var(--ucl-spacing-xs)}.event-month{font-size:var(--ucl-font-size-sm);text-transform:uppercase;letter-spacing:1px;opacity:.9}.display-event-content{padding:var(--ucl-spacing-lg);flex:1;display:flex;flex-direction:column;height:100%}.display-event-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--ucl-spacing-md);gap:var(--ucl-spacing-sm)}.display-event-body{flex:1;display:flex;flex-direction:column;justify-content:flex-start;gap:var(--ucl-spacing-sm)}.display-event-time-compact{font-size:var(--ucl-font-size-xs);color:var(--ucl-text-secondary);font-weight:var(--ucl-font-weight-semibold);flex:1;text-transform:uppercase;letter-spacing:.5px}.display-event-title-compact{font-size:var(--ucl-font-size-md);font-weight:var(--ucl-font-weight-bold);color:var(--ucl-text-primary);margin-bottom:var(--ucl-spacing-md);line-height:1.5;flex:1;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.display-event-location-compact{font-size:var(--ucl-font-size-xs);color:var(--ucl-text-secondary);margin-top:auto;padding-top:var(--ucl-spacing-md);font-weight:var(--ucl-font-weight-medium);font-style:italic}.display-event-source-compact{flex-shrink:0}.source-badge-compact{font-size:9px;padding:6px 10px;border-radius:var(--ucl-border-radius-lg);font-weight:var(--ucl-font-weight-bold);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;min-width:60px;text-align:center;box-shadow:0 2px 4px #0000001a}.source-badge-compact.icloud{background:#ff5252;color:var(--ucl-white);border:2px solid #ff3d3d;box-shadow:0 2px 4px #ff52524d}.source-badge-compact.outlook{background:var(--ucl-primary);color:var(--ucl-white);border:2px solid #002952;box-shadow:0 2px 4px #003d7a4d}.display-no-events-compact{text-align:center;padding:var(--ucl-spacing-xxl);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md)}.no-events-icon-compact{font-size:4rem;margin-bottom:var(--ucl-spacing-lg)}.display-footer-compact{margin-top:var(--ucl-spacing-lg);padding:var(--ucl-spacing-md) var(--ucl-spacing-lg);background:var(--ucl-white);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md)}.display-footer-content-compact{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.display-footer-logo-compact{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.ucl-logo-compact{font-size:1.5rem}.ucl-text-compact{font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary)}.display-footer-time-compact{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary)}@media (max-width: 768px){.display-title-compact{font-size:1.5rem}.display-events-grid{grid-template-columns:1fr;gap:var(--ucl-spacing-md)}.display-event-card{height:auto;min-height:200px}.display-footer-content-compact{flex-direction:column;gap:var(--ucl-spacing-sm);text-align:center}}@media (max-width: 1024px) and (min-width: 769px){.display-events-grid{grid-template-columns:repeat(2,1fr)}.display-event-card{height:380px}}@media (max-width: 1200px) and (min-width: 1025px){.display-events-grid{grid-template-columns:repeat(3,1fr)}.display-event-card{height:400px}}@media (max-width: 768px){.search-results-grid{grid-template-columns:1fr;gap:var(--ucl-spacing-md)}.search-result-header,.search-result-actions{flex-direction:column;gap:var(--ucl-spacing-sm)}.search-export-buttons{justify-content:center}}.calendar-layout:has(.calendar-sidebar:not(:empty)){grid-template-columns:1fr 350px}.calendar-layout:not(:has(.calendar-sidebar:not(:empty))){grid-template-columns:1fr}.calendar-layout.search-active{grid-template-columns:1fr!important}.calendar-layout.search-active .calendar-sidebar{display:none!important}.search-results-section{animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.search-results-section{scroll-margin-top:20px}.search-resu lts-subtitle{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);margin:var(--ucl-spacing-sm) 0 0 0;font-weight:var(--ucl-font-weight-normal)}.search-results-section{border:2px solid var(--ucl-primary);background:linear-gradient(135deg,#003d7a05,#0066cc05)}.search-results-header{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);margin:-var(--ucl-spacing-lg) -var(--ucl-spacing-lg) var(--ucl-spacing-lg) -var(--ucl-spacing-lg);padding:var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius-lg) var(--ucl-border-radius-lg) 0 0}.search-results-title{color:var(--ucl-white)}.search-results-count{background:#fff3;color:var(--ucl-white)}.scroll-to-results-btn{background:linear-gradient(135deg,var(--ucl-success) 0%,#10b981 100%);color:var(--ucl-white);border:none;padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius-lg);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-semibold);cursor:pointer;transition:all var(--ucl-transition);margin-top:var(--ucl-spacing-sm);box-shadow:0 2px 8px #10b9814d;animation:pulseGreen 2s ease-in-out infinite}.scroll-to-results-btn:hover{background:linear-gradient(135deg,#059669 0%,var(--ucl-success) 100%);transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.scroll-to-results-btn:active{transform:translateY(0)}@keyframes pulseGreen{0%,to{box-shadow:0 2px 8px #10b9814d}50%{box-shadow:0 4px 16px #10b98180}}.calendar-search-section{display:flex;flex-direction:column;align-items:center;gap:var(--ucl-spacing-sm)}.no-results-message-inline{background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--ucl-white);padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius-lg);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);text-align:center;margin-top:var(--ucl-spacing-sm);box-shadow:0 2px 8px #f59e0b4d;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.calendar-header{display:flex;align-items:center;justify-content:space-between;gap:var(--ucl-spacing-lg);padding:var(--ucl-spacing-md);background:var(--ucl-white);border-bottom:1px solid var(--ucl-gray-200);flex-wrap:wrap}.calendar-nav{display:flex;gap:var(--ucl-spacing-sm)}.calendar-search-section{flex:1;display:flex;align-items:center;gap:var(--ucl-spacing-sm);min-width:300px}.month-year{font-size:var(--ucl-font-size-xl);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);margin:0;white-space:nowrap}.header-controls{display:flex;align-items:center;gap:var(--ucl-spacing-sm)}.header-actions{display:flex;align-items:center;gap:var(--ucl-spacing-sm);margin-left:auto}.refresh-button,.clear-cache-button{background:var(--ucl-primary);color:#fff;border:none;padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:var(--ucl-transition);white-space:nowrap}.refresh-button:hover{background:var(--ucl-secondary);transform:translateY(-1px)}.clear-cache-button{background:var(--ucl-warning)}.clear-cache-button:hover{background:#e08e0b;transform:translateY(-1px)}.nav-button{background:var(--ucl-gray-100);color:var(--ucl-dark);border:1px solid var(--ucl-gray-300);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);cursor:pointer;transition:var(--ucl-transition);white-space:nowrap}.nav-button:hover{background:var(--ucl-gray-200);border-color:var(--ucl-gray-400);transform:translateY(-1px)}@media (max-width: 768px){.calendar-header{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-md)}.calendar-nav,.header-controls,.header-actions{justify-content:center}.calendar-search-section{min-width:auto}.month-year{text-align:center}}.calendar-main-header-compact{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg)}.header-actions-group{display:flex;align-items:center;gap:var(--ucl-spacing-lg)}.header-refresh-actions,.header-help-actions{display:flex;gap:var(--ucl-spacing-sm)}.nav-button.compact,.export-button.compact{padding:var(--ucl-spacing-xs) var(--ucl-spacing-md);font-size:var(--ucl-font-size-sm);min-height:32px}.export-button.compact{background:var(--ucl-success);border-color:var(--ucl-success)}.export-button.compact:hover{background:#059669;border-color:#059669}.faq-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius);cursor:pointer;font-size:1.2em;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all var(--ucl-transition)}.faq-btn:hover{background:#ffffff4d;transform:scale(1.1)}.calendar-search-section{display:flex;flex-direction:column;gap:var(--ucl-spacing-sm);width:100%}@media (max-width: 768px){.calendar-main-header-compact{flex-direction:column;gap:var(--ucl-spacing-sm);text-align:center}.header-actions-group{flex-direction:column;gap:var(--ucl-spacing-sm)}.header-refresh-actions,.header-help-actions{justify-content:center}.calendar-search-section{padding:0 var(--ucl-spacing-sm)}}.sidebar-event-title{font-size:var(--ucl-font-size-sm);line-height:1.3;margin:0 0 var(--ucl-spacing-xs) 0;font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-text-primary)}.sidebar-event-location{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);margin-bottom:var(--ucl-spacing-xs);line-height:1.2}.sidebar-event-description{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-secondary);line-height:1.4;margin-bottom:var(--ucl-spacing-sm)}.source-badge{font-size:12px;padding:2px 6px;border-radius:var(--ucl-border-radius-sm);font-weight:var(--ucl-font-weight-medium)}.source-badge.icloud{background:#ff6b6b1a;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.source-badge.outlook{background:#003d7a1a;color:var(--ucl-primary);border:1px solid rgba(0,61,122,.3)}.month-year-container{display:flex;flex-direction:column;align-items:center;gap:var(--ucl-spacing-xs);position:relative}.month-indicator{display:flex;align-items:center;justify-content:center}.month-badge{background:#003d7a1a;color:var(--ucl-primary);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-lg);border:1px solid rgba(0,61,122,.2);text-transform:uppercase;letter-spacing:.5px;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.month-year{font-size:1.4rem}.month-year-container{gap:var(--ucl-spacing-xs)}.month-badge{font-size:11px;padding:2px 8px}}.month-year{transition:all .3s cubic-bezier(.4,0,.2,1)}.month-year:hover{transform:scale(1.02)}.month-year:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s;pointer-events:none}.month-year:hover:before{left:100%}@media (max-width: 1250px){.calendar-grid{min-width:auto;max-width:100%;margin:0 var(--ucl-spacing-sm)}}@media (max-width: 768px){.calendar-grid{margin:0;border-radius:0}.toast-notification{bottom:10px;right:10px;left:10px;min-width:auto}}.agenda-date-header .events-count{background:var(--ucl-white);color:var(--ucl-primary);font-weight:var(--ucl-font-weight-bold);font-size:var(--ucl-font-size-base);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius-lg);border:2px solid var(--ucl-white);box-shadow:0 2px 8px #0003;min-width:70px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:countBadge .3s ease-out}@keyframes countBadge{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.agenda-date-header .events-count:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d;transition:all .2s ease}.agenda-date-header .events-count.highlighted{background:var(--ucl-warning);color:var(--ucl-white);border-color:var(--ucl-warning)}@media (max-width: 768px){.agenda-date-header .events-count{font-size:var(--ucl-font-size-sm);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);min-width:50px}}.custom-bold{font-weight:var(--ucl-font-weight-bold);color:var(--ucl-primary)}.custom-italic{font-style:italic;color:var(--ucl-secondary)}.custom-underline{text-decoration:underline;text-decoration-color:var(--ucl-accent);text-decoration-thickness:2px;text-underline-offset:2px}.custom-break{display:block;margin:var(--ucl-spacing-xs) 0}.custom-separator{border:none;border-top:2px solid var(--ucl-gray-300);margin:var(--ucl-spacing-md) 0;width:100%}.event-description-modal .custom-bold{font-weight:var(--ucl-font-weight-bold);color:var(--ucl-primary);background:rgba(var(--ucl-primary-rgb),.1);padding:1px 3px;border-radius:3px}.event-description-modal .custom-italic{font-style:italic;color:var(--ucl-secondary);font-weight:var(--ucl-font-weight-medium)}.event-description-modal .custom-underline{text-decoration:underline;text-decoration-color:var(--ucl-accent);text-decoration-thickness:2px;text-underline-offset:3px;color:var(--ucl-accent);font-weight:var(--ucl-font-weight-medium)}.event-description-modal .custom-separator{border-top:2px solid var(--ucl-primary);margin:var(--ucl-spacing-lg) 0;opacity:.6}@media (max-width: 768px){.event-description-modal .custom-bold{padding:1px 2px;font-size:.95em}.event-description-modal .custom-separator{margin:var(--ucl-spacing-md) 0}}@media (max-width: 480px){.event-description-modal .custom-bold{background:none;padding:0}.event-description-modal .custom-underline{text-decoration-thickness:1px;text-underline-offset:2px}}.custom-bold:focus,.custom-italic:focus,.custom-underline:focus{outline:2px solid var(--ucl-primary);outline-offset:2px;border-radius:2px}@media print{.custom-bold{background:none!important;color:#000!important;font-weight:700!important}.custom-italic{color:#000!important}.custom-underline{color:#000!important;text-decoration-color:#000!important}.custom-separator{border-color:#000!important}}:root{--ucl-bg-primary: #ffffff;--ucl-bg-secondary: #f8fafc;--ucl-bg-tertiary: #f1f5f9;--ucl-bg-hover: #e2e8f0;--ucl-text-primary: #1e293b;--ucl-text-secondary: #475569;--ucl-text-muted: #64748b;--ucl-border: #e2e8f0;--ucl-border-light: #f1f5f9;--ucl-primary-adaptive: #003d7a;--ucl-secondary-adaptive: #0066cc;--ucl-accent-adaptive: #4a90e2}@media (prefers-color-scheme: dark){:root{--ucl-bg-primary: #0f172a;--ucl-bg-secondary: #1e293b;--ucl-bg-tertiary: #334155;--ucl-bg-hover: #475569;--ucl-text-primary: #f8fafc;--ucl-text-secondary: #cbd5e1;--ucl-text-muted: #94a3b8;--ucl-border: #334155;--ucl-border-light: #475569;--ucl-primary-adaptive: #4a90e2;--ucl-secondary-adaptive: #60a5fa;--ucl-accent-adaptive: #93c5fd;--ucl-success: #34d399;--ucl-warning: #fbbf24;--ucl-danger: #f87171;--ucl-info: #38bdf8;--ucl-gray-50: #1e293b;--ucl-gray-100: #334155;--ucl-gray-200: #475569;--ucl-gray-300: #64748b;--ucl-gray-400: #94a3b8;--ucl-gray-500: #cbd5e1;--ucl-gray-600: #e2e8f0;--ucl-gray-700: #f1f5f9;--ucl-gray-800: #f8fafc;--ucl-gray-900: #ffffff;--ucl-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--ucl-shadow: 0 1px 3px 0 rgba(0, 0, 0, .4), 0 1px 2px 0 rgba(0, 0, 0, .2);--ucl-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .2);--ucl-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .2);--ucl-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .2)}body{background:var(--ucl-bg-primary);color:var(--ucl-text-primary)}.calendar-container{background:var(--ucl-bg-secondary)}.calendar-main-header{background:linear-gradient(135deg,var(--ucl-primary-adaptive) 0%,var(--ucl-secondary-adaptive) 100%)}.calendar-header{background:var(--ucl-bg-primary);border-bottom-color:var(--ucl-border)}.calendar-grid{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.calendar-weekdays{background:linear-gradient(135deg,var(--ucl-primary-adaptive) 0%,var(--ucl-secondary-adaptive) 100%)}.calendar-day{background:var(--ucl-bg-primary);border-color:var(--ucl-border);color:var(--ucl-text-primary)}.calendar-day:hover{background:var(--ucl-bg-hover)}.calendar-day.other-month{background:var(--ucl-bg-tertiary);color:var(--ucl-text-muted)}.calendar-day.today{background:linear-gradient(135deg,#4a90e233,#60a5fa33);border-color:var(--ucl-primary-adaptive)}.calendar-day.today .day-number{background:var(--ucl-primary-adaptive);color:var(--ucl-bg-primary)}.day-number{color:var(--ucl-text-primary)}.nav-button{background:var(--ucl-primary-adaptive);border-color:var(--ucl-primary-adaptive);color:var(--ucl-bg-primary)}.nav-button:hover{background:var(--ucl-secondary-adaptive);border-color:var(--ucl-secondary-adaptive)}.month-year{background:linear-gradient(135deg,var(--ucl-primary-adaptive) 0%,var(--ucl-secondary-adaptive) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.search-input-wrapper{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.search-bar.active .search-input-wrapper{border-color:var(--ucl-primary-adaptive);box-shadow:0 0 0 3px #4a90e233}.search-input{color:var(--ucl-text-primary)}.search-input::placeholder{color:var(--ucl-text-muted)}.search-icon{color:var(--ucl-text-muted)}.search-bar.active .search-icon{color:var(--ucl-primary-adaptive)}.search-suggestions{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.search-suggestion:hover{background:var(--ucl-bg-hover)}.universal-sidebar{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.sidebar-section{border-color:var(--ucl-border-light)}.filters-section{background:linear-gradient(135deg,var(--ucl-bg-secondary) 0%,var(--ucl-bg-primary) 100%)}.sidebar-section-title{color:var(--ucl-primary-adaptive)}.filter-select{background:var(--ucl-bg-primary);border-color:var(--ucl-border);color:var(--ucl-text-primary)}.filter-select:focus{border-color:var(--ucl-primary-adaptive);box-shadow:0 0 0 2px #4a90e233}.search-stats{background:#4a90e21a;border-color:var(--ucl-primary-adaptive)}.sidebar-event-card{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.sidebar-event-card:hover{background:var(--ucl-bg-hover)}.sidebar-event-description{background:var(--ucl-bg-secondary);border-color:var(--ucl-primary-adaptive)}.agenda-controls,.agenda-day-group{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.agenda-date-header{background:linear-gradient(135deg,var(--ucl-primary-adaptive) 0%,var(--ucl-secondary-adaptive) 100%)}.events-count{background:var(--ucl-bg-primary);color:var(--ucl-primary-adaptive);border-color:var(--ucl-primary-adaptive)}.agenda-event-card{background:var(--ucl-bg-primary);border-color:var(--ucl-border);border-left-color:var(--ucl-primary-adaptive)}.agenda-event-card:hover,.agenda-event-header:hover{background:var(--ucl-bg-hover)}.agenda-event-details{background:var(--ucl-bg-secondary);border-color:var(--ucl-border-light)}.event-modal{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.event-modal-header{background:linear-gradient(135deg,var(--ucl-primary-adaptive),var(--ucl-accent-adaptive))}.event-modal-content::-webkit-scrollbar-track{background:var(--ucl-bg-secondary)}.event-modal-content::-webkit-scrollbar-thumb{background:var(--ucl-border)}.event-modal-content::-webkit-scrollbar-thumb:hover{background:var(--ucl-text-muted)}.event-details{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.event-details-header{background:linear-gradient(135deg,var(--ucl-primary-adaptive),var(--ucl-accent-adaptive))}.event-detail-row:hover{background:var(--ucl-bg-hover)}.detail-content strong{color:var(--ucl-primary-adaptive)}.detail-content span{color:var(--ucl-text-primary)}.event-tooltip{background:var(--ucl-bg-tertiary);color:var(--ucl-text-primary);border-color:var(--ucl-border)}.event-tooltip:after{border-top-color:var(--ucl-bg-tertiary)}.skeleton-calendar-grid{background:var(--ucl-bg-primary)}.skeleton-weekdays{background:var(--ucl-bg-secondary);border-color:var(--ucl-border)}.skeleton-weekday{background:linear-gradient(90deg,var(--ucl-bg-secondary) 25%,var(--ucl-bg-hover) 50%,var(--ucl-bg-secondary) 75%);border-color:var(--ucl-border)}.skeleton-day{background:var(--ucl-bg-primary)}.skeleton-day-number{background:linear-gradient(90deg,var(--ucl-border) 25%,var(--ucl-bg-hover) 50%,var(--ucl-border) 75%)}.skeleton-event{background:linear-gradient(90deg,var(--ucl-primary-adaptive) 25%,var(--ucl-secondary-adaptive) 50%,var(--ucl-primary-adaptive) 75%)}.progress-container{background:var(--ucl-bg-primary)}.progress-message{color:var(--ucl-primary-adaptive)}.progress-bar-wrapper{background:var(--ucl-bg-secondary)}.progress-bar{background:linear-gradient(90deg,var(--ucl-primary-adaptive),var(--ucl-secondary-adaptive))}.progress-bar.indeterminate{background:var(--ucl-bg-secondary)}.progress-bar.indeterminate .progress-bar-fill{background:linear-gradient(90deg,var(--ucl-primary-adaptive),var(--ucl-secondary-adaptive))}.error{background:#f871711a;border-color:#f871714d;border-left-color:var(--ucl-danger)}.error h3{color:var(--ucl-danger)}.debug-section{background:var(--ucl-bg-secondary);border-color:var(--ucl-border)}.debug-section h4{color:var(--ucl-primary-adaptive)}.debug-section pre{color:var(--ucl-text-primary)}.no-events{background:var(--ucl-bg-primary);border-color:var(--ucl-border);color:var(--ucl-text-secondary)}.no-events-message{color:var(--ucl-text-secondary)}.sidebar-footer{background:var(--ucl-bg-secondary);border-color:var(--ucl-border-light)}.btn-sidebar-info{background:var(--ucl-primary-adaptive)}.btn-sidebar-info:hover{background:var(--ucl-secondary-adaptive)}.btn-sidebar-export{background:var(--ucl-bg-secondary);border-color:var(--ucl-border);color:var(--ucl-text-secondary)}.btn-sidebar-export:hover{background:var(--ucl-bg-hover)}.expand-button,.btn-view-modal{background:var(--ucl-bg-secondary);border-color:var(--ucl-border);color:var(--ucl-text-secondary)}.expand-button:hover,.btn-view-modal:hover{background:var(--ucl-primary-adaptive);color:var(--ucl-bg-primary);border-color:var(--ucl-primary-adaptive)}.close-details-btn{background:#fff3}.close-details-btn:hover{background:#ffffff4d}.event-modal-close{background:#fff3}.event-modal-close:hover{background:#ffffff4d}.page-number{background:var(--ucl-bg-primary);border-color:var(--ucl-border);color:var(--ucl-text-primary)}.page-number:hover{background:var(--ucl-bg-hover);border-color:var(--ucl-primary-adaptive)}.page-number.active{background:var(--ucl-primary-adaptive);color:var(--ucl-bg-primary);border-color:var(--ucl-primary-adaptive)}.range-select{background:var(--ucl-bg-primary);border-color:var(--ucl-border);color:var(--ucl-text-primary)}.range-select:focus{border-color:var(--ucl-primary-adaptive);box-shadow:0 0 0 2px #4a90e233}.source-badge.icloud{background:#ff6b6b33;border-color:#ff6b6b66}.source-badge.outlook,.event-source-badge{background:#4a90e233;color:var(--ucl-primary-adaptive);border-color:#4a90e266}.agenda-event-card.icloud .event-source-badge{background:#ff6b6b33;border-color:#ff6b6b66}.agenda-event-card.outlook .event-source-badge{background:#4a90e233;color:var(--ucl-primary-adaptive);border-color:#4a90e266}.description-link{color:var(--ucl-primary-adaptive)}.description-link:hover{background:#4a90e233;border-bottom-color:var(--ucl-primary-adaptive)}.url-link:hover{background:#4a90e233;color:var(--ucl-accent-adaptive)}.email-link:hover{background:#38bdf833;color:var(--ucl-info);border-bottom-color:var(--ucl-info)}.phone-link:hover{background:#34d39933;color:var(--ucl-success);border-bottom-color:var(--ucl-success)}.description-date{color:var(--ucl-warning);background:#fbbf2433}.description-paragraph.important-info{background:#4a90e21a;border-left-color:var(--ucl-primary-adaptive)}.stats-value,.stats-item.highlight{color:var(--ucl-primary-adaptive)}.page-info{background:var(--ucl-bg-secondary);color:var(--ucl-text-secondary)}.total-events{color:var(--ucl-primary-adaptive)}.upcoming-events{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.upcoming-events h2{color:var(--ucl-primary-adaptive)}.event-preview{background:var(--ucl-bg-primary);border-color:var(--ucl-border)}.event-preview:hover{background:var(--ucl-bg-hover)}.event-preview-title{color:var(--ucl-primary-adaptive)}.event-preview-time{background:var(--ucl-bg-secondary);color:var(--ucl-text-secondary)}.event-preview-location,.event-description-preview{color:var(--ucl-text-secondary)}}@media (prefers-color-scheme: dark) and (prefers-contrast: high){:root{--ucl-bg-primary: #000000;--ucl-bg-secondary: #1a1a1a;--ucl-bg-tertiary: #2d2d2d;--ucl-text-primary: #ffffff;--ucl-text-secondary: #e0e0e0;--ucl-border: #404040;--ucl-primary-adaptive: #66b3ff;--ucl-secondary-adaptive: #80c7ff}}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}@media (prefers-reduced-motion: reduce){*{transition:none!important}}.agenda-date-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ucl-spacing-lg);background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);position:relative;overflow:hidden}.agenda-date-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.3}.date-info{display:flex;align-items:center;gap:var(--ucl-spacing-md);position:relative;z-index:1}.date-title{margin:0;font-size:var(--ucl-font-size-lg);font-weight:var(--ucl-font-weight-semibold);text-transform:capitalize;text-shadow:0 2px 4px rgba(0,0,0,.2)}.today-badge{background:#fff3;color:var(--ucl-white);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-lg);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:todayPulse 2s ease-in-out infinite}@keyframes todayPulse{0%,to{box-shadow:0 0 #fff6}50%{box-shadow:0 0 0 8px #fff0}}.events-count-container{display:flex;flex-direction:column;align-items:center;background:#ffffff26;padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border-radius:var(--ucl-border-radius-lg);border:2px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:1;min-width:80px;box-shadow:0 4px 12px #0003}.events-count{font-size:1.8rem;font-weight:var(--ucl-font-weight-bold);line-height:1;color:var(--ucl-white);text-shadow:0 2px 4px rgba(0,0,0,.3);margin-bottom:2px}.events-label{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);color:#ffffffe6;text-align:center;line-height:1.2;text-transform:lowercase}.summary-stats{display:flex;align-items:center;gap:var(--ucl-spacing-lg);flex-wrap:wrap}.total-events-container{display:flex;align-items:baseline;gap:var(--ucl-spacing-sm);background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:var(--ucl-white);padding:var(--ucl-spacing-sm) var(--ucl-spacing-lg);border-radius:var(--ucl-border-radius-lg);box-shadow:var(--ucl-shadow-md);position:relative;overflow:hidden}.total-events-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:translate(-100%);transition:transform .6s ease}.total-events-container:hover:before{transform:translate(100%)}.total-events-number{font-size:1.5rem;font-weight:var(--ucl-font-weight-bold);color:var(--ucl-white);text-shadow:0 2px 4px rgba(0,0,0,.3);position:relative;z-index:1}.total-events-label{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);color:#ffffffe6;position:relative;z-index:1}.pagination-info{display:flex;flex-direction:column;align-items:flex-start;gap:var(--ucl-spacing-xs)}.page-info{font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-semibold);color:var(--ucl-primary);background:#003d7a1a;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius);border:1px solid rgba(0,61,122,.2)}.events-range{font-size:var(--ucl-font-size-sm);color:var(--ucl-text-muted);font-style:italic}@media (max-width: 768px){.agenda-date-header{flex-direction:column;gap:var(--ucl-spacing-sm);padding:var(--ucl-spacing-md);text-align:center}.date-info{flex-direction:column;gap:var(--ucl-spacing-xs)}.date-title{font-size:var(--ucl-font-size-base)}.events-count-container{min-width:60px;padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm)}.events-count{font-size:1.4rem}.events-label{font-size:11px}.summary-stats{flex-direction:column;align-items:stretch;gap:var(--ucl-spacing-sm)}.total-events-container{justify-content:center}.pagination-info{align-items:center}}@media (prefers-color-scheme: dark){.agenda-date-header{background:linear-gradient(135deg,var(--ucl-primary-adaptive) 0%,var(--ucl-secondary-adaptive) 100%)}.today-badge{background:#ffffff26;border-color:#fff3}.events-count-container{background:#ffffff1a;border-color:#ffffff26}.total-events-container{background:linear-gradient(135deg,var(--ucl-primary-adaptive) 0%,var(--ucl-secondary-adaptive) 100%)}.page-info{background:#4a90e233;border-color:#4a90e24d;color:var(--ucl-primary-adaptive)}}.events-count-container{animation:countIn .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes countIn{0%{opacity:0;transform:scale(.3) rotate(-10deg)}50%{opacity:1;transform:scale(1.1) rotate(5deg)}to{opacity:1;transform:scale(1) rotate(0)}}.total-events-container{animation:slideInLeft .5s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.events-count-container:hover{transform:scale(1.05);box-shadow:0 6px 16px #0000004d;transition:all .3s ease}.total-events-container:hover{transform:translateY(-2px);box-shadow:var(--ucl-shadow-lg);transition:all .3s ease}.events-count-container:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:20px;height:2px;background:#fff9;border-radius:1px}@media (prefers-reduced-motion: reduce){.today-badge,.events-count-container,.total-events-container{animation:none!important}.events-count-container:hover,.total-events-container:hover{transform:none!important}}@media (prefers-contrast: high){.events-count-container{border-width:3px;background:#ffffff4d}.total-events-container{border:2px solid var(--ucl-white)}.events-count,.total-events-number{font-weight:var(--ucl-font-weight-bold);text-shadow:0 0 4px rgba(0,0,0,.8)}}.export-row{border-top:1px solid var(--ucl-border-light);padding-top:var(--ucl-spacing-md);margin-top:var(--ucl-spacing-md)}.export-buttons{display:flex;gap:var(--ucl-spacing-sm);flex-wrap:wrap;margin-top:var(--ucl-spacing-sm)}.export-button{display:flex;align-items:center;gap:var(--ucl-spacing-xs);padding:var(--ucl-spacing-sm) var(--ucl-spacing-md);border:2px solid transparent;border-radius:var(--ucl-border-radius);background:var(--ucl-gray-100);color:var(--ucl-text-primary);font-size:var(--ucl-font-size-sm);font-weight:var(--ucl-font-weight-medium);font-family:var(--ucl-font-family);cursor:pointer;transition:all var(--ucl-transition);text-decoration:none;min-width:100px;justify-content:center;position:relative;overflow:hidden}.export-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left var(--ucl-transition)}.export-button:hover:before{left:100%}.export-button:hover{transform:translateY(-2px);box-shadow:var(--ucl-shadow-md)}.export-button:active{transform:translateY(0)}.export-button.google{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border-color:#4285f4}.export-button.google:hover{background:linear-gradient(135deg,#3367d6,#2d8f47);box-shadow:0 4px 12px #4285f466}.export-button.outlook{background:linear-gradient(135deg,#0078d4,#106ebe);color:#fff;border-color:#0078d4}.export-button.outlook:hover{background:linear-gradient(135deg,#106ebe,#005a9e);box-shadow:0 4px 12px #0078d466}.export-button.ics{background:linear-gradient(135deg,var(--ucl-success) 0%,#059669 100%);color:#fff;border-color:var(--ucl-success)}.export-button.ics:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166}.export-icon{font-size:16px;flex-shrink:0}.export-label{font-weight:var(--ucl-font-weight-semibold)}.agenda-export-buttons{display:flex;gap:var(--ucl-spacing-xs);margin-top:var(--ucl-spacing-xs)}.btn-agenda-export{background:var(--ucl-gray-100);border:1px solid var(--ucl-gray-300);color:var(--ucl-text-secondary);padding:var(--ucl-spacing-xs);border-radius:var(--ucl-border-radius-sm);cursor:pointer;transition:all var(--ucl-transition);font-size:14px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.btn-agenda-export:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transition:opacity var(--ucl-transition)}.btn-agenda-export:hover:before{opacity:1}.btn-agenda-export:hover{transform:translateY(-1px) scale(1.05);box-shadow:var(--ucl-shadow-sm)}.btn-agenda-export.google:hover{background:#4285f4;color:#fff;border-color:#4285f4;box-shadow:0 2px 8px #4285f44d}.btn-agenda-export.outlook:hover{background:#0078d4;color:#fff;border-color:#0078d4;box-shadow:0 2px 8px #0078d44d}.btn-agenda-export.ics:hover{background:var(--ucl-success);color:#fff;border-color:var(--ucl-success);box-shadow:0 2px 8px #10b9814d}.export-actions{border-top:1px solid var(--ucl-border-light);padding-top:var(--ucl-spacing-sm);margin-top:var(--ucl-spacing-sm)}@media (max-width: 768px){.export-buttons{flex-direction:column;gap:var(--ucl-spacing-xs)}.export-button{min-width:auto;width:100%}.agenda-export-buttons{justify-content:center;gap:var(--ucl-spacing-sm)}.btn-agenda-export{width:36px;height:36px;font-size:16px}}@media (prefers-color-scheme: dark){.export-button{background:var(--ucl-bg-secondary);color:var(--ucl-text-primary);border-color:var(--ucl-border)}.export-button:not(.google):not(.outlook):not(.ics){background:var(--ucl-bg-secondary)}.export-button:not(.google):not(.outlook):not(.ics):hover{background:var(--ucl-bg-hover)}.btn-agenda-export{background:var(--ucl-bg-secondary);border-color:var(--ucl-border);color:var(--ucl-text-secondary)}.btn-agenda-export:hover{background:var(--ucl-bg-hover)}.export-row{border-color:var(--ucl-border)}.export-actions{border-color:var(--ucl-border-light)}}@media (prefers-reduced-motion: reduce){.export-button,.btn-agenda-export{transition:none!important}.export-button:hover,.btn-agenda-export:hover{transform:none!important}.export-button:before,.btn-agenda-export:before{display:none!important}}@media (prefers-contrast: high){.export-button{border-width:3px;font-weight:var(--ucl-font-weight-bold)}.btn-agenda-export{border-width:2px;font-weight:var(--ucl-font-weight-bold)}.export-button.google{border-color:#1a73e8}.export-button.outlook{border-color:#0078d4}.export-button.ics{border-color:var(--ucl-success)}}.export-buttons{animation:fadeInUp .4s ease-out}.agenda-export-buttons{animation:slideInRight .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.export-button:focus,.btn-agenda-export:focus{outline:2px solid var(--ucl-accent);outline-offset:2px;border-radius:var(--ucl-border-radius)}.export-button[title],.btn-agenda-export[title]{position:relative}.export-button[title]:hover:after,.btn-agenda-export[title]:hover:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--ucl-dark);color:var(--ucl-white);padding:var(--ucl-spacing-xs) var(--ucl-spacing-sm);border-radius:var(--ucl-border-radius-sm);font-size:12px;white-space:nowrap;z-index:1000;margin-bottom:4px;animation:tooltipFadeIn .2s ease-out}.export-button.success{background:var(--ucl-success)!important;color:#fff!important;border-color:var(--ucl-success)!important}.export-button.success .export-icon:before{content:"✓";position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:inherit;border-radius:inherit}.btn-agenda-export.success{background:var(--ucl-success)!important;color:#fff!important;border-color:var(--ucl-success)!important}.btn-agenda-export.success:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:700}.screen-view{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;flex-direction:column;padding:2rem;font-family:var(--ucl-font-family);position:relative;overflow:hidden}.screen-view:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="20" height="20" patternUnits="userSpaceOnUse"><path d="M 20 0 L 0 0 0 20" fill="none" stroke="rgba(0,61,122,0.03)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');pointer-events:none}.screen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding:2rem 3rem;background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);border-radius:2rem;color:#fff;box-shadow:0 8px 32px #003d7a4d;position:relative;z-index:1}.screen-title h1{font-size:3.5rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 4px 8px rgba(0,0,0,.3);line-height:1.1}.ucl-branding{font-size:1.8rem;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.1em}.screen-clock{text-align:right}.current-time{font-size:4rem;font-weight:700;line-height:1;margin-bottom:.5rem;text-shadow:0 4px 8px rgba(0,0,0,.3);font-variant-numeric:tabular-nums}.current-date{font-size:1.5rem;font-weight:400;opacity:.9;text-transform:capitalize}.screen-events{flex:1;display:flex;flex-direction:column;gap:1.5rem;position:relative;z-index:1}.screen-event{display:flex;align-items:center;gap:2rem;padding:2rem 3rem;background:#fffffff2;border-radius:1.5rem;box-shadow:0 8px 32px #0000001a;border-left:8px solid var(--event-color);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;animation:slideInUp .6s ease-out;animation-delay:calc(var(--event-index) * .1s);animation-fill-mode:both}.screen-event:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);transform:translate(-100%);transition:transform 2s ease}.screen-event:hover:before{transform:translate(100%)}.screen-event.current{background:linear-gradient(135deg,#ef44441a,#fffffff2);border-left-color:#ef4444;box-shadow:0 8px 32px #ef444433;animation:currentEventPulse 2s ease-in-out infinite}.screen-event.today{background:linear-gradient(135deg,#003d7a1a,#fffffff2);border-left-color:var(--ucl-primary);box-shadow:0 8px 32px #003d7a33}.event-indicator{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:80px}.event-dot{width:24px;height:24px;border-radius:50%;box-shadow:0 4px 12px #0003}.event-number{font-size:1.5rem;font-weight:700;color:var(--ucl-primary);background:#003d7a1a;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}.event-content{flex:1;display:flex;gap:3rem;align-items:center}.event-datetime{min-width:300px}.event-date{font-size:1.8rem;font-weight:600;color:var(--ucl-primary);margin-bottom:.5rem;text-transform:capitalize}.event-time{font-size:1.4rem;font-weight:500;color:var(--ucl-text-secondary);font-variant-numeric:tabular-nums}.event-details{flex:1}.event-title{font-size:2.2rem;font-weight:600;color:var(--ucl-text-primary);margin:0 0 1rem;line-height:1.2;display:flex;align-items:center;gap:1rem}.live-indicator{background:#ef4444;color:#fff;padding:.5rem 1rem;border-radius:2rem;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;animation:livePulse 1.5s ease-in-out infinite;box-shadow:0 4px 12px #ef444466}.event-location{font-size:1.3rem;color:var(--ucl-text-secondary);font-weight:500;display:flex;align-items:center;gap:.5rem}.event-source{min-width:150px;text-align:right}.source-badge{display:inline-block;padding:.8rem 1.5rem;border-radius:2rem;font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.source-badge.icloud{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;box-shadow:0 4px 12px #ff6b6b4d}.source-badge.outlook{background:linear-gradient(135deg,var(--ucl-primary) 0%,var(--ucl-secondary) 100%);color:#fff;box-shadow:0 4px 12px #003d7a4d}.no-events-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:2rem}.no-events-icon{font-size:8rem;opacity:.3}.no-events-message{font-size:3rem;font-weight:600;color:var(--ucl-text-secondary)}.no-events-submessage{font-size:1.5rem;color:var(--ucl-text-muted);font-style:italic}.screen-footer{display:flex;justify-content:space-between;align-items:center;margin-top:3rem;padding:1.5rem 3rem;background:#fffc;border-radius:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:1}.footer-info{display:flex;align-items:center;gap:1rem;font-size:1.2rem;color:var(--ucl-text-secondary)}.footer-branding{font-size:1.3rem;font-weight:600;color:var(--ucl-primary)}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes currentEventPulse{0%,to{box-shadow:0 8px 32px #ef444433}50%{box-shadow:0 8px 32px #ef444466}}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@media (prefers-color-scheme: dark){.screen-view{background:linear-gradient(135deg,#0f172a,#1e293b)}.screen-header{background:linear-gradient(135deg,var(--ucl-primary-adaptive) 0%,var(--ucl-secondary-adaptive) 100%)}.screen-event{background:#1e293bf2;color:var(--ucl-text-primary)}.screen-event.current{background:linear-gradient(135deg,#ef444433,#1e293bf2)}.screen-event.today{background:linear-gradient(135deg,#4a90e233,#1e293bf2)}.event-date{color:var(--ucl-primary-adaptive)}.event-title{color:var(--ucl-text-primary)}.event-number{color:var(--ucl-primary-adaptive);background:#4a90e233}.screen-footer{background:#1e293bcc}.footer-branding{color:var(--ucl-primary-adaptive)}}@media (max-width: 1920px){.screen-header{padding:1.5rem 2rem}.screen-title h1{font-size:3rem}.current-time{font-size:3.5rem}.event-title{font-size:2rem}}@media (max-width: 1366px){.screen-view{padding:1.5rem}.screen-title h1{font-size:2.5rem}.current-time{font-size:3rem}.event-title{font-size:1.8rem}.event-date{font-size:1.5rem}.event-time{font-size:1.2rem}}@media (min-width: 2560px){.screen-title h1{font-size:4.5rem}.current-time{font-size:5rem}.event-title{font-size:2.8rem}.event-date{font-size:2.2rem}.event-time{font-size:1.8rem}.screen-event{padding:3rem 4rem}}@media (prefers-reduced-motion: reduce){.screen-event{animation:none!important}.screen-event:before{display:none!important}.live-indicator,.screen-event.current{animation:none!important}}.screen-view.fullscreen{padding:1rem}.screen-view.fullscreen .screen-header{margin-bottom:2rem}.screen-view.fullscreen .screen-footer{margin-top:2rem}.screen-view-header{position:fixed;top:1rem;right:1rem;z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:1rem;padding:1rem;box-shadow:0 4px 20px #0000001a;border:1px solid rgba(255,255,255,.2)}.screen-view-controls{display:flex;align-items:center;gap:1rem}.screen-view-controls .view-selector{margin:0}.screen-view-controls .nav-button{padding:.5rem 1rem;font-size:.9rem}.calendar-layout-full.screen-mode{padding:0;margin:0}.calendar-layout-full.screen-mode .calendar-main-full{width:100%;max-width:none}.calendar-layout-full.screen-mode .calendar-content{padding:0;margin:0}@media (prefers-color-scheme: dark){.screen-view-header{background:#1e293bf2;border-color:#ffffff1a}}@media (max-width: 1024px){.screen-view-header{top:.5rem;right:.5rem;padding:.5rem}.screen-view-controls{gap:.5rem}.screen-view-controls .nav-button{padding:.4rem .8rem;font-size:.8rem}}
