:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;background:#f8fafc}#root{min-height:100vh}button{font-family:inherit;font-size:inherit;font-weight:inherit;cursor:pointer}button:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}input{font-family:inherit;font-size:inherit}input:focus{outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}.calendar-grid{width:100%;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.month-year{margin:0;font-size:1.25rem;font-weight:600;color:#2d3748}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:#f1f5f9;border-bottom:1px solid #e2e8f0}.weekday-header{padding:.75rem .5rem;text-align:center;font-weight:600;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e2e8f0}.calendar-day{background:#fff;min-height:100px;padding:8px;cursor:default;transition:background-color .2s;display:flex;flex-direction:column;position:relative}.calendar-day:hover{background-color:#f8fafc}.calendar-day.other-month{background-color:#f8fafc;color:#a0aec0}.calendar-day.today{background-color:#ebf8ff;border:2px solid #3182ce}.calendar-day.has-holidays{background-color:#fefefe;cursor:pointer}.calendar-day.has-holidays:hover{background-color:#f8fafc}.calendar-day.other-month{background-color:#f8fafc!important}.day-number{font-weight:600;margin-bottom:4px;font-size:.875rem}.calendar-day.today .day-number{color:#3182ce;font-weight:700}.holiday-indicators{display:flex;flex-direction:column;gap:2px;flex:1}.holiday-indicator{min-height:20px;border-radius:4px;padding:2px 6px;opacity:.9;display:flex;align-items:center;cursor:pointer;transition:opacity .2s}.holiday-indicator:hover{opacity:1}.holiday-indicator.custom{min-height:24px;border-radius:6px;padding:3px 8px}.holiday-name{color:#fff;font-size:.75rem;font-weight:500;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}@media (max-width: 768px){.calendar-day{min-height:80px;padding:4px}.calendar-header{padding:.75rem 1rem}.month-year{font-size:1.125rem}.weekday-header{padding:.5rem .25rem;font-size:.75rem}.day-number{font-size:.75rem}.holiday-indicator{min-height:16px;padding:1px 4px}.holiday-indicator.custom{min-height:18px;padding:2px 6px}.holiday-name{font-size:.625rem}}@media (max-width: 480px){.calendar-day{min-height:70px;padding:2px}.weekday-header{font-size:.625rem}.holiday-indicator{min-height:14px;padding:1px 3px}.holiday-indicator.custom{min-height:16px;padding:1px 4px}.holiday-name{font-size:.5rem}}.yearly-view{width:100%;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.yearly-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.year-title{margin:0;font-size:1.5rem;font-weight:600;color:#2d3748}.nav-button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s;color:#4a5568;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.nav-button:hover{background-color:#e2e8f0}.months-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;padding:2rem}.mini-month{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s}.mini-month:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#cbd5e0;cursor:pointer}.mini-month *{cursor:pointer}.mini-month-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.mini-month-name{margin:0;font-size:1rem;font-weight:600;color:#2d3748}.holiday-count{background:#3182ce;color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:12px;font-weight:500}.mini-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.5rem}.mini-weekday{text-align:center;font-size:.75rem;font-weight:600;color:#718096;padding:.25rem 0}.mini-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.mini-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;border-radius:2px;transition:background-color .2s}.mini-day.empty{visibility:hidden}.mini-day-number{font-size:.75rem;color:#4a5568;font-weight:500}.mini-day.today{background-color:#3182ce;color:#fff;border-radius:4px}.mini-day.today .mini-day-number{color:#fff;font-weight:600}.mini-day.has-holidays{background-color:#f7fafc}.mini-day.has-holidays:hover{background-color:#e2e8f0;transform:scale(1.05);cursor:pointer}.mini-holiday-dots{display:flex;gap:1px;margin-top:1px;flex-wrap:wrap;justify-content:center;max-width:100%}.mini-holiday-dot{width:3px;height:3px;border-radius:50%;opacity:.8}.mini-holiday-dot.custom{width:4px;height:4px}@media (max-width: 1024px){.months-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;padding:1.5rem}}@media (max-width: 768px){.yearly-header{padding:1rem 1.5rem}.year-title{font-size:1.25rem}.months-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;padding:1rem}.mini-month{padding:.75rem}.mini-month-name{font-size:.875rem}.holiday-count{font-size:.625rem;padding:.125rem .375rem}}@media (max-width: 480px){.months-grid{grid-template-columns:1fr 1fr;gap:.75rem;padding:.75rem}.mini-month{padding:.5rem}.mini-month-name{font-size:.75rem}.mini-weekday{font-size:.625rem;padding:.125rem 0}.mini-day-number{font-size:.625rem}}.view-toggle{display:flex;background:#f8fafc;border-radius:8px;padding:4px;border:1px solid #e2e8f0}.toggle-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500;color:#64748b}.toggle-button:hover{background-color:#e2e8f0;color:#475569}.toggle-button.active{background-color:#fff;color:#3182ce;box-shadow:0 1px 3px #0000001a}.toggle-icon{font-size:1rem}.toggle-text{font-weight:500}@media (max-width: 768px){.toggle-button{padding:.375rem .75rem;font-size:.75rem}.toggle-icon{font-size:.875rem}}@media (max-width: 480px){.toggle-text{display:none}.toggle-button{padding:.5rem}}.country-selector{position:relative;width:100%}.selector-header{margin-bottom:.5rem}.selector-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.selector-toggle{width:100%;padding:.75rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.selector-toggle:hover{border-color:#9ca3af}.selector-toggle:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.selector-toggle.open{border-color:#3b82f6;border-bottom-left-radius:0;border-bottom-right-radius:0}.selected-count{color:#6b7280}.dropdown-arrow{color:#9ca3af;transition:transform .2s;font-size:.75rem}.selector-toggle.open .dropdown-arrow{transform:rotate(180deg)}.selected-countries{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.selected-country{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.country-code{font-weight:600;opacity:.9}.country-name{opacity:.8}.remove-country{background:none;border:none;color:#fff;cursor:pointer;padding:0;margin-left:.25rem;font-size:1rem;line-height:1;opacity:.8;transition:opacity .2s}.remove-country:hover{opacity:1}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #3b82f6;border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 6px -1px #0000001a;z-index:50;max-height:300px;display:flex;flex-direction:column}.search-container{padding:.75rem;border-bottom:1px solid #e5e7eb}.search-input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;outline:none}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.countries-list{flex:1;overflow-y:auto;max-height:200px}.country-option{display:flex;align-items:center;justify-content:space-between;padding:.75rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f3f4f6}.country-option:hover{background-color:#f9fafb}.country-option.selected{background-color:#eff6ff}.country-option:last-child{border-bottom:none}.country-info{display:flex;align-items:center;gap:.75rem}.country-code-option{font-weight:600;color:#374151;min-width:2rem}.country-name-option{color:#6b7280;font-size:.875rem}.checkmark{color:#3b82f6;font-weight:600}.loading-state,.no-results{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem}@media (max-width: 768px){.selected-countries{gap:.25rem}.selected-country{font-size:.625rem;padding:.125rem .375rem}.country-name{display:none}.dropdown-menu{max-height:250px}.countries-list{max-height:150px}.country-option{padding:.5rem .75rem}.country-name-option{font-size:.75rem}}.share-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:100px;justify-content:center}.share-button:hover:not(.disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.share-button:active:not(.disabled){transform:translateY(0);box-shadow:0 2px 4px #3b82f64d}.share-button.copied{background:#10b981}.share-button.copied:hover{background:#059669}.share-button.disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.share-icon{font-size:1rem}.share-text{font-weight:500}@media (max-width: 768px){.share-button{padding:.375rem .75rem;font-size:.75rem;min-width:80px}.share-icon{font-size:.875rem}}@media (max-width: 480px){.share-text{display:none}.share-button{min-width:40px;padding:.5rem}}.export-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.export-button:hover:not(.disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.export-button.disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.export-icon{font-size:1rem}.export-text{font-weight:600}.export-count{background:#fff3;padding:.125rem .375rem;border-radius:12px;font-size:.75rem;font-weight:600}@media (max-width: 768px){.export-button{padding:.375rem .75rem;font-size:.75rem}.export-text{display:none}.export-icon{font-size:1.125rem}}@media (max-width: 480px){.export-button{padding:.25rem .5rem}}.modal-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:1rem}.modal-content{background:#fff;border-radius:8px;box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem}.modal-title{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f3f4f6;color:#374151}.holiday-form{padding:0 1.5rem 1.5rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.form-input,.form-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input.error,.form-textarea.error{border-color:#ef4444}.form-textarea{resize:vertical;min-height:80px}.color-input-container{display:flex;align-items:center;gap:.75rem}.form-color{width:60px;height:40px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;padding:0}.color-preview{padding:.5rem .75rem;border-radius:4px;font-size:.75rem;font-weight:500;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1);flex:1;text-align:center}.error-text{display:block;color:#ef4444;font-size:.75rem;margin-top:.25rem}.modal-actions{display:flex;align-items:center;justify-content:space-between;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.action-buttons{display:flex;gap:.75rem}.delete-button{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.delete-button:hover{background:#dc2626}.cancel-button{background:#f3f4f6;color:#374151;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background:#e5e7eb}.save-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.save-button:hover{background:#2563eb}@media (max-width: 768px){.modal-overlay{padding:.5rem}.modal-content{max-height:95vh}.modal-header{padding:1rem 1rem 0;margin-bottom:1rem}.modal-title{font-size:1.125rem}.holiday-form{padding:0 1rem 1rem}.form-group{margin-bottom:1rem}.modal-actions{flex-direction:column;gap:1rem;align-items:stretch}.action-buttons{order:1}.delete-button{order:2;align-self:center}}.public-holiday-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.public-holiday-modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #00000026;max-width:400px;width:90%;max-height:90vh;overflow:hidden;animation:slideIn .2s ease-out}.public-holiday-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem 1rem;border-bottom:1px solid #e2e8f0}.public-holiday-modal-title{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.public-holiday-modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#64748b;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.public-holiday-modal-close:hover{background-color:#f1f5f9;color:#374151}.public-holiday-modal-content{padding:1.5rem 2rem 2rem}.holiday-info{display:flex;flex-direction:column;gap:1.25rem}.holiday-name-section,.holiday-country-section,.holiday-local-name-section{display:flex;flex-direction:column;gap:.5rem}.holiday-info label{font-size:.875rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.025em}.holiday-name-display,.holiday-country-display,.holiday-local-name-display{margin:0;padding:.75rem 1rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem;color:#1e293b}.holiday-country-display{font-weight:600;text-transform:uppercase;font-size:.875rem;letter-spacing:.1em}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 480px){.public-holiday-modal{width:95%;margin:1rem}.public-holiday-modal-header{padding:1rem 1.5rem .75rem}.public-holiday-modal-content{padding:1rem 1.5rem 1.5rem}.public-holiday-modal-title{font-size:1.125rem}}.holiday-summary{background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.summary-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#1f2937}.summary-text{margin:0;font-size:.875rem;color:#6b7280;line-height:1.5}.legend-section{margin-bottom:1.5rem}.legend-section:last-child{margin-bottom:0}.legend-subtitle{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:#374151}.legend-items{display:flex;flex-direction:column;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.legend-color.custom{width:14px;height:14px;border-radius:3px}.legend-label{font-size:.75rem;color:#4b5563;font-weight:500}.custom-holidays-list{display:flex;flex-direction:column;gap:.5rem}.custom-holiday-item{display:flex;align-items:center;gap:.5rem}.custom-holiday-info{display:flex;flex-direction:column;gap:.125rem}.custom-holiday-name{font-size:.75rem;font-weight:500;color:#374151}.custom-holiday-date{font-size:.625rem;color:#6b7280}.more-holidays{font-size:.75rem;color:#6b7280;font-style:italic;padding-left:1.25rem}.help-text{font-size:.75rem;color:#6b7280;line-height:1.4;padding:.75rem;background:#f9fafb;border-radius:6px;border-left:3px solid #3b82f6}.help-text strong{color:#374151}@media (max-width: 768px){.holiday-summary{padding:1rem}.summary-title{font-size:.875rem}.legend-subtitle{font-size:.75rem}.legend-items{gap:.375rem}.legend-label,.custom-holiday-name,.custom-holiday-date{font-size:.625rem}}.language-selector{position:relative;z-index:100}.language-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;color:#64748b;transition:all .2s ease;white-space:nowrap}.language-toggle:hover{border-color:#3b82f6;color:#3b82f6;background:#f8fafc}.language-toggle:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.language-icon{font-size:1rem}.language-name{font-weight:500}.dropdown-arrow{font-size:.75rem;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.language-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.language-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 25px #00000026;z-index:101;min-width:200px;max-height:300px;overflow-y:auto;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.language-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f3f4f6}.language-option:hover{background-color:#f8fafc}.language-option:last-child{border-bottom:none}.language-option.selected{background-color:#eff6ff;color:#3b82f6}.language-flag{font-size:1.25rem}.language-display-name{font-size:.875rem;font-weight:500;flex:1}.checkmark{color:#3b82f6;font-weight:600;font-size:.875rem}@media (max-width: 768px){.language-toggle{padding:.375rem .5rem;font-size:.75rem}.language-name{display:none}.language-icon{font-size:1.125rem}.language-dropdown{right:-50%;min-width:180px}}@media (max-width: 480px){.language-toggle{padding:.25rem .5rem}.language-dropdown{right:-100%;min-width:160px}.language-option{padding:.5rem .75rem}.language-display-name{font-size:.75rem}}.contact-page{min-height:100vh;background:#f8fafc;padding:1rem;display:flex;align-items:center;justify-content:center}.contact-container{max-width:1000px;width:100%;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d,0 10px 25px #0000001a;overflow:hidden;max-height:85vh;display:flex;flex-direction:column}.contact-header{background:#f8fafc;color:#1e293b;padding:1.5rem 2rem 1rem;text-align:center;border-bottom:1px solid #e2e8f0;position:relative;flex-shrink:0}.back-button{position:absolute;top:1rem;left:1.5rem;background:#3b82f6;border:1px solid #3b82f6;color:#fff;padding:.4rem .8rem;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem;box-shadow:0 2px 4px #3b82f633}.back-button:hover{background:#2563eb;border-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.contact-title{margin:0 0 .25rem;font-size:1.8rem;font-weight:700;letter-spacing:-.02em;color:#1e293b}.contact-subtitle{margin:0;font-size:.9rem;color:#64748b;font-weight:400}.contact-content{display:grid;grid-template-columns:1fr 2fr;gap:2rem;padding:1.5rem 2rem;flex:1;overflow-y:auto}.contact-info h2{margin:0 0 .5rem;font-size:1.2rem;color:#1e293b;font-weight:600}.contact-info p{margin:0 0 1rem;color:#64748b;line-height:1.5;font-size:.9rem}.contact-methods{display:flex;flex-direction:column;gap:.5rem}.contact-method{display:flex;flex-direction:column;gap:.15rem;padding:.6rem;background:#f8fafc;border-radius:6px;border-left:3px solid #3b82f6}.contact-method strong{color:#1e293b;font-weight:600;font-size:.8rem}.contact-method span{color:#64748b;font-size:.85rem}.contact-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-label{color:#1e293b;font-weight:600;font-size:.8rem}.form-input,.form-select,.form-textarea{padding:.6rem .8rem;border:2px solid #e2e8f0;border-radius:6px;font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff;color:#1e293b}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input.error,.form-select.error,.form-textarea.error{border-color:#ef4444}.form-textarea{resize:vertical;min-height:80px;font-family:inherit}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8}.error-text{color:#ef4444;font-size:.875rem;font-weight:500}.success-message,.error-message{padding:1rem;border-radius:8px;font-weight:500;text-align:center}.success-message{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.error-message{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.submit-button{background:#3b82f6;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #3b82f633}.submit-button:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 8px #3b82f64d}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 2px 4px #3b82f61a}@media (max-width: 768px){.contact-page{padding:.5rem}.contact-container{border-radius:12px;max-height:90vh}.contact-header{padding:1rem 1rem .8rem}.back-button{top:.7rem;left:1rem;padding:.3rem .6rem;font-size:.75rem}.contact-title{font-size:1.5rem}.contact-subtitle{font-size:.8rem}.contact-content{grid-template-columns:1fr;gap:1rem;padding:1rem}.form-row{grid-template-columns:1fr;gap:1rem}.contact-method{padding:.5rem}}@media (max-width: 480px){.contact-page{padding:.25rem}.contact-header{padding:.8rem .8rem .6rem}.back-button{top:.5rem;left:.8rem;padding:.25rem .5rem;font-size:.7rem}.contact-title{font-size:1.3rem}.contact-content{padding:.8rem}}.app{min-height:100vh;display:flex;flex-direction:column;background:#f8fafc;color:#2d3748}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:10}.header-content{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;max-width:1600px;margin:0 auto}.header-left{display:flex;flex-direction:column;gap:.25rem}.app-title-container{display:flex;align-items:center;gap:.75rem;transition:opacity .2s ease,transform .2s ease;border-radius:8px;padding:.25rem}.app-title-container:hover{opacity:.8;transform:translateY(-1px)}.app-title-icon{width:32px;height:32px;flex-shrink:0}.app-title{margin:0;font-size:1.5rem;font-weight:700;color:#1e293b}.app-subtitle{margin:0;font-size:.875rem;color:#64748b;font-weight:400}.header-right{display:flex;align-items:center;gap:1rem}.app-main{flex:1;display:flex;max-width:1600px;margin:0 auto;width:100%;gap:2rem;padding:2rem}.sidebar{width:300px;flex-shrink:0;display:flex;flex-direction:column;gap:1.5rem}.calendar-container{flex:1;position:relative;min-width:0}.app-main .contact-page{min-height:auto;background:#f8fafc;padding:0;display:block;width:100%}.app-main .contact-container{max-width:none;margin:0;border-radius:12px;box-shadow:0 4px 6px #0000000d,0 10px 25px #0000001a}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:5;border-radius:8px}.loading-spinner{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.loading-spinner:before{content:"";width:16px;height:16px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:#fef2f2;border:1px solid #fca5a5;color:#dc2626;padding:.75rem 1rem;border-radius:6px;font-size:.875rem}@media (max-width: 1024px){.app-main{flex-direction:column;gap:1.5rem;padding:1.5rem}.sidebar{width:100%;order:2}.calendar-container{order:1}}@media (max-width: 768px){.header-content{padding:1rem 1.5rem;flex-direction:column;gap:1rem;align-items:flex-start}.header-right{align-self:stretch;justify-content:flex-end}.app-title-icon{width:28px;height:28px}.app-title{font-size:1.25rem}.app-subtitle{font-size:.75rem}.app-main{padding:1rem;gap:1rem}}@media (max-width: 480px){.header-content{padding:.75rem 1rem}.app-title-container{gap:.5rem}.app-title-icon{width:24px;height:24px}.app-title{font-size:1.125rem}.app-main{padding:.75rem}.sidebar{gap:1rem}}.app-footer{background:#fff;border-top:1px solid #e2e8f0;padding:1rem 0;margin-top:auto}.footer-content{max-width:1600px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:#64748b}.footer-content p{margin:0}.footer-contact-link{color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s ease}.footer-contact-link:hover{color:#1e40af}@media (max-width: 768px){.footer-content{flex-direction:column;gap:.5rem;text-align:center;padding:0 1rem}}
