.app-header{display:flex;justify-content:space-between;align-items:center;padding:0 16px;height:64px;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 1px 2px #0000000d;z-index:100}.header-left{display:flex;align-items:center;gap:16px;flex:1}.n8n-status{font-size:12px;font-weight:500;padding:4px 8px;border-radius:4px;white-space:nowrap;margin-right:8px}.n8n-status.online{color:#137333;background:#e6f4ea}.n8n-status.offline{color:#d93025;background:#fce8e6}.sync-button{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #dadce0;border-radius:4px;background:#fff;color:#3c4043;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;margin-right:8px}.sync-button:hover:not(:disabled){background:#f8f9fa;border-color:#1a73e8;color:#1a73e8}.sync-button:disabled{opacity:.6;cursor:not-allowed}.sync-button .spinner{animation:spin 1s linear infinite}.icon-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;color:#5f6368;transition:all .2s ease}.icon-button:hover{background:#f1f3f4;color:#202124}.logo{display:flex;align-items:center;gap:12px;margin-right:8px}.logo-icon{color:#1a73e8;flex-shrink:0}.logo-text{font-size:22px;font-weight:400;color:#5f6368;white-space:nowrap;letter-spacing:.2px}.date-navigation{display:flex;align-items:center;gap:8px;margin-left:16px}.today-button{padding:8px 16px;border:1px solid #dadce0;border-radius:4px;background:#fff;color:#3c4043;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.today-button:hover{background:#f8f9fa;box-shadow:0 1px 2px #0000001a}.nav-controls{display:flex;gap:4px}.nav-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:#5f6368;transition:all .2s ease}.nav-button:hover{background:#f1f3f4;color:#202124}.current-date-display{font-size:22px;font-weight:400;color:#202124;min-width:200px;margin-left:12px;letter-spacing:.3px}.view-selector{display:flex;background:#f1f3f4;border-radius:8px;padding:4px;gap:4px}.view-button{padding:8px 16px;border:none;background:transparent;border-radius:4px;font-size:14px;font-weight:500;color:#5f6368;cursor:pointer;transition:all .2s ease;white-space:nowrap}.view-button:hover{background:#fffc}.view-button.active{background:#fff;color:#1a73e8;box-shadow:0 1px 2px #0000001a}.user-menu-container{position:relative;margin-left:8px}@media (max-width: 768px){.app-header{height:auto;min-height:56px;padding:8px;flex-wrap:wrap;gap:8px}.header-left{flex:1 1 100%;order:1;justify-content:space-between;margin-bottom:4px}.logo-text{display:none}.logo{margin-right:0}.date-navigation{margin-left:0;gap:4px;flex:1;justify-content:center}.current-date-display{font-size:16px;min-width:auto;margin-left:0;text-align:center;flex:1}.nav-controls{gap:2px}.nav-button{width:32px;height:32px;padding:4px}.today-button{padding:6px 12px;font-size:13px;white-space:nowrap}.header-right{flex:1 1 100%;order:2;justify-content:space-between;gap:4px}.n8n-status{font-size:11px;padding:3px 6px;margin-right:4px}.sync-button{padding:4px 8px;font-size:12px;margin-right:4px}.sync-button span{display:none}.sync-button svg{width:14px;height:14px}.view-selector{padding:2px;gap:2px;flex:1;justify-content:center}.view-button{padding:6px 10px;font-size:12px;flex:1;min-width:0}.user-name{display:none}.user-avatar{width:28px;height:28px;font-size:12px}.icon-button{width:36px;height:36px;padding:6px}.user-menu-container{margin-left:0}}@media (max-width: 480px){.app-header{min-height:52px;padding:6px 4px;gap:6px}.header-left{gap:4px;margin-bottom:2px}.date-navigation{gap:2px}.current-date-display{font-size:14px;margin-left:0}.nav-button{width:28px;height:28px;padding:2px}.today-button{padding:4px 8px;font-size:12px}.header-right{gap:2px}.n8n-status{font-size:10px;padding:2px 4px;margin-right:2px}.sync-button{padding:3px 6px;font-size:11px;margin-right:2px}.sync-button span{display:none}.sync-button svg{width:12px;height:12px}.view-selector{padding:1px;gap:1px}.view-button{padding:4px 6px;font-size:11px}.user-avatar{width:24px;height:24px;font-size:11px}.icon-button{width:32px;height:32px;padding:4px}}.sidebar{width:280px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;padding:16px;gap:24px;overflow-y:auto;transition:width .3s ease,transform .3s ease}.sidebar.collapsed{width:0;padding:0;overflow:hidden;transform:translate(-100%)}.create-event-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:#1a73e8;color:#fff;border:none;border-radius:24px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000001f}.create-event-button:hover{background:#1557b0;box-shadow:0 2px 6px #00000029;transform:translateY(-1px)}.create-event-button:active{transform:translateY(0);box-shadow:0 1px 3px #0000001f}.create-event-button svg{flex-shrink:0}.mini-calendar-wrapper{background:#fff;border-radius:8px;padding:8px;box-shadow:0 1px 3px #0000001a}.mini-calendar-wrapper :global(.fc){font-size:13px}.mini-calendar-wrapper :global(.fc-header-toolbar){margin-bottom:12px;padding:0 8px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;position:relative;min-height:32px;gap:8px}.mini-calendar-wrapper :global(.fc-toolbar-chunk){display:flex;align-items:center}.mini-calendar-wrapper :global(.fc-toolbar-chunk:first-child){justify-content:flex-start}.mini-calendar-wrapper :global(.fc-toolbar-chunk:last-child){justify-content:flex-end}.mini-calendar-wrapper :global(.fc-toolbar-chunk:nth-child(2)){justify-content:center;grid-column:2;position:relative}.mini-calendar-wrapper :global(.fc-toolbar-title){font-size:15px;font-weight:500;color:#202124;text-align:center;white-space:nowrap;letter-spacing:.3px;line-height:1.2;margin:0;padding:0;display:block}.mini-calendar-wrapper :global(.fc-button){padding:6px 10px;font-size:13px;border-radius:4px;background:#f1f3f4;border:1px solid #dadce0;color:#5f6368}.mini-calendar-wrapper :global(.fc-button:hover){background:#1557b0;box-shadow:0 1px 3px #0003}.mini-calendar-wrapper :global(.fc-daygrid-day){padding:6px;cursor:pointer;transition:background .2s ease}.mini-calendar-wrapper :global(.fc-daygrid-day:hover){background:#f8f9fa}.mini-calendar-wrapper :global(.fc-daygrid-day-number){padding:6px;font-size:13px;font-weight:400;color:#202124;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.mini-calendar-wrapper :global(.fc-daygrid-day:hover .fc-daygrid-day-number){background:#e8f0fe;color:#1a73e8}.mini-calendar-wrapper :global(.fc-day-today){background:#e8f0fe}.mini-calendar-wrapper :global(.fc-day-today .fc-daygrid-day-number){background:#1a73e8;color:#fff;font-weight:600}.mini-calendar-wrapper :global(.fc-col-header-cell){padding:8px 4px;font-size:12px;font-weight:600;color:#5f6368;text-align:center}.mini-calendar-wrapper :global(.fc-col-header-cell-cushion){display:block;width:100%;text-align:center}.mini-calendar-wrapper :global(.fc-daygrid-day.fc-day-other){opacity:.4}.sidebar-section{display:flex;flex-direction:column;gap:12px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.sync-button{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#5f6368;border-radius:4px;transition:background-color .2s;flex-shrink:0}.sync-button:hover{background-color:#f1f3f4;color:#1a73e8}.sync-button svg{width:16px;height:16px}.section-title{font-size:13px;font-weight:600;color:#5f6368;text-transform:uppercase;letter-spacing:.5px;margin:0}.calendar-list{display:flex;flex-direction:column;gap:4px}.calendar-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:4px;cursor:pointer;transition:background .2s ease;-webkit-user-select:none;user-select:none}.calendar-item:hover{background:#f8f9fa}.calendar-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#1a73e8}.calendar-color-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.1)}.calendar-name{font-size:14px;color:#202124;flex:1;font-weight:400;line-height:1.4}.calendar-item input:checked+.calendar-color-indicator+.calendar-name{font-weight:500}.calendar-loading{padding:12px;text-align:center;color:#5f6368;font-size:13px;font-style:italic}.calendar-owner{font-size:11px;color:#5f6368;font-weight:400;opacity:.7}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:280px;max-width:85vw;z-index:1000;box-shadow:2px 0 8px #00000026;transform:translate(-100%);transition:transform .3s ease;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar:not(.collapsed){transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.active{opacity:1;pointer-events:all}.create-event-button{padding:10px 12px;font-size:13px}.mini-calendar-wrapper{padding:6px}.mini-calendar-wrapper :global(.fc){font-size:11px}.mini-calendar-wrapper :global(.fc-toolbar-title){font-size:13px!important}.mini-calendar-wrapper :global(.fc-daygrid-day-number){font-size:11px!important;padding:4px!important;width:24px!important;height:24px!important}}@media (max-width: 480px){.sidebar{width:260px}.create-event-button{padding:8px 10px;font-size:12px}.mini-calendar-wrapper :global(.fc){font-size:10px}.mini-calendar-wrapper :global(.fc-toolbar-title){font-size:12px!important}.mini-calendar-wrapper :global(.fc-daygrid-day-number){font-size:10px!important;padding:3px!important;width:20px!important;height:20px!important}}.time-picker-wrapper{position:relative;display:inline-block}.time-picker-display{background:#f1f3f4;border:1px solid #dadce0;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;color:#3c4043;min-width:60px;text-align:center;-webkit-user-select:none;user-select:none}.time-picker-display:hover{background:#e8eaed}.time-picker-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 2px 10px #0003;z-index:1000;display:flex;max-height:300px;overflow:hidden}.time-picker-column{display:flex;flex-direction:column;min-width:60px}.time-picker-header{padding:8px;background:#f8f9fa;border-bottom:1px solid #dadce0;font-weight:600;font-size:12px;text-align:center;color:#5f6368}.time-picker-list{overflow-y:auto;max-height:250px}.time-picker-item{padding:8px 12px;cursor:pointer;text-align:center;font-size:14px;color:#3c4043;transition:background .1s}.time-picker-item:hover{background:#f1f3f4}.time-picker-item.selected{background:#1a73e8;color:#fff}.time-picker-item.selected:hover{background:#1557b0}.contact-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.contact-modal{background:#fff;border-radius:8px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f,0 5px 5px -3px #0003;overflow:hidden}.contact-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #e0e0e0}.contact-modal-title-section{display:flex;align-items:center;gap:16px;flex:1}.contact-modal-avatar{width:40px;height:40px;border-radius:50%;background:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:16px;flex-shrink:0}.contact-modal-title{font-size:20px;font-weight:400;color:#202124;margin:0}.contact-modal-close{width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5f6368;transition:background .2s;flex-shrink:0}.contact-modal-close:hover{background:#f1f3f4}.contact-modal-form{flex:1;display:flex;flex-direction:column;overflow-y:auto}.form-section{padding:24px;flex:1}.form-field{margin-bottom:24px}.form-field:last-child{margin-bottom:0}.form-label{display:block;font-size:14px;font-weight:500;color:#5f6368;margin-bottom:8px}.form-input{width:100%;padding:10px 12px;border:1px solid #dadce0;border-radius:4px;font-size:14px;color:#202124;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-input:focus{border-color:#1a73e8;box-shadow:0 0 0 1px #1a73e8}.form-input::placeholder{color:#9aa0a6}.form-actions{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid #e0e0e0;background:#f8f9fa}.cancel-button{padding:10px 24px;border:1px solid #dadce0;border-radius:4px;background:#fff;color:#202124;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;min-width:80px}.cancel-button:hover{background:#f8f9fa}.save-button{padding:10px 24px;border:none;border-radius:4px;background:#1a73e8;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;min-width:80px}.save-button:hover{background:#1557b0}.save-button:active{background:#0d47a1}@media (max-width: 768px){.contact-modal{max-width:100%;max-height:100vh;max-height:100dvh;border-radius:0}.contact-modal-overlay{padding:0}.contact-modal-header,.form-section{padding:16px}.form-actions{padding:12px 16px}}@media (max-width: 480px){.contact-modal-header{padding:12px}.contact-modal-title{font-size:18px}.contact-modal-avatar{width:32px;height:32px;font-size:14px}.form-section{padding:12px}.form-actions{padding:10px 12px;flex-direction:column-reverse}.cancel-button,.save-button{width:100%}}.contact-detail-page{width:100%;height:100vh;display:flex;flex-direction:column;background:#fff;overflow-y:auto}.contact-detail-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid #e0e0e0;position:sticky;top:0;background:#fff;z-index:100}.back-button{width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5f6368;transition:background .2s;margin-right:8px}.back-button:hover{background:#f1f3f4}.header-actions{display:flex;align-items:center;gap:8px}.star-button{width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5f6368;transition:background .2s}.star-button:hover{background:#f1f3f4}.edit-button{padding:8px 24px;border:1px solid #dadce0;border-radius:4px;background:#fff;color:#1a73e8;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.edit-button:hover{background:#f8f9fa}.delete-button{padding:8px 24px;border:1px solid #dadce0;border-radius:4px;background:#fff;color:#d93025;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.delete-button:hover{background:#fce8e6;border-color:#d93025}.more-button{width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5f6368;transition:background .2s}.more-button:hover{background:#f1f3f4}.contact-detail-content{max-width:800px;margin:0 auto;padding:24px;width:100%}.contact-profile-section{display:flex;flex-direction:column;align-items:center;padding:32px 0;border-bottom:1px solid #e0e0e0;margin-bottom:24px}.contact-avatar-large{width:96px;height:96px;border-radius:50%;background:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:36px;margin-bottom:16px}.contact-name-large{font-size:32px;font-weight:400;color:#202124;margin:0;text-align:center}.contact-actions-row{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.action-card{flex:1;min-width:120px;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;border:1px solid #dadce0;border-radius:8px;background:#fff;cursor:pointer;transition:background .2s,box-shadow .2s}.action-card:hover{background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.action-card svg{color:#5f6368}.action-card span{font-size:13px;color:#5f6368}.add-label-button{display:flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid #dadce0;border-radius:4px;background:#fff;color:#5f6368;font-size:14px;cursor:pointer;transition:background .2s;margin-bottom:32px}.add-label-button:hover{background:#f8f9fa}.contact-details-section{background:#f8f9fa;border-radius:8px;padding:16px;margin-bottom:24px}.section-title{font-size:16px;font-weight:500;color:#202124;margin:0 0 16px}.detail-item{display:flex;flex-direction:column;gap:12px}.detail-row{display:flex;align-items:flex-start;gap:16px}.detail-icon{color:#5f6368;flex-shrink:0;margin-top:2px}.detail-content{display:flex;flex-direction:column;gap:4px;flex:1}.detail-value{font-size:14px;color:#202124}.detail-label{font-size:12px;color:#5f6368}.detail-link{font-size:14px;color:#1a73e8;cursor:pointer}.detail-link:hover{text-decoration:underline}.contact-timeline-section{margin-top:24px}.timeline-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.help-icon{width:20px;height:20px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5f6368;transition:background .2s}.help-icon:hover{background:#f1f3f4}.timeline-content{display:flex;flex-direction:column;gap:8px}.timeline-item{padding:8px 0}.timeline-text{font-size:14px;color:#5f6368}@media (max-width: 768px){.contact-detail-header{padding:8px 12px}.contact-detail-content{padding:16px}.contact-profile-section{padding:24px 0}.contact-avatar-large{width:80px;height:80px;font-size:30px}.contact-name-large{font-size:24px}.contact-actions-row{gap:8px}.action-card{min-width:100px;padding:12px}.action-card svg{width:20px;height:20px}.action-card span{font-size:12px}.contact-details-section,.contact-timeline-section{padding:12px}}@media (max-width: 480px){.contact-detail-header{padding:6px 8px}.back-button,.star-button,.more-button{width:36px;height:36px}.edit-button,.delete-button{padding:6px 16px;font-size:13px}.contact-detail-content{padding:12px}.contact-profile-section{padding:16px 0}.contact-avatar-large{width:64px;height:64px;font-size:24px}.contact-name-large{font-size:20px}.contact-actions-row{gap:6px;flex-wrap:wrap}.action-card{flex:1 1 calc(50% - 3px);min-width:0;padding:10px}.action-card svg{width:18px;height:18px}.action-card span{font-size:11px}.add-label-button{padding:6px 12px;font-size:13px}.contact-details-section,.contact-timeline-section{padding:10px}.section-title{font-size:14px}.detail-value,.detail-link{font-size:13px}.detail-label{font-size:11px}}.contacts-page{width:100%;height:100vh;display:flex;flex-direction:column;background:#fff;overflow:hidden}.contacts-top-bar{display:flex;align-items:center;padding:8px 16px;border-bottom:1px solid #e0e0e0;gap:16px;position:relative}.back-to-calendar-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#1a73e8;color:#fff;border:none;border-radius:24px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s,box-shadow .2s;white-space:nowrap}.back-to-calendar-button:hover{background:#1557b0;box-shadow:0 2px 4px #1a73e84d}.back-to-calendar-button:active{background:#1348a0}.back-to-calendar-button svg{width:20px;height:20px}.user-menu-container{position:relative;margin-left:auto}.user-button{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 4px;border:none;background:transparent;border-radius:20px;cursor:pointer;transition:all .2s ease}.user-button:hover{background:#f1f3f4}.user-avatar{width:32px;height:32px;border-radius:50%;background:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;flex-shrink:0}.user-avatar.large{width:48px;height:48px;font-size:20px}.user-name{font-size:14px;color:#202124;font-weight:500}.dropdown-icon{transition:transform .2s ease;color:#5f6368}.dropdown-icon.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0003;min-width:280px;overflow:hidden;z-index:1000;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border:none;background:transparent;width:100%;text-align:left;cursor:pointer;color:#202124;font-size:14px;transition:background .2s ease}.dropdown-item:hover{background:#f8f9fa}.user-info-item{flex-direction:column;align-items:flex-start;gap:12px}.user-info-item .user-avatar{align-self:flex-start}.user-email{font-weight:500;color:#202124}.user-status{font-size:12px;color:#5f6368}.dropdown-divider{height:1px;background:#e0e0e0;margin:4px 0}.search-container{flex:1;max-width:720px;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#5f6368;pointer-events:none}.search-input{width:100%;padding:10px 16px 10px 48px;border:1px solid #dadce0;border-radius:24px;font-size:14px;outline:none;transition:box-shadow .2s}.search-input:focus{box-shadow:0 2px 5px 1px #403c4329;border-color:transparent}.top-bar-icons{display:flex;align-items:center;gap:8px}.icon-button{width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5f6368;transition:background .2s}.icon-button:hover{background:#f1f3f4}.profile-icon{width:32px;height:32px;border-radius:50%;background:#34a853;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:14px;cursor:pointer}.contacts-main-content{flex:1;overflow-y:auto;padding:0}.contacts-header-section{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e0e0e0}.contacts-title{font-size:22px;font-weight:400;color:#202124;margin:0}.contacts-actions{display:flex;gap:8px}.action-button{width:40px;height:40px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5f6368;transition:background .2s}.action-button:hover{background:#f1f3f4}.contacts-table-container{overflow-x:auto}.contacts-table{width:100%;border-collapse:collapse;font-size:14px}.contacts-table thead{background:#f8f9fa;position:sticky;top:0;z-index:10}.contacts-table th{padding:12px 16px;text-align:left;font-weight:500;color:#5f6368;font-size:12px;text-transform:uppercase;border-bottom:1px solid #e0e0e0}.actions-column{width:80px;text-align:center}.contacts-group-header{background:#f8f9fa;font-weight:500;color:#5f6368;font-size:13px}.contacts-group-header td{padding:8px 16px;border-bottom:1px solid #e0e0e0}.contact-row{cursor:pointer;transition:background .1s;border-bottom:1px solid #f1f3f4}.contact-row:hover{background:#f8f9fa}.contact-row td{padding:12px 16px;color:#202124}.contact-actions-cell{padding:12px 16px;text-align:center}.delete-contact-button{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:50%;cursor:pointer;color:#5f6368;transition:all .2s ease;padding:0}.delete-contact-button:hover{background:#fce8e6;color:#d93025}.delete-contact-button:active{background:#f9ab9f}.contact-name-cell{display:flex;align-items:center;gap:12px}.contact-avatar{width:32px;height:32px;border-radius:50%;background:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:13px;flex-shrink:0}.empty-message{text-align:center;padding:48px;color:#5f6368;font-size:14px}.fab-button{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#1a73e8;color:#fff;border:none;cursor:pointer;box-shadow:0 2px 5px #0003,0 2px 10px #0000001a;display:flex;align-items:center;justify-content:center;transition:box-shadow .2s,transform .2s;z-index:1000}.fab-button:hover{box-shadow:0 4px 8px #0003,0 4px 12px #00000026;transform:translateY(-2px)}.fab-button:active{transform:translateY(0)}@media (max-width: 768px){.contacts-top-bar{padding:8px 12px;gap:12px}.back-to-calendar-button{padding:6px 12px;font-size:13px;gap:6px}.back-to-calendar-button svg{width:18px;height:18px}.back-to-calendar-button span,.user-name{display:none}.user-avatar{width:28px;height:28px;font-size:12px}.user-menu-container{margin-left:auto}.search-input{padding:8px 14px 8px 40px;font-size:13px}.contacts-header-section{padding:12px 16px}.contacts-title{font-size:18px}.contacts-table th,.contacts-table td{padding:8px 12px;font-size:13px}.contact-avatar{width:28px;height:28px;font-size:12px}.fab-button{width:48px;height:48px;bottom:16px;right:16px}}@media (max-width: 480px){.contacts-top-bar{padding:6px 8px;gap:8px}.back-to-calendar-button{padding:6px 10px;min-width:40px}.user-avatar{width:24px;height:24px;font-size:11px}.search-container{max-width:none}.search-input{padding:6px 12px 6px 36px;font-size:12px}.icon-button{width:32px;height:32px}.contacts-header-section{padding:10px 12px;flex-direction:column;align-items:flex-start;gap:8px}.contacts-title{font-size:16px}.contacts-actions{align-self:flex-end}.contacts-table{font-size:12px}.contacts-table th{padding:8px;font-size:11px}.contacts-table td{padding:8px;font-size:12px}.actions-column{width:60px}.delete-contact-button{width:28px;height:28px}.delete-contact-button svg{width:16px;height:16px}.contact-avatar{width:24px;height:24px;font-size:11px}.contact-name-cell{gap:8px}.fab-button{width:44px;height:44px;bottom:12px;right:12px}}.settings-page{display:flex;flex-direction:column;height:100vh;background:#f8f9fa}.settings-header{display:flex;align-items:center;gap:16px;padding:16px 24px;background:#fff;border-bottom:1px solid #e0e0e0}.back-button{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #dadce0;border-radius:4px;background:#fff;color:#3c4043;font-size:14px;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#f8f9fa;border-color:#1a73e8;color:#1a73e8}.settings-header h1{font-size:24px;font-weight:400;color:#202124;margin:0}.settings-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:16px;color:#5f6368}.settings-message{margin:16px 24px;padding:12px 16px;border-radius:4px;font-size:14px}.settings-message.success{background:#e6f4ea;color:#137333;border:1px solid #c2e7d0}.settings-message.error{background:#fce8e6;color:#d93025;border:1px solid #f9ab00}.settings-tabs{display:flex;gap:0;padding:0 24px;background:#fff;border-bottom:1px solid #e0e0e0}.settings-tab{padding:12px 24px;border:none;background:transparent;border-bottom:2px solid transparent;font-size:14px;font-weight:500;color:#5f6368;cursor:pointer;transition:all .2s ease}.settings-tab:hover{color:#1a73e8;background:#f8f9fa}.settings-tab.active{color:#1a73e8;border-bottom-color:#1a73e8}.settings-content{flex:1;overflow-y:auto;padding:24px}.settings-section{max-width:800px;background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 2px #0000000d}.settings-section h2{font-size:20px;font-weight:500;color:#202124;margin:0 0 24px}.settings-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#3c4043}.form-group input{padding:10px 12px;border:1px solid #dadce0;border-radius:4px;font-size:14px;color:#202124;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e81a}.form-group small{font-size:12px;color:#5f6368;margin-top:-4px}.form-actions{display:flex;gap:12px;margin-top:8px;padding-top:20px;border-top:1px solid #e0e0e0}.save-button,.test-button{padding:10px 24px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.save-button{background:#1a73e8;color:#fff}.save-button:hover:not(:disabled){background:#1557b0;box-shadow:0 1px 3px #0003}.save-button:disabled{opacity:.6;cursor:not-allowed}.test-button{background:#f1f3f4;color:#3c4043;border:1px solid #dadce0}.test-button:hover:not(:disabled){background:#e8eaed}.test-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.settings-header{padding:12px 16px}.settings-header h1{font-size:20px}.settings-tabs{padding:0 16px;overflow-x:auto}.settings-tab{padding:10px 16px;font-size:13px;white-space:nowrap}.settings-content,.settings-section{padding:16px}.form-actions{flex-direction:column}.save-button,.test-button{width:100%}}.audit-log-table{overflow-x:auto;margin-top:16px}.audit-log-table table{width:100%;border-collapse:collapse;background:#fff}.audit-log-table th{background:#f8f9fa;position:sticky;top:0;z-index:10}.audit-log-table tbody tr:hover{background:#f8f9fa}@media (max-width: 768px){.audit-log-table{font-size:12px}.audit-log-table th,.audit-log-table td{padding:8px 4px}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{display:flex;flex:1;overflow:hidden}.calendar-container{flex:1;padding:16px;overflow:auto;background:#fff}.calendar-container :global(.fc){height:100%;font-family:Google Sans,Segoe UI,sans-serif}.calendar-container :global(.fc-header-toolbar){margin-bottom:1.5em}.calendar-container :global(.fc-button){background:#fff;border:1px solid #dadce0;color:#3c4043;padding:8px 16px;border-radius:4px;font-weight:500;transition:all .2s ease}.calendar-container :global(.fc-button:hover){background:#f8f9fa;border-color:#dadce0}.calendar-container :global(.fc-button-primary:not(:disabled):active),.calendar-container :global(.fc-button-primary:not(:disabled).fc-button-active){background:#1a73e8;border-color:#1a73e8;color:#fff}.calendar-container :global(.fc-daygrid-day){border-color:#e0e0e0}.calendar-container :global(.fc-day-today){background:#f8f9fa}.calendar-container :global(.fc-day-today .fc-daygrid-day-number){color:#1a73e8;font-weight:600}.calendar-container :global(.fc-timegrid-slot){border-color:#f0f0f0}.calendar-container :global(.fc-timegrid-slot-label){color:#5f6368;font-size:12px}.calendar-container :global(.fc-event){border:none;border-radius:4px;padding:2px 4px;cursor:pointer;transition:all .2s ease}.calendar-container :global(.fc-event:hover){box-shadow:0 2px 4px #0003;transform:translateY(-1px)}.calendar-container :global(.fc-event-title){font-weight:500;padding:0}.fc-event-content-custom{display:flex;flex-direction:column;gap:2px;padding:2px 0}.event-title{font-weight:500;font-size:13px;line-height:1.4;color:inherit;margin-bottom:2px}.event-time{font-size:11px;opacity:.85;line-height:1.3;font-weight:400}.calendar-container :global(.fc-daygrid-event){margin:1px 2px}.calendar-container :global(.fc-timegrid-event){border-left:3px solid #1a73e8}.calendar-container :global(.fc-col-header-cell){padding:8px 4px;background:#f8f9fa;border-color:#e0e0e0}.calendar-container :global(.fc-col-header-cell-cushion){font-weight:500;color:#5f6368;font-size:13px;text-transform:uppercase;letter-spacing:.5px;padding:12px 4px}.calendar-container :global(.fc-scrollgrid){border-color:#e0e0e0}.calendar-container :global(.fc-scrollgrid-section-header){border-color:#e0e0e0}.calendar-container :global(.fc-timegrid-col){border-color:#f0f0f0}.calendar-container :global(.fc-timegrid-now-indicator-line){border-color:#ea4335;border-width:2px}.calendar-container :global(.fc-timegrid-now-indicator-arrow){border-color:#ea4335}.calendar-container::-webkit-scrollbar,.sidebar::-webkit-scrollbar{width:8px;height:8px}.calendar-container::-webkit-scrollbar-track,.sidebar::-webkit-scrollbar-track{background:#f1f1f1}.calendar-container::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.calendar-container::-webkit-scrollbar-thumb:hover,.sidebar::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 768px){.app-layout{height:100vh;height:100dvh;display:flex;flex-direction:column}.main-content{flex-direction:row;flex:1;overflow:hidden;position:relative}.calendar-container{padding:4px 2px;width:100%;overflow:hidden;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}.calendar-container :global(.fc){height:100%!important;display:flex;flex-direction:column}.calendar-container :global(.fc-view-harness){flex:1;overflow:auto;-webkit-overflow-scrolling:touch}.calendar-container :global(.fc-daygrid-day),.calendar-container :global(.fc-timegrid-slot){cursor:pointer;-webkit-tap-highlight-color:rgba(26,115,232,.1);min-height:40px}.calendar-container :global(.fc-daygrid-day:hover),.calendar-container :global(.fc-timegrid-slot:hover){background:#f8f9fa}.calendar-container :global(.fc-event){cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:24px}.calendar-container :global(.fc-timeGridWeek-view){overflow-x:auto;overflow-y:auto}.calendar-container :global(.fc-timegrid-col){min-width:70px}.calendar-container :global(.fc-col-header-cell){min-width:70px}.calendar-container :global(.fc-col-header-cell-cushion){padding:6px 4px!important;font-size:11px!important;white-space:nowrap}.calendar-container :global(.fc-daygrid-day-frame){min-height:60px}.calendar-container :global(.fc-daygrid-day-number){padding:4px 6px!important;font-size:13px!important}.calendar-container :global(.fc){font-size:12px}.calendar-container :global(.fc-toolbar-title){font-size:16px!important}.calendar-container :global(.fc-col-header-cell-cushion){font-size:11px!important;padding:8px 2px!important}.calendar-container :global(.fc-timegrid-slot-label){font-size:10px!important;padding:2px 4px!important;width:40px}.calendar-container :global(.fc-timegrid-slot-label-cushion){font-size:10px!important}.calendar-container :global(.fc-event){font-size:11px!important;padding:2px 4px!important;margin:1px 2px;border-radius:3px}.event-title{font-size:11px!important;line-height:1.3}.event-time{font-size:9px!important;line-height:1.2}.calendar-container :global(.fc-scrollgrid-sync-table){min-width:100%}.calendar-container :global(.fc-scrollgrid-section-header){position:sticky;top:0;z-index:5;background:#fff}}@media (max-width: 480px){.calendar-container{padding:4px 2px}.calendar-container :global(.fc){font-size:11px}.calendar-container :global(.fc-toolbar-title){font-size:14px!important}.calendar-container :global(.fc-col-header-cell-cushion){font-size:10px!important;padding:6px 1px!important}.calendar-container :global(.fc-timegrid-slot-label){font-size:9px!important;width:35px;padding:1px 2px!important}.calendar-container :global(.fc-timegrid-col){min-width:65px}.calendar-container :global(.fc-col-header-cell){min-width:65px}.calendar-container :global(.fc-daygrid-day-frame){min-height:50px}.calendar-container :global(.fc-daygrid-day-number){font-size:12px!important;padding:3px 4px!important}.calendar-container :global(.fc-event){font-size:10px!important;padding:2px 3px!important;margin:1px}.event-title{font-size:10px!important;line-height:1.2}.event-time{font-size:8px!important;line-height:1.1}.fc-event-content-custom{padding:1px 0;gap:1px}}.header-left{display:flex;align-items:center;gap:16px}.menu-icon{background:none;border:none;font-size:20px;cursor:pointer;padding:8px;color:#5f6368;border-radius:50%;transition:background .2s}.menu-icon:hover{background:#f1f3f4}.logo{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:400;color:#5f6368}.logo-icon{font-size:24px}.logo-text{color:#5f6368}.today-btn{background:#fff;border:1px solid #dadce0;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;color:#3c4043;transition:background .2s}.today-btn:hover{background:#f8f9fa}.nav-arrows{display:flex;gap:4px}.nav-arrow{background:none;border:none;font-size:20px;cursor:pointer;padding:8px;color:#5f6368;border-radius:50%;transition:background .2s}.nav-arrow:hover{background:#f1f3f4}.current-date{font-size:22px;font-weight:400;color:#3c4043;min-width:180px}.header-right{display:flex;align-items:center;gap:8px}.user-info{display:flex;align-items:center;gap:12px;margin-left:8px;padding-left:12px;border-left:1px solid #dadce0}.user-info span{font-size:14px;color:#3c4043;font-weight:500}.logout-btn{background:#f1f3f4;border:1px solid #dadce0;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;color:#3c4043;transition:background .2s}.logout-btn:hover{background:#e8eaed}.view-selector{display:flex;border:1px solid #dadce0;border-radius:4px;overflow:hidden}.view-icon-btn{background:#fff;border:none;border-right:1px solid #dadce0;padding:8px 16px;cursor:pointer;font-size:14px;color:#5f6368;transition:background .2s}.view-icon-btn:last-child{border-right:none}.view-icon-btn:hover{background:#f8f9fa}.view-icon-btn.active{background:#e8f0fe;color:#1a73e8}.settings-icon,.contacts-icon{background:none;border:none;font-size:20px;cursor:pointer;padding:8px;color:#5f6368;border-radius:50%;transition:background .2s}.settings-icon:hover,.contacts-icon:hover{background:#f1f3f4}.calendar-container{flex:1;overflow:hidden;background:#fff}#calendar{height:100%;padding:16px}#calendar .fc-toolbar{display:none}#miniCalendar{margin-bottom:16px}#miniCalendar .fc{font-size:12px}#miniCalendar .fc-toolbar-title{font-size:14px!important}#miniCalendar .fc-daygrid-day-number{font-size:12px!important;padding:4px!important}#miniCalendar .fc-day-today{background:#e8f0fe!important}#miniCalendar .fc-day-today .fc-daygrid-day-number{background:#1a73e8;color:#fff!important;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.contacts-panel{position:fixed;right:0;top:64px;width:400px;height:calc(100vh - 64px);background:#fff;border-left:1px solid #dadce0;padding:20px;overflow-y:auto;z-index:100;box-shadow:-2px 0 8px #0000001a}.contacts-panel.hidden{display:none}.contacts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.contacts-header h2{color:#3c4043;font-size:20px;font-weight:400}.add-btn{padding:8px 16px;background:#1a73e8;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.add-btn:hover{background:#1557b0}.contacts-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.contact-item{padding:16px;border:1px solid #dadce0;border-radius:8px;background:#f8f9fa;transition:box-shadow .2s}.contact-item:hover{box-shadow:0 2px 8px #0000001a}.contact-name{font-weight:500;font-size:16px;color:#3c4043;margin-bottom:8px}.contact-detail{font-size:14px;color:#5f6368;margin-top:4px}.empty-message{text-align:center;color:#5f6368;padding:40px}.fc{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.fc-header-toolbar{margin-bottom:20px}.fc-button{background:#1a73e8!important;border:none!important;padding:8px 16px!important;border-radius:4px!important;font-weight:500!important;text-transform:none!important}.fc-button:hover{background:#1557b0!important}.fc-button-primary:not(:disabled):active,.fc-button-primary:not(:disabled).fc-button-active{background:#1557b0!important}.fc-today-button{background:#fff!important;color:#1a73e8!important;border:1px solid #dadce0!important}.fc-today-button:hover{background:#f8f9fa!important}.fc-toolbar-title{font-size:22px!important;font-weight:400!important;color:#3c4043!important}.fc-daygrid-day-number{color:#5f6368!important;font-weight:400!important}.fc-day-today{background:#e8f0fe!important}.fc-event{border:none!important;border-radius:4px!important;padding:0!important;cursor:pointer!important;background:#1a73e8;color:#fff!important;overflow:visible!important}.fc-event:hover{opacity:.9}.fc-event .fc-event-title{display:none!important}.fc-event-content-custom{padding:6px 8px;display:flex!important;flex-direction:column!important;height:100%;min-height:40px;justify-content:center;width:100%;box-sizing:border-box}.event-title{font-weight:500;font-size:13px;line-height:1.3;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block!important;color:#fff!important;flex-shrink:0}.event-time{font-size:11px;line-height:1.2;opacity:.95;white-space:nowrap;display:block!important;color:#fff!important;flex-shrink:0}.fc-daygrid-event,.fc-timegrid-event{border-radius:4px!important}.modal{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#00000080;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;margin:5% auto;padding:0;border-radius:8px;width:90%;max-width:800px;box-shadow:0 4px 20px #0000004d;animation:slideDown .3s;max-height:90vh;overflow-y:auto}.event-modal{display:flex;flex-direction:column}.event-modal-header{display:flex;align-items:center;padding:16px 24px;border-bottom:1px solid #dadce0;gap:16px}.event-title-input{flex:1;border:none;font-size:22px;font-weight:400;color:#3c4043;padding:8px 0;outline:none}.event-title-input::placeholder{color:#9aa0a6}.help-icon{color:#5f6368;cursor:pointer;font-size:20px;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.save-btn-top{background:#1a73e8;color:#fff;border:none;padding:8px 24px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.save-btn-top:hover{background:#1557b0}.event-datetime-section{padding:16px 24px;border-bottom:1px solid #dadce0}.datetime-buttons{display:flex;align-items:center;gap:8px;margin-bottom:8px}.datetime-btn-wrapper{position:relative;display:inline-block;cursor:pointer}.datetime-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:10;pointer-events:auto;font-size:0;margin:0;padding:0;border:none;background:transparent}.time-input-wrapper{position:relative}.datetime-input-time{position:absolute;top:0;left:0;width:100%;height:100%;opacity:.01;cursor:pointer;z-index:20;pointer-events:auto;font-size:14px;margin:0;padding:0;border:none;background:transparent;color:transparent}.time-input-wrapper .datetime-btn{pointer-events:none;z-index:5;position:relative}.datetime-btn{background:#f1f3f4;border:1px solid #dadce0;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;color:#3c4043;transition:background .2s;display:inline-block;position:relative;z-index:1;pointer-events:auto;-webkit-user-select:none;user-select:none}.datetime-btn-wrapper:hover .datetime-btn{background:#e8eaed}.datetime-separator{color:#5f6368;padding:0 4px}.datetime-options{display:flex;align-items:center;gap:16px;margin-top:12px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#3c4043}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.repeat-btn{background:#f1f3f4;border:1px solid #dadce0;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;color:#3c4043;display:flex;align-items:center;gap:8px}.dropdown-arrow{font-size:10px;color:#5f6368}.event-modal-body{min-height:400px}.event-left-column{padding:16px 24px}.event-tabs{display:flex;gap:0;margin-bottom:16px;border-bottom:1px solid #dadce0}.tab-btn{background:none;border:none;padding:12px 16px;font-size:14px;color:#5f6368;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab-btn.active{color:#1a73e8;border-bottom-color:#1a73e8}.tab-btn:hover{background:#f8f9fa}.event-field{display:flex;align-items:center;gap:12px;margin-bottom:16px}.field-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:18px}.field-input,.field-select{flex:1;border:none;border-bottom:1px solid #dadce0;padding:8px 0;font-size:14px;color:#3c4043;outline:none;transition:border-color .2s}.field-input:focus,.field-select:focus{border-bottom-color:#1a73e8}.field-input::placeholder{color:#9aa0a6}.notification-field{display:flex;align-items:center;gap:8px;flex:1}.notification-select{border:1px solid #dadce0;border-radius:4px;padding:6px 8px;font-size:14px;background:#fff}.notification-input{width:60px;border:1px solid #dadce0;border-radius:4px;padding:6px 8px;font-size:14px}.remove-notification{color:#5f6368;cursor:pointer;font-size:20px;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.add-link{color:#1a73e8;text-decoration:none;font-size:14px;margin-left:auto}.add-link:hover{text-decoration:underline}.toggle-switch{position:relative;display:inline-block;width:40px;height:20px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:20px}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#1a73e8}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.help-icon-small{color:#5f6368;cursor:pointer;font-size:16px;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.event-description{margin-top:16px}.description-toolbar{display:flex;gap:4px;padding:8px;border-bottom:1px solid #dadce0;margin-bottom:8px}.toolbar-btn{background:none;border:none;padding:4px 8px;cursor:pointer;font-size:14px;color:#5f6368;border-radius:2px;transition:background .2s}.toolbar-btn:hover{background:#f1f3f4}.description-textarea{width:100%;min-height:120px;border:none;padding:8px;font-size:14px;font-family:inherit;resize:vertical;outline:none}.event-modal-footer{padding:16px 24px;border-top:1px solid #dadce0;display:flex;justify-content:flex-start}.delete-btn{background:#ea4335;color:#fff;border:none;padding:8px 16px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.delete-btn:hover{background:#c5221f}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.close-contact{color:#aaa;float:right;font-size:28px;font-weight:700;cursor:pointer;line-height:20px}.close-contact:hover,.close-contact:focus{color:#000}#modalTitle,#contactModalTitle{color:#3c4043;margin-bottom:20px;font-weight:400;font-size:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#5f6368;font-size:14px;font-weight:500}.form-group input{width:100%;padding:10px;border:1px solid #dadce0;border-radius:4px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#1a73e8}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.form-actions button{padding:10px 24px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}#saveBtn,#saveContactBtn{background:#1a73e8;color:#fff}#saveBtn:hover,#saveContactBtn:hover{background:#1557b0}#deleteBtn{background:#ea4335;color:#fff}#deleteBtn:hover{background:#c5221f}#cancelBtn,#cancelContactBtn{background:#f1f3f4;color:#5f6368}#cancelBtn:hover,#cancelContactBtn:hover{background:#e8eaed}@media (max-width: 768px){header{flex-direction:column;gap:16px}.header-controls{width:100%;justify-content:space-between}.contacts-list{grid-template-columns:1fr}.modal-content{max-width:100%;max-height:100vh;max-height:100dvh;margin:0;border-radius:0}.event-modal-header{padding:12px 16px}.event-title-input{font-size:18px}.event-datetime-section{padding:12px 16px}.datetime-buttons{flex-wrap:wrap;gap:6px}.datetime-btn{padding:6px 10px;font-size:13px}.event-modal-body,.event-left-column,.event-modal-footer{padding:12px 16px}}@media (max-width: 480px){.modal-content{max-width:100%}.event-modal-header{padding:10px 12px}.event-title-input{font-size:16px}.event-datetime-section{padding:10px 12px}.datetime-buttons{gap:4px}.datetime-btn{padding:5px 8px;font-size:12px}.event-modal-body,.event-left-column,.event-modal-footer{padding:10px 12px}}.close{color:#5f6368;font-size:24px;font-weight:400;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.close:hover{background:#f1f3f4}.login-modal{display:flex;align-items:center;justify-content:center}.login-content{max-width:400px;width:90%;padding:40px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.login-header{text-align:center;margin-bottom:32px}.login-header .logo{justify-content:center;margin-bottom:16px}.login-header h2{font-size:24px;color:#3c4043;margin-bottom:8px}.login-header p{color:#5f6368;font-size:14px}.login-content .form-group{margin-bottom:20px}.login-content .form-group label{display:block;margin-bottom:8px;color:#3c4043;font-size:14px;font-weight:500}.login-content .form-group input{width:100%;padding:12px;border:1px solid #dadce0;border-radius:4px;font-size:14px;transition:border-color .2s}.login-content .form-group input:focus{outline:none;border-color:#1a73e8}.error-message{background:#fce8e6;color:#c5221f;padding:12px;border-radius:4px;margin-bottom:16px;font-size:14px}.login-btn{width:100%;padding:12px;background:#1a73e8;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.login-btn:hover:not(:disabled){background:#1557b0}.login-btn:disabled{background:#dadce0;cursor:not-allowed}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Google Sans,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#fff;color:#3c4043;height:100vh;overflow:hidden}#root{height:100vh;width:100vw}
