.navigation-arrow{background:linear-gradient(135deg,#ffd93d,#ffc107);border:4px solid #333;border-radius:50%;width:60px;height:60px;font-size:28px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:4px 4px #333,0 4px 10px #0003;display:flex;align-items:center;justify-content:center;color:#333}.navigation-arrow:hover{transform:translateY(-4px) scale(1.1);box-shadow:6px 6px #333,0 8px 15px #0000004d}.navigation-arrow:active{transform:translateY(-2px) scale(1.05);box-shadow:3px 3px #333,0 2px 5px #0003}.navigation-arrow:focus{outline:3px dashed #FFD93D;outline-offset:4px}.calendar-template{min-height:100vh;background:linear-gradient(135deg,#ff9a9e,#fad0c4 50% 100%);padding:40px 20px;display:flex;flex-direction:column;align-items:center;font-family:Fredoka,Bubblegum Sans,cursive;position:relative}.calendar-template__header{display:flex;align-items:center;justify-content:center;margin-bottom:40px;width:100%}.calendar-template__title-box{display:flex;align-items:center;gap:32px;padding:0}.calendar-template__title-box--active{background-color:#ffffffbf;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:20px;padding:20px 40px}.calendar-template__title{font-size:48px;font-weight:700;color:#333;text-shadow:4px 4px 0px rgba(0,0,0,.1);margin:0;text-align:center;font-family:Bubblegum Sans,Fredoka,cursive}.calendar-template__content{flex:1;width:100%;display:flex;justify-content:center;align-items:flex-start}@media(max-width:768px){.calendar-template{padding:24px 12px}.calendar-template__header{gap:16px;margin-bottom:24px}.calendar-template__title{font-size:32px}}@media(max-width:480px){.calendar-template{padding:16px 8px}.calendar-template__title{font-size:24px}}.day-postit{background:linear-gradient(135deg,#ffeb3b,#fff9c4);border:3px solid #333;border-radius:12px;padding:16px;min-height:100px;width:100%;cursor:pointer;transition:all .3s ease;box-shadow:3px 3px #333,0 3px 8px #00000026;transform:rotate(-1deg);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;font-family:Fredoka,Bubblegum Sans,cursive}.day-postit:nth-child(2n){transform:rotate(1deg);background:linear-gradient(135deg,#81c784,#c8e6c9)}.day-postit:nth-child(3n){background:linear-gradient(135deg,#64b5f6,#bbdefb)}.day-postit:nth-child(5n){background:linear-gradient(135deg,#ff8a80,#ffccbc)}.day-postit:hover{transform:rotate(0) translateY(-8px) scale(1.05);box-shadow:5px 5px #333,0 10px 20px #00000040;z-index:10}.day-postit:active{transform:rotate(0) translateY(-4px) scale(1.02);box-shadow:3px 3px #333,0 5px 10px #0003}.day-postit--birthday{background:linear-gradient(135deg,#ff6b9d,#ffc1e3);transform:rotate(-2deg) scale(1.05);border-color:#e91e63;animation:pulse 2s ease-in-out infinite}.day-postit--birthday:hover{transform:rotate(0) translateY(-8px) scale(1.1)}.day-postit--concert{background:linear-gradient(135deg,#66bb6a,#a5d6a7);transform:rotate(-2deg) scale(1.05);border-color:#4caf50;animation:pulse-concert 2s ease-in-out infinite}.day-postit--concert:hover{transform:rotate(0) translateY(-8px) scale(1.1)}.day-postit--wedding{background:linear-gradient(135deg,#42a5f5,#90caf9);transform:rotate(-2deg) scale(1.05);border-color:#2196f3;animation:pulse-wedding 2s ease-in-out infinite}.day-postit--wedding:hover{transform:rotate(0) translateY(-8px) scale(1.1)}.day-postit--restaurant{background:linear-gradient(135deg,#ab47bc,#ce93d8);transform:rotate(-2deg) scale(1.05);border-color:#9c27b0;animation:pulse-restaurant 2s ease-in-out infinite}.day-postit--restaurant:hover{transform:rotate(0) translateY(-8px) scale(1.1)}@keyframes pulse{0%,to{box-shadow:3px 3px #333,0 3px 8px #00000026}50%{box-shadow:4px 4px #333,0 6px 15px #e91e6366}}@keyframes pulse-concert{0%,to{box-shadow:3px 3px #333,0 3px 8px #00000026}50%{box-shadow:4px 4px #333,0 6px 15px #4caf5066}}@keyframes pulse-wedding{0%,to{box-shadow:3px 3px #333,0 3px 8px #00000026}50%{box-shadow:4px 4px #333,0 6px 15px #2196f366}}@keyframes pulse-restaurant{0%,to{box-shadow:3px 3px #333,0 3px 8px #00000026}50%{box-shadow:4px 4px #333,0 6px 15px #9c27b066}}.day-postit__number{font-size:32px;font-weight:700;color:#333;line-height:1}.day-postit__photo-indicator{position:absolute;top:8px;right:8px;font-size:16px;opacity:.7;transition:opacity .2s}.day-postit:hover .day-postit__photo-indicator{opacity:1}.day-postit__icon{font-size:24px;margin-top:8px;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.day-postit__image{margin-top:8px;width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid #333;position:relative}.day-postit__image img{width:100%;height:100%;object-fit:cover}.day-postit__label{position:absolute;top:8px;left:8px;background-color:#fffffff2;color:#333;padding:3px 8px;border-radius:8px;font-size:11px;font-weight:600;white-space:nowrap;border:2px solid #333;box-shadow:2px 2px #333;text-shadow:none;z-index:10;max-width:80px;overflow:hidden;text-overflow:ellipsis}.day-postit:focus{outline:none}.day-postit__faces{position:absolute;bottom:8px;right:8px;display:flex;flex-direction:column;gap:4px;z-index:5}.day-postit__face{width:30px;height:30px;border-radius:50%;border:2px solid white;overflow:hidden;background-color:#fff;box-shadow:0 2px 4px #0003}.day-postit__face img{width:100%;height:100%;object-fit:cover}.calendar-grid{background:linear-gradient(135deg,#f3e5f5,#e1f5fe);border:5px solid #333;border-radius:24px;padding:24px;box-shadow:8px 8px #333,0 8px 20px #0003;max-width:900px;width:100%;margin:0 auto;font-family:Fredoka,Bubblegum Sans,cursive}.calendar-grid__header{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-bottom:20px}.calendar-grid__weekday{text-align:center;font-weight:700;font-size:18px;color:#333;background:linear-gradient(135deg,#ffd54f,#ffeb3b);border:3px solid #333;border-radius:12px;padding:12px;box-shadow:2px 2px #333}.calendar-grid__days{display:grid;grid-template-columns:repeat(7,1fr);gap:16px}.calendar-grid__cell,.calendar-grid__empty-cell{min-height:100px}@media(max-width:768px){.calendar-grid{padding:16px}.calendar-grid__header{gap:8px;margin-bottom:12px}.calendar-grid__weekday{font-size:14px;padding:8px}.calendar-grid__days{gap:12px}.calendar-grid__cell,.calendar-grid__empty-cell{min-height:80px}}@media(max-width:480px){.calendar-grid{padding:12px;border-width:3px}.calendar-grid__days{gap:8px}.calendar-grid__cell,.calendar-grid__empty-cell{min-height:60px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;z-index:1000;animation:fadeIn .2s ease-in}.memory-editor{display:flex;flex-direction:column;flex:1;border:2px solid var(--user-colour, #a8e6cf);border-radius:0 0 8px 8px;overflow:hidden;background:var(--user-colour-pastel, #ffffff);transition:all .3s ease}.memory-editor--empty{opacity:.6;border-color:#ccc}.memory-editor--empty:hover{opacity:.8;border-color:var(--user-colour, #a8e6cf);cursor:pointer}.memory-editor--active{opacity:1;border-color:var(--user-colour, #a8e6cf);background:var(--user-colour-pastel, #ffffff)}.memory-editor__toolbar{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#e8f5e9;border-bottom:2px solid #a8e6cf;flex-wrap:wrap}.memory-editor__btn{width:32px;height:32px;border:2px solid transparent;border-radius:8px;background:#fff;cursor:pointer;font-family:Fredoka,sans-serif;font-size:14px;font-weight:600;color:#2d5a3d;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.memory-editor__btn:hover{background:#c8e6c9;transform:scale(1.05)}.memory-editor__btn--active{background:#6bcf7f;color:#fff;border-color:#4caf50}.memory-editor__btn--delete{background:#ff8a80;color:#fff;font-size:18px;font-weight:700}.memory-editor__btn--delete:hover{background:#ff5252;transform:scale(1.1)}.memory-editor__btn--save{background:#6bcf7f;font-size:16px}.memory-editor__btn--save:hover{background:#4caf50;transform:scale(1.1)}.memory-editor__separator{width:1px;height:24px;background:#a8e6cf;margin:0 4px}.memory-editor__spacer{flex:1}.memory-editor__content{flex:1;overflow-y:auto;padding:16px 20px}.memory-editor__content .tiptap{height:100%;outline:none;font-family:Fredoka,Comic Sans MS,cursive;font-size:20px;font-weight:400;line-height:1.8;color:#2d5a3d}.memory-editor__content .tiptap p{margin:0 0 .5em}.memory-editor__content .tiptap p:last-child{margin-bottom:0}.memory-editor__content .tiptap strong{font-weight:700}.memory-editor__content .tiptap em{font-style:italic}.memory-editor__content .tiptap s{text-decoration:line-through}.memory-editor__content .tiptap mark{border-radius:4px;padding:0 2px}.memory-editor__content .tiptap ul,.memory-editor__content .tiptap ol{margin:.5em 0;padding-left:1.5em}.memory-editor__content .tiptap li{margin:.25em 0}.memory-editor__content .tiptap p.is-editor-empty:first-child:before{color:#9e9e9e;content:attr(data-placeholder);float:left;height:0;pointer-events:none}.memory-editor:focus-within{border-color:#6bcf7f;box-shadow:0 0 0 3px #6bcf7f33}.memory-editor__pencil-trigger{display:flex;align-items:center;justify-content:center;width:120px;height:120px;margin:auto;background:#f5f5f5;border:3px solid var(--user-colour, #999999);border-radius:12px;transition:all .3s ease;cursor:pointer}.memory-editor__pencil-trigger:hover{background:#e0e0e0;border-color:var(--user-colour, #666666);transform:scale(1.08)}.memory-editor__pencil-icon{font-size:72px;opacity:.6;transition:opacity .3s ease}.memory-editor__pencil-trigger:hover .memory-editor__pencil-icon{opacity:.9}.day-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:1400px;height:85%;max-height:900px;background:#fff;border-radius:24px;box-shadow:0 8px 32px #0003;border:3px solid #ff6b9d;z-index:1001;animation:popIn .3s cubic-bezier(.68,-.55,.265,1.55);padding:24px;display:flex;flex-direction:column}.day-modal__close{position:absolute;top:16px;right:16px;background:#ff6b9d;border:none;width:40px;height:40px;border-radius:50%;font-size:24px;color:#fff;cursor:pointer;transition:transform .2s ease;z-index:10}.day-modal__close:hover{transform:scale(1.1);background:#ff4d7d}.day-modal__content{display:flex;gap:24px;height:100%}.day-modal__left{flex:0 0 50%;display:flex;flex-direction:column;gap:12px}.day-modal__picture-box{flex:1;border:3px dashed #ffd93d;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#fff9e6;min-height:400px}.day-modal__picture-box:has(.day-modal__picture-container){border:none;background:transparent}.day-modal__picture-container{position:relative;display:inline-flex;align-items:center;justify-content:center;border:5px solid #ffd93d;border-radius:16px;overflow:hidden;max-width:100%;max-height:100%}.day-modal__picture-container img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.day-modal__delete-picture-btn{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background-color:#dc3545e6;color:#fff;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:0;z-index:10}.day-modal__picture-container:hover .day-modal__delete-picture-btn{opacity:1}.day-modal__delete-picture-btn:hover{background-color:#dc3545;transform:scale(1.1)}.day-modal__delete-picture-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.day-modal__upload-picture-btn{display:block;cursor:pointer;width:100%;height:100%}.day-modal__picture-placeholder{text-align:center;color:orange;transition:all .2s;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.day-modal__upload-picture-btn:hover .day-modal__picture-placeholder{color:#ff8c00;transform:scale(1.05)}.day-modal__picture-placeholder span{font-size:64px;display:block;margin-bottom:8px}.day-modal__picture-placeholder p{font-size:18px;margin:0;font-family:Fredoka,sans-serif;font-weight:500}.day-modal__day-label{font-size:30px;font-weight:700;color:#6bcf7f;text-align:left}.day-modal__special-label{font-size:28px;font-weight:700;color:#6bcf7f;text-align:left;font-family:Fredoka,sans-serif}.day-modal__right{flex:1;display:flex;flex-direction:column;position:relative}.day-modal__editors-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:16px;height:100%}.day-modal__position-container{display:flex;flex-direction:column;height:100%}.day-modal__content-header{padding:8px 12px;border-radius:8px 8px 0 0;color:#fff;font-family:Fredoka,sans-serif;font-size:14px;font-weight:600;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.2)}.day-modal__empty-position{display:flex;align-items:center;justify-content:center;width:120px;height:120px;margin:auto;transition:all .3s ease;cursor:pointer}.day-modal__empty-position:hover{transform:scale(1.08)}.day-modal__empty-icon{font-size:72px;opacity:.6;transition:opacity .3s ease}.day-modal__empty-position:hover .day-modal__empty-icon{opacity:.9}.day-modal__empty-face{width:80px;height:80px;border-radius:50%;border:3px solid #dee2e6;object-fit:cover;box-shadow:0 2px 8px #00000026;transition:all .3s ease}.day-modal__empty-position:hover .day-modal__empty-face{border-color:#6bcf7f;box-shadow:0 4px 12px #6bcf7f4d}.day-modal__empty-text{font-family:Fredoka,sans-serif;font-size:16px;color:#999;margin:0 0 16px;font-weight:500}.day-modal__claim-button{background:#6bcf7f;color:#fff;border:none;border-radius:20px;padding:10px 24px;font-family:Fredoka,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.day-modal__claim-button:hover{background:#4caf50;transform:scale(1.05)}.day-modal__claim-button:active{transform:scale(.98)}.day-modal__claim-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.day-modal__loading{display:flex;align-items:center;justify-content:center;gap:12px;height:100%;font-family:Fredoka,sans-serif;font-size:18px;color:#6bcf7f}.day-modal__memory-text{flex:1;border:2px solid #a8e6cf;border-radius:16px;padding:20px;font-family:Fredoka,Comic Sans MS,cursive;font-size:22px;font-weight:500;line-height:1.8;resize:none;background:#f0fff4;outline:none;color:#2d5a3d}.day-modal__memory-text:focus{border-color:#6bcf7f;box-shadow:0 0 0 3px #6bcf7f1a}.day-modal__memory-text:disabled{opacity:.7}.day-modal__saving{position:absolute;bottom:16px;right:16px;display:flex;align-items:center;gap:8px;background:#6bcf7fe6;color:#fff;padding:8px 16px;border-radius:20px;font-family:Fredoka,sans-serif;font-size:14px;font-weight:500;animation:fadeIn .2s ease-in}.day-modal__spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.day-modal{width:95%;height:90%}.day-modal__content{flex-direction:column}.day-modal__left{flex:0 0 auto}.day-modal__picture-box{min-height:200px}.day-modal__day-label{font-size:24px}.day-modal__right{flex:1;min-height:200px}}.service-request-btn{position:fixed;top:20px;left:20px;width:60px;height:60px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid #333;color:#fff;font-size:28px;cursor:pointer;box-shadow:3px 3px #333,0 3px 8px #0003;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.service-request-btn:hover{transform:translateY(-2px);box-shadow:4px 4px #333,0 5px 12px #0000004d}.service-request-btn:active{transform:translateY(0);box-shadow:2px 2px #333,0 2px 4px #0003}.service-request-form{position:fixed;top:90px;left:20px;width:350px;background:#fff;border:3px solid #667eea;border-radius:16px;padding:20px;box-shadow:0 8px 24px #00000026;z-index:999;display:flex;flex-direction:column;gap:12px;font-family:Fredoka,sans-serif;animation:slideIn .3s ease}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.form-header h3{margin:0;font-size:18px;color:#667eea;font-weight:600}.close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:#999;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-btn:hover{color:#333}.service-request-form input,.service-request-form textarea{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-family:Fredoka,sans-serif;font-size:14px;outline:none;transition:border-color .2s}.service-request-form input:focus,.service-request-form textarea:focus{border-color:#667eea}.service-request-form textarea{min-height:120px;resize:vertical;max-height:300px}.service-request-submit{align-self:flex-end;padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:8px;font-family:Fredoka,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;box-shadow:0 2px 4px #0000001a}.service-request-submit:hover:not(:disabled){background:#5568d3;transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.service-request-submit:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}.service-request-submit:disabled{opacity:.5;cursor:not-allowed}.success-message{padding:16px;background:#d4edda;border:2px solid #28a745;border-radius:8px;color:#155724;text-align:center;font-weight:600;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.text-input{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-family:Fredoka,sans-serif;font-size:15px;color:#495057;background-color:#fff;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.text-input:focus{outline:none;border-color:#ff6b9d;box-shadow:0 0 0 3px #ff6b9d1a}.text-input:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.6}.text-input::placeholder{color:#adb5bd}.special-day-toggle{position:fixed;top:20px;left:100px;width:60px;height:60px;border-radius:12px;background:linear-gradient(135deg,#f093fb,#f5576c);border:3px solid #333;color:#fff;font-size:28px;cursor:pointer;box-shadow:3px 3px #333,0 3px 8px #0003;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.special-day-toggle:hover{transform:translateY(-2px);box-shadow:4px 4px #333,0 5px 12px #0000004d}.special-day-toggle:active{transform:translateY(0);box-shadow:2px 2px #333,0 2px 4px #0003}.special-day-form-container{position:fixed;top:90px;left:100px;width:350px;background:#fff;border:3px solid #f093fb;border-radius:16px;padding:20px;box-shadow:0 8px 24px #00000026;z-index:999;font-family:Fredoka,sans-serif;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.special-day-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.special-day-form h3{margin:0;color:#f5576c;font-size:18px;font-weight:600}.special-day-close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:#999;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.special-day-close-btn:hover{color:#333}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:14px}.form-group select{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-family:Fredoka,sans-serif;font-size:14px;color:#333;background:#fff;cursor:pointer;outline:none;transition:border-color .2s}.form-group select:focus{border-color:#f093fb}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}.special-day-submit{padding:10px 20px;background:#f093fb;color:#fff;border:none;border-radius:8px;font-family:Fredoka,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000001a}.special-day-submit:hover:not(:disabled){background:#e082ea;transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.special-day-submit:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}.special-day-submit:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.special-day-toggle{left:90px;width:50px;height:50px;font-size:24px}.special-day-form-container{left:90px;width:calc(100vw - 110px);max-width:350px}}.calendar-page{min-height:100vh;display:flex;align-items:center;justify-content:center}.calendar-page--loading,.calendar-page--error{background:linear-gradient(135deg,#ff9a9e,#fad0c4 50% 100%);font-family:Fredoka,Bubblegum Sans,cursive}.calendar-page__spinner{font-size:32px;font-weight:700;color:#333;background:linear-gradient(135deg,#ffd93d,#ffc107);border:4px solid #333;border-radius:24px;padding:32px 48px;box-shadow:6px 6px #333,0 6px 15px #0003;animation:bounce 1s ease-in-out infinite}.calendar-page__error{text-align:center;background:linear-gradient(135deg,#ff6b6b,#ffe66d);border:4px solid #333;border-radius:24px;padding:48px;box-shadow:6px 6px #333,0 6px 15px #0003;max-width:500px}.calendar-page__error h2{font-size:36px;margin:0 0 16px;color:#333}.calendar-page__error p{font-size:18px;margin:0;color:#555}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:450px;background:#fff;border-radius:24px;box-shadow:0 8px 32px #0003;border:3px solid #ff6b9d;z-index:1001;animation:popIn .3s cubic-bezier(.68,-.55,.265,1.55);padding:40px}@keyframes popIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.login-modal__title{font-size:32px;font-weight:700;color:#ff6b9d;text-align:center;margin-bottom:32px;font-family:Fredoka,Comic Sans MS,cursive}.login-modal__form{display:flex;flex-direction:column;gap:24px}.login-modal__field{display:flex;flex-direction:column;gap:8px}.login-modal__label{font-size:16px;font-weight:600;color:#2d5a3d;font-family:Fredoka,sans-serif}.login-modal__select,.login-modal__input{padding:12px 16px;font-size:16px;border:2px solid #a8e6cf;border-radius:12px;font-family:Fredoka,sans-serif;background:#f0fff4;color:#2d5a3d;transition:border-color .2s ease}.login-modal__select:focus,.login-modal__input:focus{outline:none;border-color:#6bcf7f;box-shadow:0 0 0 3px #6bcf7f1a}.login-modal__select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236bcf7f' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.login-modal__button{padding:14px 32px;font-size:18px;font-weight:600;font-family:Fredoka,sans-serif;background:#ff6b9d;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;margin-top:8px}.login-modal__button:hover:not(:disabled){background:#ff4d7d;transform:translateY(-2px);box-shadow:0 4px 12px #ff6b9d4d}.login-modal__button:active:not(:disabled){transform:translateY(0)}.login-modal__button:disabled{background:#ccc;cursor:not-allowed}.login-modal__error{background:#ffe6e6;border:2px solid #ff6b6b;border-radius:12px;padding:12px 16px;color:#c00;font-size:14px;font-family:Fredoka,sans-serif;text-align:center}@media(max-width:768px){.login-modal{width:95%;padding:32px 24px}.login-modal__title{font-size:28px}}.admin-dashboard{max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:40px}.dashboard-title{font-size:36px;color:#ff6b9d;margin:0 0 8px;font-weight:600}.dashboard-subtitle{font-size:18px;color:#6c757d;margin:0}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:40px}.dashboard-card{background-color:#fff;border:2px solid #e9ecef;border-radius:12px;padding:30px;text-decoration:none;color:inherit;transition:all .2s ease;cursor:pointer}.dashboard-card:not(.disabled):hover{border-color:#ff6b9d;transform:translateY(-2px);box-shadow:0 4px 12px #ff6b9d26}.dashboard-card.disabled{opacity:.6;cursor:not-allowed}.card-icon{font-size:48px;margin-bottom:16px}.card-title{font-size:22px;color:#495057;margin:0 0 12px;font-weight:600}.card-description{font-size:14px;color:#6c757d;margin:0;line-height:1.5}.dashboard-info{margin-top:40px}.info-card{background-color:#fff;border:2px solid #e9ecef;border-radius:12px;padding:24px}.info-card h3{font-size:20px;color:#495057;margin:0 0 12px;font-weight:600}.info-card p{font-size:14px;color:#6c757d;margin:0;line-height:1.6}@media(max-width:768px){.dashboard-title{font-size:28px}.dashboard-subtitle{font-size:16px}.dashboard-cards{grid-template-columns:1fr}}.special-days-page{max-width:1200px;margin:0 auto}.page-header{margin-bottom:40px}.header-top{display:flex;align-items:center;gap:20px;margin-bottom:8px}.page-header h1{font-size:36px;color:#ff6b9d;margin:0;font-weight:600}.month-selector,.year-selector{padding:10px 16px;border:3px solid #333;border-radius:12px;font-family:Fredoka,sans-serif;font-size:16px;font-weight:600;color:#333;background:linear-gradient(135deg,#ffeb3b,#fff9c4);cursor:pointer;transition:all .3s ease;box-shadow:3px 3px #333;margin-left:15px}.month-selector{min-width:200px}.year-selector{min-width:100px}.month-selector:hover,.year-selector:hover{transform:translateY(-2px);box-shadow:4px 4px #333}.month-selector:focus,.year-selector:focus{outline:none;transform:translateY(-2px);box-shadow:4px 4px #333;background:linear-gradient(135deg,gold,#fff59d)}.page-subtitle{font-size:16px;color:#6c757d;margin:0}.empty-state{text-align:center;padding:80px 20px;background-color:#fff;border-radius:12px;border:2px solid #e9ecef}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h2{font-size:24px;color:#495057;margin:0 0 12px}.empty-state p{font-size:16px;color:#6c757d;margin:8px 0}.special-days-list{background-color:#fff;border-radius:12px;border:2px solid #e9ecef;overflow:hidden}.list-header{display:grid;grid-template-columns:150px 180px 1fr 100px;gap:20px;padding:16px 24px;background-color:#f8f9fa;border-bottom:2px solid #e9ecef;font-weight:600;font-size:14px;color:#495057}.special-day-item{display:grid;grid-template-columns:150px 180px 1fr 100px;gap:20px;padding:20px 24px;border-bottom:1px solid #e9ecef;align-items:center;transition:background-color .2s}.special-day-item:hover{background-color:#f8f9fa}.day-info{display:flex;align-items:baseline;gap:12px}.day-name{font-size:16px;color:#495057;font-weight:500}.day-number{font-size:32px;font-weight:600;color:#ff6b9d;line-height:1}.type-badge{display:inline-block;padding:8px 16px;background-color:#ff6b9d;color:#fff;border-radius:20px;font-size:14px;font-weight:500}.day-actions{display:flex;gap:8px;justify-content:flex-end}.delete-button{padding:8px 12px;background-color:transparent;border:none;border-radius:6px;font-size:18px;cursor:pointer;transition:background-color .2s}.delete-button:hover{background-color:#ffe5ec}.add-special-day-row{background-color:#f0f8ff;border-top:3px solid #ff6b9d;padding:24px;display:grid;grid-template-columns:150px 180px 1fr 100px;gap:20px;align-items:center}.add-day-dropdown,.add-type-dropdown{padding:12px 16px;border:3px solid #333;border-radius:12px;font-family:Fredoka,sans-serif;font-size:15px;font-weight:600;color:#333;background:linear-gradient(135deg,#81c784,#c8e6c9);cursor:pointer;transition:all .3s ease;box-shadow:3px 3px #333}.add-day-dropdown:hover,.add-type-dropdown:hover{transform:translateY(-2px);box-shadow:4px 4px #333}.add-day-dropdown:focus,.add-type-dropdown:focus{outline:none;transform:translateY(-2px);box-shadow:4px 4px #333;background:linear-gradient(135deg,#66bb6a,#a5d6a7)}.add-special-button{padding:12px 24px;background:linear-gradient(135deg,#ff6b9d,#ffc1e3);color:#333;border:3px solid #333;border-radius:12px;font-family:Fredoka,sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s ease;justify-self:end;box-shadow:3px 3px #333}.add-special-button:disabled{background:linear-gradient(135deg,#dee2e6,#f8f9fa);cursor:not-allowed;opacity:.6}.add-special-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:4px 4px #333;background:linear-gradient(135deg,#ff4d85,#ffb3d9)}.add-special-button:active:not(:disabled){transform:translateY(0);box-shadow:2px 2px #333}@media(max-width:768px){.header-top{flex-direction:column;align-items:flex-start;gap:12px}.page-header h1{font-size:28px}.month-selector{width:100%}.list-header{display:none}.special-day-item{grid-template-columns:1fr;gap:12px;padding:16px}.day-info{flex-direction:row-reverse;justify-content:flex-end}.day-number{font-size:28px}.day-actions{justify-content:flex-start}.add-special-day-row{grid-template-columns:1fr;gap:12px;padding:16px}.add-special-button{justify-self:stretch}}.special-type-config-card{border:2px solid #e9ecef;border-radius:12px;padding:20px;background-color:#f8f9fa;transition:all .2s}.special-type-config-card:hover{border-color:#ff6b9d;box-shadow:0 4px 12px #ff6b9d1a}.type-icon{font-size:32px}.type-label{font-size:20px;color:#495057;margin:0;font-weight:600}.user-face-card{border:3px solid;border-radius:16px;padding:24px;background-color:#f8f9fa;transition:all .2s;text-align:center}.user-face-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a}.user-name{font-size:22px;color:#495057;margin:0 0 20px;font-weight:600}.card-body{display:flex;flex-direction:column;gap:15px;align-items:center}.face-preview{width:150px;height:150px;border-radius:50%;overflow:hidden;background-color:#fff;border:3px solid #e9ecef}.face-preview img{width:100%;height:100%;object-fit:cover}.no-face{width:150px;height:150px;border-radius:50%;background-color:#fff;border:3px dashed #dee2e6;display:flex;align-items:center;justify-content:center}.no-face p{color:#adb5bd;font-size:14px;font-style:italic;margin:0}.upload-button,.remove-button{padding:10px 20px;border:none;border-radius:8px;font-family:Fredoka,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;width:100%;max-width:200px}.upload-button{background-color:#ff6b9d;color:#fff}.upload-button:hover:not(:disabled){background-color:#ff4d85;transform:translateY(-1px);box-shadow:0 2px 8px #ff6b9d4d}.remove-button{background-color:#fff;color:#dc3545;border:2px solid #dc3545}.remove-button:hover{background-color:#dc3545;color:#fff}.parameters-page{max-width:1200px;margin:0 auto}.parameters-page h1{font-size:36px;color:#ff6b9d;margin:0 0 40px;font-weight:600}.error button{margin-top:20px;padding:10px 24px;background-color:#ff6b9d;color:#fff;border:none;border-radius:8px;font-family:Fredoka,sans-serif;font-size:16px;cursor:pointer;transition:background-color .2s}.error button:hover{background-color:#ff4d85}.user-faces-section,.special-types-section{background-color:#fff;border-radius:12px;border:2px solid #e9ecef;padding:30px;margin-bottom:30px}.user-faces-section h2,.special-types-section h2{font-size:24px;color:#495057;margin:0 0 12px;font-weight:600}.section-description{font-size:14px;color:#6c757d;margin:0 0 30px;line-height:1.5}.user-faces-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.special-types-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}@media(max-width:768px){.parameters-page h1{font-size:28px}.user-faces-list,.special-types-list{grid-template-columns:1fr}}.month-image-card{border:2px solid #e9ecef;border-radius:12px;padding:20px;background-color:#f8f9fa;transition:all .2s}.month-image-card:hover{border-color:#64b5f6;box-shadow:0 4px 12px #64b5f61a}.card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e9ecef}.month-icon{font-size:32px}.month-label{font-size:20px;color:#495057;margin:0;font-weight:600}.card-body{display:flex;flex-direction:column;gap:15px}.image-preview{position:relative;width:100%;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background-color:#fff;border:2px solid #e9ecef}.image-preview img{width:100%;height:100%;object-fit:cover}.no-image{width:100%;aspect-ratio:16/9;border-radius:8px;background-color:#fff;border:2px dashed #dee2e6;display:flex;align-items:center;justify-content:center}.no-image p{color:#adb5bd;font-size:14px;font-style:italic;margin:0}.upload-button,.remove-image-button{padding:10px 16px;border:none;border-radius:8px;font-family:Fredoka,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.upload-button{background-color:#64b5f6;color:#fff}.upload-button:hover:not(:disabled){background-color:#42a5f5;transform:translateY(-1px);box-shadow:0 2px 8px #64b5f64d}.upload-button:disabled{background-color:#dee2e6;cursor:not-allowed;opacity:.6}.remove-image-button{background-color:#fff;color:#dc3545;border:2px solid #dc3545}.remove-image-button:hover{background-color:#dc3545;color:#fff}.monthly-images-page{max-width:1400px;margin:0 auto}.monthly-images-page h1{font-size:36px;color:#64b5f6;margin:0 0 16px;font-weight:600}.page-description{font-size:14px;color:#6c757d;margin:0 0 40px;line-height:1.5}.loading,.error{text-align:center;padding:60px 20px;color:#6c757d;font-size:18px}.error button{margin-top:20px;padding:10px 24px;background-color:#64b5f6;color:#fff;border:none;border-radius:8px;font-family:Fredoka,sans-serif;font-size:16px;cursor:pointer;transition:background-color .2s}.error button:hover{background-color:#42a5f5}.months-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}@media(max-width:768px){.monthly-images-page h1{font-size:28px}.months-grid{grid-template-columns:1fr}}.service-requests-page{max-width:1400px;margin:0 auto;padding:24px;font-family:Fredoka,sans-serif}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px}.page-header h1{font-size:36px;color:#667eea;margin:0;font-weight:600}.filter-container{display:flex;align-items:center;gap:12px}.filter-label{font-size:16px;font-weight:600;color:#333}.status-filter-dropdown{padding:10px 16px;border:2px solid #667eea;border-radius:8px;font-family:Fredoka,sans-serif;font-size:15px;font-weight:600;cursor:pointer;outline:none;transition:all .2s;background:#fff;color:#667eea;min-width:180px}.status-filter-dropdown:hover{background:#f5f7ff}.status-filter-dropdown:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.loading,.error{text-align:center;padding:60px 20px;font-size:18px}.error{color:#d32f2f}.error button{margin-top:16px;padding:10px 24px;background:#667eea;color:#fff;border:none;border-radius:8px;font-family:Fredoka,sans-serif;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.error button:hover{background:#5568d3}.no-requests{text-align:center;padding:60px 20px;color:#999;font-size:18px;font-style:italic;background:#fff;border-radius:12px;border:2px dashed #e0e0e0}.requests-sections{display:flex;flex-direction:column;gap:32px}.status-section{width:100%}.status-section:not(:last-child){padding-bottom:32px;border-bottom:1px dashed #e0e0e0}.status-section-title{font-size:24px;font-weight:600;margin-bottom:16px;padding-bottom:8px;border-bottom:3px solid #e0e0e0;display:flex;align-items:center;gap:12px}.count-badge{background:#667eea;color:#fff;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:600;margin-left:auto}.section-new .status-section-title{color:#2196f3;border-bottom-color:#2196f3}.section-in-progress .status-section-title{color:#ff9800;border-bottom-color:#ff9800}.section-done .status-section-title{color:#4caf50;border-bottom-color:#4caf50}.requests-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.requests-table{width:100%;border-collapse:collapse;table-layout:fixed}.requests-table thead{background:#667eea;color:#fff}.section-new .requests-table thead{background:#2196f3}.section-in-progress .requests-table thead{background:#ff9800}.section-done .requests-table thead{background:#4caf50}.requests-table th{padding:16px;text-align:left;font-weight:600;font-size:14px;text-transform:uppercase;color:#fff}.requests-table th:nth-child(1),.requests-table td:nth-child(1){width:15%}.requests-table th:nth-child(2),.requests-table td:nth-child(2){width:35%}.requests-table th:nth-child(3),.requests-table td:nth-child(3){width:12%}.requests-table th:nth-child(4),.requests-table td:nth-child(4){width:10%}.requests-table th:nth-child(5),.requests-table td:nth-child(5){width:15%}.requests-table th:nth-child(6),.requests-table td:nth-child(6){width:8%}.requests-table td{padding:16px;border-bottom:1px solid #e0e0e0;vertical-align:top}.requests-table tbody tr:last-child td{border-bottom:none}.requests-table tbody tr:hover{background:#f5f5f5}.title-cell{font-weight:600;color:#333;max-width:200px;word-wrap:break-word}.request-cell{max-width:800px}.request-text{max-height:160px;overflow-y:auto;line-height:1.5;color:#555;word-wrap:break-word;white-space:pre-wrap}.issuer-cell{text-align:left}.issuer-badge{display:inline-block;padding:6px 12px;border-radius:20px;color:#fff;font-size:12px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2);white-space:nowrap}.date-cell{color:#666;font-size:14px;white-space:nowrap}.status-cell{text-align:left}.status-dropdown{padding:6px 12px;border:2px solid #e0e0e0;border-radius:8px;font-family:Fredoka,sans-serif;font-size:13px;font-weight:600;cursor:pointer;outline:none;transition:all .2s;background:#fff}.status-dropdown:hover{border-color:#667eea}.status-dropdown:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.status-new{color:#2196f3}.status-in_progress{color:#ff9800}.status-done{color:#4caf50}.actions-cell{text-align:center}.delete-btn{background:none;border:none;font-size:20px;cursor:pointer;opacity:.6;transition:all .2s;padding:4px 8px}.delete-btn:hover{opacity:1;transform:scale(1.2)}.delete-btn:active{transform:scale(1.1)}@media(max-width:1200px){.requests-table{font-size:14px}.requests-table th,.requests-table td{padding:12px}.title-cell{max-width:150px}.request-cell{max-width:300px}}@media(max-width:768px){.service-requests-page{padding:16px}.service-requests-page h1{font-size:28px;margin-bottom:24px}.requests-table-container{overflow-x:auto}.requests-table{min-width:800px}}.admin-sidebar{width:250px;height:100vh;background-color:#f8f9fa;border-right:2px solid #e9ecef;display:flex;flex-direction:column;font-family:Fredoka,sans-serif}.sidebar-content{flex:1;padding:20px 0;overflow-y:auto}.sidebar-nav{padding:0 10px}.menu-list{list-style:none;padding:0;margin:0}.menu-item{display:flex;align-items:center;padding:12px 16px;margin-bottom:4px;border-radius:8px;text-decoration:none;color:#495057;transition:all .2s ease;cursor:pointer}.menu-item:hover{background-color:#e9ecef;color:#ff6b9d}.menu-item.active{background-color:#ff6b9d;color:#fff;font-weight:600}.menu-icon{font-size:20px;margin-right:12px;display:flex;align-items:center}.menu-label{font-size:16px}.sidebar-footer{border-top:2px solid #e9ecef;padding:16px;background-color:#fff}.user-info{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:8px;background-color:#f8f9fa;border-radius:8px}.user-color-indicator{width:24px;height:24px;border-radius:50%;flex-shrink:0;border:2px solid #fff;box-shadow:0 2px 4px #0000001a}.user-name{font-size:14px;color:#495057;font-weight:500}.logout-button{width:100%;padding:10px;background-color:#fff;border:2px solid #ff6b9d;border-radius:8px;color:#ff6b9d;font-family:Fredoka,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-button:hover{background-color:#ff6b9d;color:#fff}@media(max-width:768px){.admin-sidebar{width:200px}.menu-label{font-size:14px}}.admin-topbar{height:70px;background-color:#fff;border-bottom:2px solid #e9ecef;display:flex;align-items:center;justify-content:space-between;padding:0 30px;font-family:Fredoka,sans-serif;box-shadow:0 2px 4px #0000000d}.topbar-left{display:flex;align-items:center}.topbar-title{margin:0;font-size:24px;color:#ff6b9d;font-weight:600}.topbar-right{display:flex;align-items:center;gap:20px}.calendar-link{display:flex;align-items:center;gap:6px;padding:8px 16px;background-color:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;color:#495057;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease}.calendar-link:hover{background-color:#e9ecef;border-color:#ff6b9d;color:#ff6b9d}.user-badge{display:flex;align-items:center;gap:8px;padding:6px 12px;background-color:#f8f9fa;border-radius:20px}.user-badge-color{width:20px;height:20px;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 4px #0000001a}.user-badge-name{font-size:14px;color:#495057;font-weight:500}.topbar-logout-button{padding:8px 16px;background-color:#fff;border:2px solid #ff6b9d;border-radius:8px;color:#ff6b9d;font-family:Fredoka,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.topbar-logout-button:hover{background-color:#ff6b9d;color:#fff}@media(max-width:768px){.admin-topbar{padding:0 15px}.topbar-title{font-size:18px}.calendar-link{padding:6px 12px;font-size:12px}.user-badge-name{display:none}.topbar-logout-button{padding:6px 12px;font-size:12px}}.admin-layout{display:flex;height:100vh;width:100%;overflow:hidden;font-family:Fredoka,sans-serif}.admin-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.admin-content{flex:1;padding:30px;background-color:#f8f9fa;overflow-y:auto}@media(max-width:768px){.admin-content{padding:15px}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Fredoka,Bubblegum Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{width:100%;min-height:100vh}
