:root{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-tertiary:#f7fafc;--bg-hover:#edf2f7;--text-primary:#2d3748;--text-secondary:#4a5568;--text-tertiary:#718096;--text-quaternary:#a0aec0;--border-color:#e2e8f0;--border-hover:#cbd5e0;--shadow-sm:0 2px 4px #0000000d;--shadow-md:0 2px 8px #0000001a;--shadow-lg:0 4px 12px #00000026;--accent-primary:#667eea;--accent-hover:#5568d3;--accent-light:#ebf4ff;--success:#48bb78;--success-light:#c6f6d5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee;--gradient-start:#667eea;--gradient-end:#764ba2}body.dark-mode{--bg-primary:#1a202c;--bg-secondary:#2d3748;--bg-tertiary:#374151;--bg-hover:#4a5568;--text-primary:#f7fafc;--text-secondary:#e2e8f0;--text-tertiary:#cbd5e0;--text-quaternary:#a0aec0;--border-color:#4a5568;--border-hover:#718096;--shadow-sm:0 2px 4px #0000004d;--shadow-md:0 2px 8px #0006;--shadow-lg:0 4px 12px #00000080;--accent-primary:#667eea;--accent-hover:#7c8ef7;--accent-light:#2d3748;--success:#48bb78;--success-light:#2d3748;--warning:#f59e0b;--warning-light:#2d3748;--danger:#ef4444;--danger-light:#2d3748;--gradient-start:#667eea;--gradient-end:#764ba2;background:linear-gradient(135deg,#1a202c,#2d3748)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--gradient-start) 0,var(--gradient-end) 100%);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background .3s ease,color .3s ease}.app,body{min-height:100vh}.app{background:#f5f7fa;background:var(--bg-primary);display:flex;flex-direction:column;transition:background .3s ease}.app-header{background:#fff;background:var(--bg-secondary);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;transition:background .3s ease,box-shadow .3s ease;z-index:100}.header-content{justify-content:space-between;margin:0 auto;max-width:1400px}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.header-icon{color:#667eea;color:var(--accent-primary);height:40px;width:40px}.app-header h1{color:#2d3748;color:var(--text-primary);font-size:1.5rem;margin:0}.app-header p{color:#718096;color:var(--text-tertiary);font-size:.875rem;margin:0}.header-right{align-items:center;display:flex;gap:1rem}.user-info{text-align:right}.user-name{color:#2d3748;color:var(--text-primary);display:block;font-size:.9375rem;font-weight:600}.invite-code{border-radius:4px;color:#718096;color:var(--text-tertiary);display:block;font-family:Courier New,monospace;font-size:.75rem;margin-top:.125rem;padding:.125rem .375rem}.invite-code,.theme-toggle-btn{background:#f7fafc;background:var(--bg-tertiary)}.theme-toggle-btn{align-items:center;border:none;border-radius:8px;color:#4a5568;color:var(--text-secondary);cursor:pointer;display:flex;padding:.5rem;transition:all .3s ease}.theme-toggle-btn:hover{background:#667eea;background:var(--accent-primary);color:#fff;transform:rotate(20deg)}.logout-btn{align-items:center;background:#ef4444;background:var(--danger);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;padding:.5rem;transition:background .2s}.logout-btn:hover{background:#dc2626}.app-nav{background:#fff;background:var(--bg-secondary);border-radius:12px;box-shadow:0 2px 4px #0000000d;box-shadow:var(--shadow-sm);margin:1rem auto;max-width:1400px;overflow-x:auto;padding:.5rem 2rem;scrollbar-color:#cbd5e0 #0000;scrollbar-color:var(--border-hover) #0000;scrollbar-width:thin;transition:background .3s ease}.app-nav,.nav-button{display:flex;gap:.5rem}.nav-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#718096;color:var(--text-tertiary);cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s;white-space:nowrap}.nav-button:hover{background:#f7fafc;background:var(--bg-tertiary);color:#2d3748;color:var(--text-primary)}.nav-button.active{background:#667eea;background:var(--accent-primary);color:#fff}.app-main{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--gradient-start) 0,var(--gradient-end) 100%);display:flex;justify-content:center;min-height:100vh;padding:2rem}.auth-box{background:#fff;background:var(--bg-secondary);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:2rem;transition:background .3s ease;width:100%}.auth-header{margin-bottom:2rem;text-align:center}.auth-logo{color:#667eea;color:var(--accent-primary);margin-bottom:1rem}.auth-header h1{color:#2d3748;color:var(--text-primary);font-size:2rem;margin-bottom:.5rem}.auth-header p{color:#718096;color:var(--text-tertiary)}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.auth-tabs button{background:#fff;background:var(--bg-secondary);border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:8px;color:#718096;color:var(--text-tertiary);cursor:pointer;flex:1 1;font-weight:500;padding:.75rem;transition:all .2s}.auth-tabs button:hover{color:#667eea;color:var(--accent-primary)}.auth-tabs button.active,.auth-tabs button:hover{border-color:#667eea;border-color:var(--accent-primary)}.auth-tabs button.active{background:#667eea;background:var(--accent-primary);color:#fff}.auth-error{background:#fee;background:var(--danger-light);border-radius:8px;color:#ef4444;color:var(--danger);font-size:.875rem;margin-bottom:1rem;padding:.75rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group label{align-items:center;color:#2d3748;display:flex;gap:.5rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e2e8f0;color:#2d3748;font-family:inherit;font-size:1rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea}.form-group textarea{min-height:100px}.color-picker{display:flex;flex-wrap:wrap;gap:.5rem}.color-option{border:3px solid #0000;border-radius:50%;cursor:pointer;height:40px;transition:all .2s;width:40px}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#2d3748;border-color:var(--text-primary);box-shadow:0 0 0 2px #fff,0 0 0 4px #2d3748;box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px var(--text-primary)}.calendar-container{background:var(--bg-secondary);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow-md);padding:1.5rem;transition:background .3s ease}.calendar-header{margin-bottom:1.5rem}.calendar-header h2{color:#2d3748}.calendar-header button{background:#0000;color:#667eea;color:var(--accent-primary)}.calendar-header button:hover{background:#f7fafc;background:var(--bg-tertiary)}.calendar-weekdays{margin-bottom:.5rem}.weekday{color:#718096;padding:.5rem}.calendar-day{background:#fff;border:1px solid #e2e8f0;min-height:100px}.calendar-day:hover{border-color:#667eea}.calendar-day.empty,.calendar-day.empty:hover,.calendar-day:hover{background:#f7fafc;background:var(--bg-tertiary)}.calendar-day.empty:hover{border-color:#e2e8f0;border-color:var(--border-color)}.calendar-day.today{background:#ebf4ff;border-color:#667eea;border-color:var(--accent-primary);font-weight:600}.day-number{color:#2d3748;font-size:.875rem;margin-bottom:.5rem}.event-item{background:#f7fafc;background:var(--bg-tertiary);border-left:3px solid}.event-item,.event-time{color:#4a5568;color:var(--text-secondary)}.event-delete{background:#0000;color:#ef4444;color:var(--danger)}.calendar-legend{margin-top:1.5rem}.legend-item{color:#4a5568;color:var(--text-secondary);font-size:.875rem}.legend-color{border-radius:4px}.modal-overlay{animation:fadeIn .2s ease;background:#000000b3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:var(--bg-secondary);transition:background .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header h3{color:#2d3748}.modal-header button{background:#0000;border-radius:4px;color:#718096;color:var(--text-tertiary);transition:all .2s}.modal-header button:hover{background:#f7fafc;background:var(--bg-tertiary);color:#2d3748}.modal-actions{gap:1rem}.modal-actions button{flex:1 1}.btn-primary{align-items:center;background:#667eea;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:background .2s}.btn-primary:hover{background:#5568d3;background:var(--accent-hover)}.btn-primary:disabled{background:#cbd5e0;background:var(--border-hover)}.btn-secondary{background:#f7fafc;border:none;border-radius:8px;color:#2d3748;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:background .2s}.btn-secondary:hover{background:#edf2f7}.loading{align-items:center;color:#718096;color:var(--text-tertiary);display:flex;flex-direction:column;justify-content:center;padding:3rem}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-top-color:#667eea;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:40px;margin-bottom:1rem;width:40px}@keyframes spin{to{transform:rotate(1turn)}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f7fafc;background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb{background:#cbd5e0;background:var(--border-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a0aec0;background:var(--text-quaternary)}@media (max-width:768px){.app-header{padding:1rem}.header-content{flex-direction:column;gap:1rem}.app-nav{margin:.5rem;padding:.5rem 1rem}.app-main{padding:1rem}.calendar-day{min-height:80px}.form-row{grid-template-columns:1fr}.auth-mobile-container{background-color:#f5f5f0;display:flex;flex-direction:column;min-height:100vh}.auth-mobile-scroll{display:flex;flex:1 1;flex-direction:column;justify-content:center;overflow-y:auto;padding:20px}.auth-mobile-header{align-items:center;display:flex;flex-direction:column;margin-bottom:30px}.auth-mobile-icon-container{align-items:center;background-color:#e8e0e0;border-radius:40px;display:flex;height:80px;justify-content:center;margin-bottom:15px;width:80px}.auth-mobile-title{color:#4a4a4a;font-size:16px;font-weight:400;margin:0;text-align:center}.auth-mobile-switch-container{display:flex;gap:10px;margin-bottom:30px}.auth-mobile-switch-button{align-items:center;background-color:#e8e0e0;border:none;border-radius:25px;color:#6b4c4c;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 20px;transition:all .3s ease}.auth-mobile-switch-button.active{background-color:#6b4c4c;color:#fff}.auth-mobile-switch-button svg{flex-shrink:0}.auth-mobile-form{display:flex;flex-direction:column;gap:16px}.auth-mobile-field{display:flex;flex-direction:column;gap:8px}.auth-mobile-field-label{gap:6px}.auth-mobile-field-label,.auth-mobile-field-label-center{align-items:center;color:#4a4a4a;display:flex;font-size:14px;font-weight:500;justify-content:center}.auth-mobile-field-label-center{margin-bottom:8px}.auth-mobile-field-input{background-color:#fff;border:1px solid #d0d0d0;border-radius:8px;box-sizing:border-box;color:#4a4a4a;font-size:14px;padding:14px 16px;text-align:center;transition:border-color .2s;width:100%}.auth-mobile-field-input:focus{border-color:#6b4c4c;outline:none}.auth-mobile-field-input::placeholder{color:#a0a0a0}.auth-mobile-color-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:4px}.auth-mobile-color-dot{border:3px solid #0000;border-radius:50%;cursor:pointer;height:36px;padding:0;position:relative;transition:all .2s ease;width:36px}.auth-mobile-color-dot.selected{border-color:#333;transform:scale(1.15)}.auth-mobile-color-dot:active{transform:scale(.9)}.auth-mobile-submit-button{background-color:#6b4c4c;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;margin-top:20px;padding:14px 24px;text-transform:lowercase;transition:all .2s ease}.auth-mobile-submit-button:hover{background-color:#5a3c3c}.auth-mobile-submit-button:active{transform:scale(.98)}.auth-mobile-submit-button:disabled{background-color:#a89898;cursor:not-allowed}.auth-mobile-error{background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:13px;margin-bottom:16px;padding:12px 16px;text-align:center}}@media (min-width:769px){.auth-mobile-color-dot,.auth-mobile-color-grid,.auth-mobile-container,.auth-mobile-error,.auth-mobile-field,.auth-mobile-field-input,.auth-mobile-field-label,.auth-mobile-field-label-center,.auth-mobile-form,.auth-mobile-header,.auth-mobile-icon-container,.auth-mobile-scroll,.auth-mobile-submit-button,.auth-mobile-switch-button,.auth-mobile-switch-container,.auth-mobile-title{display:none!important}}@media (max-width:768px){.mobile-calendar-container{background-color:#f5f5f0;display:flex;flex-direction:column;min-height:100vh;padding:20px}.mobile-calendar-header{align-items:center;display:flex;flex-direction:column;margin-bottom:25px}.mobile-header-icon{align-items:center;background-color:#e8e0e0;border-radius:30px;display:flex;height:60px;justify-content:center;margin-bottom:12px;width:60px}.mobile-header-title{color:#4a4a4a;font-size:16px;font-weight:400;margin:0;text-align:center}.mobile-date-section{margin-bottom:20px}.mobile-date-input-wrapper{margin-bottom:10px;position:relative}.mobile-date-input{background-color:#fff;border:1px solid #d0d0d0;border-radius:8px;box-sizing:border-box;color:#4a4a4a;font-size:14px;padding:12px 16px;width:100%}.mobile-format-input{position:relative}.mobile-format-field{background-color:#fff;border:1px solid #d0d0d0;border-radius:8px;box-sizing:border-box;color:#a0a0a0;font-size:14px;padding:12px 16px;text-align:center;width:100%}.mobile-month-nav{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:0 10px}.mobile-nav-button{align-items:center;background:#0000;border:none;color:#4a4a4a;cursor:pointer;display:flex;justify-content:center;padding:8px}.mobile-month-display{align-items:center;display:flex;gap:20px}.mobile-current-month,.mobile-year-selector{color:#4a4a4a;font-size:16px;font-weight:500}.mobile-year-selector{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;gap:8px}.mobile-calendar-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.mobile-weekday{color:#6b6b6b;font-size:13px;font-weight:500;padding:8px 0;text-align:center}.mobile-calendar-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:20px}.mobile-calendar-day{align-items:center;aspect-ratio:1;background-color:#fff;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:4px;position:relative;transition:all .2s ease}.mobile-calendar-day.outside-month{background-color:initial}.mobile-calendar-day.outside-month .mobile-day-number{color:silver}.mobile-calendar-day.today{background-color:#8b6b6b}.mobile-calendar-day.today .mobile-day-number{color:#fff;font-weight:600}.mobile-calendar-day:active{transform:scale(.95)}.mobile-day-number{color:#4a4a4a;font-size:14px;font-weight:400}.mobile-event-dots{display:flex;gap:3px;margin-top:4px}.mobile-event-dot{border-radius:50%;height:6px;width:6px}.mobile-calendar-actions{display:flex;gap:12px;margin-top:auto;padding-top:20px}.mobile-action-btn{border:none;border-radius:25px;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:14px 24px;transition:all .2s ease}.mobile-action-btn.secondary{background-color:#e8e0e0;color:#6b4c4c}.mobile-action-btn.primary{background-color:#6b4c4c;color:#fff}.mobile-action-btn:active{transform:scale(.98)}.mobile-fab{align-items:center;background-color:#6b4c4c;border:none;border-radius:28px;bottom:80px;box-shadow:0 4px 12px #0003;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:20px;transition:all .3s ease;width:56px;z-index:100}.mobile-fab:active{transform:scale(.95)}.mobile-modal{margin:20px;max-height:85vh!important;max-width:90vw!important}.mobile-modal .modal-form{max-height:calc(85vh - 150px);overflow-y:auto}.calendar-container{display:none!important}}@media (min-width:769px){.mobile-action-btn,.mobile-calendar-actions,.mobile-calendar-container,.mobile-calendar-day,.mobile-calendar-grid,.mobile-calendar-header,.mobile-calendar-weekdays,.mobile-current-month,.mobile-date-input,.mobile-date-input-wrapper,.mobile-date-section,.mobile-day-number,.mobile-event-dot,.mobile-event-dots,.mobile-fab,.mobile-format-field,.mobile-format-input,.mobile-header-icon,.mobile-header-title,.mobile-month-display,.mobile-month-nav,.mobile-nav-button,.mobile-weekday,.mobile-year-selector{display:none!important}}@media (max-width:768px){.mobile-app-header{background:#fff;box-shadow:0 2px 8px #0000000d;padding:16px 20px}.mobile-header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.mobile-header-left{align-items:center;display:flex;gap:12px}.mobile-header-icon{color:#6b4c4c;flex-shrink:0}.mobile-header-info{display:flex;flex-direction:column}.mobile-app-title{color:#111827;font-size:18px;font-weight:600;line-height:1.2;margin:0}.mobile-app-subtitle{color:#6b7280;font-size:13px;line-height:1.2;margin:0}.mobile-header-bottom{align-items:center;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;padding-top:12px}.mobile-user-info{display:flex;flex-direction:column;gap:2px}.mobile-user-name{color:#111827;font-size:15px;font-weight:500}.mobile-invite-code{color:#9ca3af;font-family:Courier New,monospace;font-size:12px}.mobile-header-actions{align-items:center;display:flex;gap:8px}.mobile-icon-btn{align-items:center;background:#f3f4f6;border:none;border-radius:20px;color:#6b7280;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.mobile-icon-btn:active{background:#e5e7eb;transform:scale(.95)}.mobile-icon-btn.logout-btn{background:#fee2e2;color:#dc2626}.mobile-app-nav{-webkit-overflow-scrolling:touch;background:#fff;box-shadow:0 -2px 8px #0000000d;display:flex;gap:8px;overflow-x:auto;padding:8px 12px}.mobile-app-nav::-webkit-scrollbar{display:none}.mobile-nav-button{align-items:center;background:#0000;border:none;border-radius:12px;color:#6b7280;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:13px;font-weight:500;gap:6px;justify-content:center;min-width:80px;padding:12px 8px;transition:all .2s}.mobile-nav-button svg{flex-shrink:0}.mobile-nav-button span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav-button.active{background:#6b4c4c;color:#fff}.mobile-nav-button:active{transform:scale(.95)}.app-main.mobile{min-height:calc(100vh - 180px);padding:16px}.app-header,.app-nav{display:none!important}}@media (min-width:769px){.mobile-app-header,.mobile-app-nav{display:none!important}}:root{--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#e9ecef;--bg-hover:#f1f3f5;--border-color:#dee2e6;--text-primary:#212529;--text-secondary:#495057;--text-tertiary:#6c757d;--text-quaternary:#adb5bd;--accent-primary:#6366f1;--accent-hover:#4f46e5;--accent-light:#eef2ff}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--bg-tertiary:#404040;--bg-hover:#4a4a4a;--border-color:#555;--text-primary:#fff;--text-secondary:#e0e0e0;--text-tertiary:#b0b0b0;--text-quaternary:grey;--accent-primary:#818cf8;--accent-hover:#6366f1;--accent-light:#312e81}.calendar-container{background:#fff;background:var(--bg-primary);border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.calendar-toolbar{align-items:center;background:#f8f9fa;background:var(--bg-secondary);border-bottom:1px solid #dee2e6;border-bottom:1px solid var(--border-color);border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:1rem}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:.75rem}.btn-filter{align-items:center;background:#e9ecef;background:var(--bg-tertiary);border:2px solid #dee2e6;border:2px solid var(--border-color);border-radius:8px;color:#495057;color:var(--text-secondary);cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-filter:hover{background:#f1f3f5;background:var(--bg-hover)}.btn-filter.active,.btn-filter:hover{border-color:#6366f1;border-color:var(--accent-primary)}.btn-filter.active{background:#eef2ff;background:var(--accent-light);color:#6366f1;color:var(--accent-primary)}.filter-count{background:#6366f1;background:var(--accent-primary);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .5rem}.search-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:#adb5bd;color:var(--text-quaternary);left:.75rem;pointer-events:none;position:absolute}.search-input{background:#f8f9fa;background:var(--bg-secondary);border:2px solid #dee2e6;border:2px solid var(--border-color);border-radius:8px;color:#212529;color:var(--text-primary);font-size:.875rem;min-width:250px;padding:.5rem .75rem .5rem 2.5rem;transition:border-color .2s}.search-input:focus{border-color:#6366f1;border-color:var(--accent-primary);outline:none}.btn-toolbar{align-items:center;background:#e9ecef;background:var(--bg-tertiary);border:none;border-radius:8px;color:#495057;color:var(--text-secondary);cursor:pointer;display:flex;padding:.5rem;transition:all .2s}.btn-toolbar:hover{background:#6366f1;background:var(--accent-primary);color:#fff}.calendar-header{align-items:center;background:#fff;background:var(--bg-primary);display:flex;justify-content:space-between;padding:1.5rem}.calendar-header h2{color:#212529;color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0}.calendar-header button{background:#e9ecef;background:var(--bg-tertiary);border:none;border-radius:8px;color:#212529;color:var(--text-primary);cursor:pointer;padding:.5rem;transition:background .2s}.calendar-header button:hover{background:#6366f1;background:var(--accent-primary);color:#fff}.calendar-weekdays{grid-gap:.5rem;background:#f8f9fa;background:var(--bg-secondary);display:grid;gap:.5rem;grid-template-columns:repeat(7,1fr);padding:0 1rem}.weekday{color:#6c757d;color:var(--text-tertiary);font-size:.875rem;font-weight:600;padding:.75rem 0;text-align:center}.calendar-grid{grid-gap:.5rem;background:#fff;background:var(--bg-primary);display:grid;gap:.5rem;grid-template-columns:repeat(7,1fr);padding:1rem}.calendar-day{background:#f8f9fa;background:var(--bg-secondary);border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;min-height:120px;padding:.5rem;transition:all .2s}.calendar-day:hover{background:#f1f3f5;background:var(--bg-hover);border-color:#6366f1;border-color:var(--accent-primary)}.calendar-day.empty{background:#0000;border:none;cursor:default}.calendar-day.today{background:#eef2ff;background:var(--accent-light);border:2px solid #6366f1;border:2px solid var(--accent-primary)}.calendar-day.compact{min-height:70px}.day-number{color:#212529;color:var(--text-primary);font-weight:600;margin-bottom:.25rem}.day-events{display:flex;flex-direction:column;gap:.25rem}.event-item{align-items:center;background:#fff;border-left:3px solid #6366f1;border-left:3px solid var(--accent-primary);border-radius:4px;cursor:pointer;display:flex;font-size:.75rem;gap:.25rem;padding:.25rem .5rem;position:relative;transition:all .2s}.event-item:hover{box-shadow:0 2px 4px #0000001a;transform:translateX(2px)}.calendar-day.compact .event-item{font-size:.6875rem;padding:.125rem .375rem}.event-time{color:#6c757d;color:var(--text-tertiary);font-weight:600;white-space:nowrap}.event-title{color:#212529;color:var(--text-primary);flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-delete{align-items:center;background:#ef4444;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;justify-content:center;opacity:0;padding:.125rem;transition:opacity .2s}.event-item:hover .event-delete{opacity:1}.more-events{color:#6c757d;color:var(--text-tertiary);font-size:.6875rem;font-weight:600;padding:.25rem;text-align:center}.calendar-legend{background:#f8f9fa;background:var(--bg-secondary);border-top:1px solid #dee2e6;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border-radius:50%;height:16px;width:16px}.legend-item span{color:#495057;color:var(--text-secondary);font-size:.875rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;background:var(--bg-primary);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;padding:1.5rem;width:100%}.modal-large{max-width:600px}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.modal-header h3{color:#212529;color:var(--text-primary);font-size:1.25rem;margin:0}.modal-header button{background:none;border:none;color:#495057;color:var(--text-secondary);cursor:pointer;padding:.25rem;transition:color .2s}.modal-header button:hover{color:#212529;color:var(--text-primary)}.modal-form{gap:1rem}.form-group,.modal-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#212529;color:var(--text-primary);font-size:.875rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{background:#f8f9fa;background:var(--bg-secondary);border:2px solid #dee2e6;border:2px solid var(--border-color);border-radius:8px;color:#212529;color:var(--text-primary);font-size:.9375rem;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#6366f1;border-color:var(--accent-primary);outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.btn-primary{background:#6366f1;background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#4f46e5;background:var(--accent-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#e9ecef;background:var(--bg-tertiary);color:#212529;color:var(--text-primary)}.btn-secondary:hover{background:#f1f3f5;background:var(--bg-hover)}.filter-content{padding:1rem 0}.filter-section{margin-bottom:1.5rem}.filter-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.filter-section h4{color:#212529;color:var(--text-primary);font-size:1rem;margin:0}.filter-actions{align-items:center;display:flex;gap:.5rem}.btn-link{background:none;border:none;color:#6366f1;color:var(--accent-primary);cursor:pointer;font-size:.875rem;padding:0}.btn-link:hover{text-decoration:underline}.members-filter{display:flex;flex-direction:column;gap:.75rem}.member-checkbox{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.5rem;transition:background .2s}.member-checkbox:hover{background:#e9ecef;background:var(--bg-tertiary)}.member-checkbox input[type=checkbox]{cursor:pointer;height:18px;width:18px}.member-color{border-radius:50%;flex-shrink:0;height:24px;width:24px}.member-checkbox span{color:#212529;color:var(--text-primary);font-size:.9375rem}.integrations-content{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.integration-card{border:2px solid #dee2e6;border:2px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.integration-header{align-items:flex-start;display:flex;gap:1rem}.integration-header h4{color:#212529;color:var(--text-primary);font-size:1.125rem;margin:0 0 .25rem}.integration-header p{color:#6c757d;color:var(--text-tertiary);font-size:.875rem;margin:0}.status-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;margin-top:.5rem;padding:.25rem .75rem}.status-badge.connected{background:#d1fae5;color:#065f46}.integration-actions{display:flex;flex-wrap:wrap;gap:.75rem}.import-status{border-radius:8px;font-size:.875rem;font-weight:500;padding:.75rem}.import-status.success{background:#d1fae5;color:#065f46}.import-status.error{background:#fee2e2;color:#991b1b}.help-text{background:#e9ecef;background:var(--bg-tertiary);border-radius:8px;color:#495057;color:var(--text-secondary);font-size:.875rem;padding:.75rem}.feed-url-box{display:flex;gap:.5rem}.feed-url-input{background:#e9ecef;background:var(--bg-tertiary);border:2px solid #dee2e6;border:2px solid var(--border-color);border-radius:8px;color:#212529;color:var(--text-primary);flex:1 1;font-family:Courier New,monospace;font-size:.875rem;padding:.75rem}.btn-copy{background:#6366f1;background:var(--accent-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:background .2s}.btn-copy:hover{background:#4f46e5;background:var(--accent-hover)}.feed-instructions{background:#e9ecef;background:var(--bg-tertiary);border-radius:8px;padding:1rem}.feed-instructions h5{color:#212529;color:var(--text-primary);font-size:.9375rem;margin:0 0 .75rem}.feed-instructions ul{margin:0;padding-left:1.5rem}.feed-instructions li{color:#495057;color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.feed-instructions strong{color:#212529;color:var(--text-primary)}@media (max-width:768px){.calendar-toolbar{flex-direction:column;gap:.75rem}.toolbar-left,.toolbar-right{justify-content:space-between;width:100%}.search-input{flex:1 1;min-width:auto}.calendar-day{min-height:80px}.calendar-day.compact{min-height:50px}.form-row{grid-template-columns:1fr}.modal-content{max-width:100%}.mobile-calendar-container{background-color:#f5f5f0;max-width:100%;min-height:100vh;overflow-x:hidden;padding:20px 0}.mobile-calendar-container,.mobile-calendar-header{box-sizing:border-box;display:flex;flex-direction:column;width:100%}.mobile-calendar-header{align-items:center;margin-bottom:20px;padding:0 20px}.mobile-header-icon{align-items:center;background-color:#e8e0e0;border-radius:30px;display:flex;flex-shrink:0;height:60px;justify-content:center;margin-bottom:12px;width:60px}.mobile-header-title{word-wrap:break-word;color:#4a4a4a;font-size:15px;font-weight:400;line-height:1.4;margin:0;max-width:100%;padding:0 10px;text-align:center}.mobile-date-section{box-sizing:border-box;margin-bottom:20px;padding:0 20px;width:100%}.mobile-date-input-wrapper{margin-bottom:10px;position:relative;width:100%}.mobile-date-input{color:#4a4a4a;padding:12px 16px}.mobile-format-input{position:relative;width:100%}.mobile-date-input{align-items:center;background-color:#fff;border:1px solid #d0d0d0;border-radius:8px;box-sizing:border-box;color:#a0a0a0;font-size:14px;padding:14px 16px;text-align:center;width:100%}.mobile-month-nav{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:0 10px}.mobile-nav-button{align-items:center;background:#0000;border:none;color:#4a4a4a;cursor:pointer;display:flex;justify-content:center;padding:8px}.mobile-month-display{align-items:center;display:flex;gap:20px}.mobile-current-month,.mobile-year-selector{color:#4a4a4a;font-size:16px;font-weight:500}.mobile-year-selector{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;gap:8px}.mobile-calendar-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.mobile-weekday{color:#6b6b6b;font-size:13px;font-weight:500;padding:8px 0;text-align:center}.mobile-calendar-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:20px}.mobile-calendar-day{align-items:center;aspect-ratio:1;background-color:#fff;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:4px;position:relative;transition:all .2s ease}.mobile-calendar-day.outside-month{background-color:initial}.mobile-calendar-day.outside-month .mobile-day-number{color:silver}.mobile-calendar-day.today{background-color:#8b6b6b}.mobile-calendar-day.today .mobile-day-number{color:#fff;font-weight:600}.mobile-calendar-day:active{transform:scale(.95)}.mobile-day-number{color:#4a4a4a;font-size:14px;font-weight:400}.mobile-event-dots{display:flex;gap:3px;margin-top:4px}.mobile-event-dot{border-radius:50%;height:6px;width:6px}.mobile-calendar-actions{display:flex;gap:12px;margin-top:auto;padding-top:20px}.mobile-action-btn{border:none;border-radius:25px;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:14px 24px;transition:all .2s ease}.mobile-action-btn.secondary{background-color:#e8e0e0;color:#6b4c4c}.mobile-action-btn.primary{background-color:#6b4c4c;color:#fff}.mobile-action-btn:active{transform:scale(.98)}.mobile-fab{align-items:center;background-color:#6b4c4c;border:none;border-radius:28px;bottom:80px;box-shadow:0 4px 12px #0003;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:20px;transition:all .3s ease;width:56px;z-index:100}.mobile-fab:active{transform:scale(.95)}.mobile-event-screen{background-color:#f5f5f0;display:flex;flex-direction:column;min-height:100vh;padding-bottom:20px}.mobile-event-header{align-items:center;display:flex;flex-direction:column;padding:20px;position:relative}.mobile-back-btn{background:#0000;border:none;color:#6b4c4c;cursor:pointer;left:20px;padding:8px;position:absolute;top:20px}.mobile-back-btn,.mobile-event-header-icon{align-items:center;display:flex;justify-content:center}.mobile-event-header-icon{background-color:#e8e0e0;border-radius:30px;height:60px;margin-bottom:12px;width:60px}.mobile-event-header-title{color:#4a4a4a;font-size:16px;font-weight:400;margin:0;text-align:center}.mobile-event-form{display:flex;flex:1 1;flex-direction:column;padding:0 20px}.mobile-event-date-display{margin-bottom:20px}.mobile-date-picker{background-color:#fff;border:1px solid #d0d0d0;border-radius:8px;box-sizing:border-box;color:#4a4a4a;font-size:16px;padding:12px 16px;text-align:center;width:100%}.mobile-event-field{align-items:flex-start;background-color:#fff;border-radius:12px;display:flex;gap:12px;margin-bottom:12px;padding:16px}.mobile-event-field-icon{flex-shrink:0;padding-top:4px}.mobile-category-icon{font-size:24px;line-height:1}.mobile-category-icon.large{font-size:32px}.mobile-event-field-content{display:flex;flex:1 1;flex-direction:column;gap:8px}.mobile-event-field-content.full-width{width:100%}.mobile-event-field-label{color:#8b8b8b;font-size:12px;font-weight:400;text-transform:lowercase}.mobile-event-input,.mobile-event-select{background:#0000;border:none;color:#4a4a4a;font-size:16px;padding:0;width:100%}.mobile-event-input:focus,.mobile-event-select:focus{outline:none}.mobile-event-input::placeholder{color:#b0b0b0}.mobile-event-time-picker{align-items:center;display:flex;gap:16px}.mobile-time-input{background:#0000;border:none;color:#4a4a4a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:48px;font-weight:300;padding:0;width:auto}.mobile-time-input:focus{outline:none}.mobile-time-toggle{display:flex;flex-direction:column;gap:8px}.mobile-time-toggle-btn{background-color:#e8e0e0;border:none;border-radius:12px;color:#6b4c4c;cursor:pointer;font-size:14px;font-weight:500;min-width:50px;padding:8px 16px;transition:all .2s ease}.mobile-time-toggle-btn.active{background-color:#6b4c4c;color:#fff}.mobile-event-actions{display:flex;gap:12px;margin-top:auto;padding:20px}.mobile-event-btn{border:none;border-radius:25px;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:14px 24px;transition:all .2s ease}.mobile-event-btn.secondary{background-color:#e8e0e0;color:#6b4c4c}.mobile-event-btn.primary{background-color:#6b4c4c;color:#fff}.mobile-event-btn.danger{background-color:#dc3545;color:#fff}.mobile-event-btn:active{transform:scale(.98)}.mobile-event-details{display:flex;flex:1 1;flex-direction:column;gap:16px;padding:0 20px}.mobile-event-date-badge{color:#4a4a4a;font-size:16px;font-weight:500;margin-bottom:8px;text-align:center}.mobile-event-date-badge,.mobile-event-detail-row{background-color:#fff;border-radius:12px;padding:16px}.mobile-event-detail-row{align-items:flex-start;display:flex;gap:12px}.mobile-event-detail-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.mobile-event-detail-label{color:#8b8b8b;font-size:12px;font-weight:400;text-transform:lowercase}.mobile-event-detail-value{color:#4a4a4a;font-size:16px;font-weight:400}.mobile-modal{margin:20px;max-height:85vh!important;max-width:90vw!important}.mobile-modal .modal-form{max-height:calc(85vh - 150px);overflow-y:auto}.calendar-container{display:none!important}}@media (min-width:769px){.mobile-action-btn,.mobile-back-btn,.mobile-calendar-actions,.mobile-calendar-container,.mobile-calendar-day,.mobile-calendar-grid,.mobile-calendar-header,.mobile-calendar-weekdays,.mobile-category-icon,.mobile-current-month,.mobile-date-input,.mobile-date-input-wrapper,.mobile-date-picker,.mobile-date-section,.mobile-day-number,.mobile-event-actions,.mobile-event-btn,.mobile-event-date-badge,.mobile-event-date-display,.mobile-event-detail-content,.mobile-event-detail-label,.mobile-event-detail-row,.mobile-event-detail-value,.mobile-event-details,.mobile-event-dot,.mobile-event-dots,.mobile-event-field,.mobile-event-field-content,.mobile-event-field-icon,.mobile-event-field-label,.mobile-event-form,.mobile-event-header,.mobile-event-header-icon,.mobile-event-header-title,.mobile-event-input,.mobile-event-screen,.mobile-event-select,.mobile-event-time-picker,.mobile-fab,.mobile-format-field,.mobile-format-input,.mobile-header-icon,.mobile-header-title,.mobile-month-display,.mobile-month-nav,.mobile-nav-button,.mobile-time-input,.mobile-time-toggle,.mobile-time-toggle-btn,.mobile-weekday,.mobile-year-selector{display:none!important}}@media (max-width:480px){.calendar-grid{gap:1px;grid-template-columns:repeat(7,1fr);padding:0}.calendar-day{border:1px solid #dee2e6;border:1px solid var(--border-color);cursor:pointer;min-height:40px;padding:2px}.calendar-day.today{border-width:2px}.day-number{font-size:.65rem;font-weight:500;margin-bottom:.1rem}.day-events{flex-direction:column;gap:1px;max-height:32px}.day-events,.event-item{display:flex;overflow:hidden}.event-item{align-items:center;border-left-width:2px;border-radius:2px;cursor:pointer;font-size:.55rem;padding:.1rem .15rem}.event-item .event-title{display:none}.event-item .event-time{flex:none;font-size:.55rem;white-space:nowrap}.more-events{font-size:.55rem;padding:1px 0;text-align:center}.calendar-weekdays{font-size:.7rem;padding:0}.calendar-header h2{font-size:1rem}.calendar-header button{padding:.25rem}.calendar-toolbar{flex-direction:column;gap:.25rem;padding:.25rem .5rem}.toolbar-left,.toolbar-right{justify-content:space-between;width:100%}.search-input{flex:1 1;font-size:.75rem;min-width:auto;padding:.25rem .5rem .25rem 1.5rem}.calendar-day.compact{min-height:35px}}
/*# sourceMappingURL=main.c7da88f8.css.map*/