*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,sans-serif;background-color:#f5f6fa;color:#333}a{text-decoration:none;color:inherit}.btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;font-size:1rem;border-radius:.5rem;border:none;cursor:pointer;font-weight:600;width:100%;transition:all .2s ease}.btn-primary{background-color:#2a3077;color:#fff}.btn-primary:hover{background-color:rgb(37.8,43.2,107.1)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:rgb(97.2,105.3,112.5)}.btn-danger{background-color:#b91c1c;color:#fff}.btn-danger:hover{background-color:rgb(166.5,25.2,25.2)}.btn.btn-social{justify-content:start;background:#fff;border:1px solid #ccc;color:#000;padding-left:1.5rem;gap:.75rem}.btn.btn-social img{width:20px;height:20px;object-fit:contain}.btn.btn-social:hover{background-color:#f8f9fa;border-color:#bbb}.btn-link{background:none;border:none;color:#2a3077;padding:.5rem;font-size:.9rem;cursor:pointer}.btn-attendance{border:none;padding:12px;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:transform .1s active}.btn-attendance:active{transform:scale(0.96)}.btn-attendance.btn-present{color:#28a745;background:rgba(40,167,69,.1)}.btn-attendance.btn-absent{color:#dc3545;background:rgba(220,53,69,.1)}.fab-button{position:fixed;bottom:25px;right:25px;border-radius:50px;padding:12px 20px;z-index:1050;display:flex;align-items:center;gap:8px;border:none;background-color:#0d6efd;color:#fff;max-width:42px;transition:transform .3s cubic-bezier(0.4, 0, 0.2, 1),opacity .2s;transform:scale(1);opacity:1}.fab-button.fab-hidden{transform:scale(0);opacity:0;pointer-events:none}.fab-button:active{transform:scale(0.9)}.c-dropdown{position:relative;width:100%;user-select:none}.c-dropdown__header{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;border-radius:.5rem;border:1px solid rgba(0,0,0,0);cursor:pointer;transition:all .2s ease}.c-dropdown__header i{float:right;transition:transform .3s ease}.c-dropdown__list{position:absolute;top:calc(100% + 5px);left:0;right:0;list-style:none;padding:0;margin:0;z-index:100;border-radius:.5rem;overflow:hidden;display:none}.c-dropdown__list.is-open{display:block;animation:fadeInDown .2s ease-out}.c-dropdown__item{padding:12px 15px;cursor:pointer;transition:background .2s}@keyframes fadeInDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.person-card{background:#fff;border-radius:.5rem;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px rgba(0,0,0,.05);border:1px solid #edf2f7}.person-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.person-card .card-header h5{margin:0;font-size:1.1rem;color:#f8f8f8}.person-card .attendance-indicator{font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.person-card .card-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:1rem;padding-top:1rem;border-top:1px solid #f1f5f9}.attendance-card{background:#fff;border:1px solid #dee2e6;border-radius:4px;margin-bottom:12px;position:relative;box-shadow:0 2px 4px rgba(0,0,0,.05)}.attendance-card .card-content{display:flex;padding:15px;gap:15px}.attendance-card .participant-avatar{width:75px;height:75px;background-color:#f1f3f5;display:flex;align-items:center;justify-content:center;border-radius:4px}.attendance-card .participant-avatar i{color:#adb5bd;font-size:2.5rem}.attendance-card .participant-info{flex:1}.attendance-card .participant-info h3{font-size:1.1rem;margin:0 0 5px 0;font-weight:600;color:#333}.attendance-card .participant-info .status-box{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#666}.attendance-card .participant-info .status-box .status-indicator{display:flex;align-items:center}.attendance-card .participant-info .status-box .status-indicator .bi-check-lg{position:absolute;color:#2d6a4f;font-size:60px;padding-top:15px}.attendance-card .participant-info .status-box .status-indicator .text-danger{position:absolute;color:#d62828;font-size:45px;padding-top:15px}.attendance-card .card-footer{border-top:1px solid #f1f1f1;padding:10px 15px;display:flex;justify-content:space-between;align-items:center}.attendance-card .card-footer .action-links{display:flex;gap:15px}.attendance-card .card-footer .action-links .link-btn{color:#d9534f;font-size:.85rem;text-decoration:none;cursor:pointer;font-weight:500}.attendance-card .card-footer .action-links .link-btn:hover{text-decoration:underline}.attendance-card .card-footer .action-links .link-btn.text-muted{color:#6c757d}.attendance-card .card-footer .btn-notes{background:none;border:none;padding:0;font-size:.85rem;cursor:pointer;color:#d9534f;font-weight:500}.attendance-card .card-footer .btn-notes:hover{text-decoration:underline}.attendance-card .notes-area{padding:10px 15px;border-top:1px solid #f1f1f1}.attendance-card .notes-area.d-none{display:none !important}.attendance-card .notes-area .note-item{padding:5px 0;border-bottom:1px solid #f5f5f5}.attendance-card .notes-area .note-item:last-child{border-bottom:none}.attendance-card .notes-area .note-item .note-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.attendance-card .notes-area .note-item .note-meta .note-meta-text{font-size:.75rem;color:#999}.attendance-card .notes-area .note-item .note-meta .btn-delete-note{background:none;border:none;padding:0;cursor:pointer;color:#ccc;font-size:.75rem;line-height:1}.attendance-card .notes-area .note-item .note-meta .btn-delete-note:hover{color:#d62828}.attendance-card .notes-area .note-item .note-text{font-size:.85rem;color:#333;white-space:pre-wrap}.attendance-card .notes-area .notes-empty,.attendance-card .notes-area .notes-loading,.attendance-card .notes-area .notes-error{font-size:.85rem;color:#999;margin:0;text-align:center;padding:4px 0}.attendance-card .notes-area .notes-list{margin-top:8px}.attendance-card .notes-area .note-form .note-textarea{width:100%;border:1px solid #dee2e6;border-radius:4px;padding:6px 8px;font-size:.85rem;resize:none;margin-bottom:6px;font-family:inherit}.attendance-card .notes-area .note-form .note-textarea:focus{outline:none;border-color:#2a3077}.attendance-card .notes-area .note-form .note-form-actions{display:flex;gap:12px}.attendance-card .notes-area .note-form .note-form-actions button{background:none;border:none;padding:0;font-size:.85rem;cursor:pointer;font-weight:500}.attendance-card .notes-area .note-form .note-form-actions button:hover{text-decoration:underline}.attendance-card .notes-area .note-form .note-form-actions button.btn-save-note{color:#d9534f}.attendance-card .notes-area .note-form .note-form-actions button.btn-cancel-note{color:#6c757d}.attendance-card .card-loader{position:absolute;top:0;left:0;right:0;bottom:0;background:hsla(0,0%,100%,.8);display:flex;align-items:center;justify-content:center;z-index:99;border-radius:4px}.attendance-card .card-loader.d-none{display:none !important}.attendance-card .card-loader .spinner{width:30px;height:30px;border:4px solid #f3f3f3;border-top:4px solid #036;border-radius:50%;animation:spin 1s linear infinite;display:block}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.attendance-card.error-save{border:1px solid #d9534f;animation:shake .3s ease-in-out}.participant-avatar img{width:100%;height:100%;object-fit:cover;border-radius:4px}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.offline .attendance-card .note-form{display:none}.offline .attendance-card .link-btn,.offline .attendance-card .btn-delete-note{opacity:.35;pointer-events:none;cursor:default}.child-card{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;border-bottom:1px solid #dee2e6;cursor:pointer}.child-card .child-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f1f3f5;flex-shrink:0}.child-card .child-avatar img{width:100%;height:100%;object-fit:cover}.child-card .child-avatar i{font-size:2rem;color:#adb5bd}.child-card .child-info{display:flex;flex-direction:column}.child-card .child-info .child-name{font-weight:600;color:#333}.child-card .child-info .child-years{font-size:.8rem;color:#666}.form-group{display:flex;flex-direction:column;margin-bottom:1rem}.form-group label{margin-bottom:.3rem;font-weight:500;color:#f8f8f8}.form-group input{padding:1rem 1.5rem;border-radius:.5rem;border:1px solid #ccc;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#2a3077;box-shadow:0 0 0 3px rgba(42,48,119,.2)}.error{color:#b91c1c;background:#fee2e2;padding:.75rem;border-radius:.5rem;margin-bottom:1rem;font-size:.9rem;border:1px solid #fee2e2}.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:confirmFadeIn .15s ease}.confirm-overlay .confirm-dialog{background:#fff;border-radius:12px;padding:28px 24px 20px;max-width:320px;width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.25);animation:confirmSlideUp .2s ease}.confirm-overlay .confirm-dialog .confirm-icon{font-size:2.5rem;color:#b91c1c;margin-bottom:12px;line-height:1}.confirm-overlay .confirm-dialog .confirm-title{font-size:1.1rem;font-weight:700;color:#1a1a1a;margin:0 0 8px}.confirm-overlay .confirm-dialog .confirm-message{font-size:.88rem;color:#6c757d;margin:0 0 22px}.confirm-overlay .confirm-dialog .confirm-message .confirm-note-preview{display:block;margin-top:10px;padding:8px 10px;background:#f8f9fa;border-left:3px solid #dee2e6;border-radius:4px;font-size:.82rem;color:#555;text-align:left;font-style:italic;word-break:break-word}.confirm-overlay .confirm-dialog .confirm-actions{display:flex;gap:10px}.confirm-overlay .confirm-dialog .confirm-actions button{flex:1;padding:10px 16px;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s}.confirm-overlay .confirm-dialog .confirm-actions button:hover{opacity:.85}.confirm-overlay .confirm-dialog .confirm-actions .confirm-btn-cancel{background:#f1f3f5;color:#6c757d}.confirm-overlay .confirm-dialog .confirm-actions .confirm-btn-ok{background:#b91c1c;color:#fff}@keyframes confirmFadeIn{from{opacity:0}to{opacity:1}}@keyframes confirmSlideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}#childReportModal{position:fixed;top:0;left:0;width:100%;height:100vh;background:#f4f7f9;z-index:9999;display:none;flex-direction:column}#childReportModal.is-visible{display:flex}#childReportModal .modal-header{flex-shrink:0;height:60px;background:#036;color:#fff;display:flex;align-items:center;padding:0 15px}#childReportModal .modal-header a{color:#fff}#childReportModal .modal-header .modal-title{font-size:1rem;margin:0}#childReportModal .modal-body{flex-grow:1;overflow-y:auto;padding:15px;-webkit-overflow-scrolling:touch;max-height:calc(100vh - 60px)}#attendanceModal{position:fixed;top:0;left:0;width:100%;height:100vh;background:#f4f7f9;z-index:9999;display:none;flex-direction:column}#attendanceModal.is-visible{display:flex}#attendanceModal .modal-header{flex-shrink:0;height:60px;background:#036;color:#fff;display:flex;align-items:center;padding:0 15px}#attendanceModal .modal-body{flex-grow:1;overflow-y:auto;padding:15px;-webkit-overflow-scrolling:touch;max-height:calc(100vh - 60px)}.divider{text-align:center;margin:1rem 0;position:relative;font-size:1.1rem;color:#666}.divider::before,.divider::after{content:"";position:absolute;top:50%;width:35%;height:1px;background:#ccc}.divider::before{left:0}.divider::after{right:0}.text-center{text-align:center}.truncate-text{display:inline-block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header{position:fixed;top:0;left:0;right:0;height:60px;background-color:#2a3077;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:1000;box-shadow:0 2px 4px rgba(0,0,0,.1)}.app-header__logo{font-weight:700;font-size:1.2rem;text-decoration:none;color:#fff}@media(min-width: 768px){.app-header .app-sidebar__toggle{display:none}}.app-header .app-nav{list-style:none;display:flex;align-items:center;gap:.25rem}.app-header .app-nav__item{display:flex;align-items:center;justify-content:center;padding:.4rem;color:#fff;border-radius:.5rem}.app-header .app-nav__item:hover{background:hsla(0,0%,100%,.15)}.app-header #adminNavBtn{margin-left:.5rem;padding-left:.75rem;border-left:1px solid hsla(0,0%,100%,.25)}.app-header .header-toggle-hidden{display:none}.offline .app-header #adminNavBtn{opacity:.35;pointer-events:none;cursor:default}.app-sidebar{position:fixed;top:60px;left:0;width:280px;height:calc(100vh - 60px);background-color:#f8f8f8;z-index:1000;transition:transform .3s ease-in-out;display:flex;flex-direction:column;transform:translateX(-100%)}@media(min-width: 768px){.app-sidebar{transform:translateX(0)}}.app-sidebar.is-active{transform:translateX(0)}.app-sidebar .app-sidebar__header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:1rem 1rem 1.5rem 1rem;gap:.5rem;margin-bottom:0;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;background-color:#2a3077;background:linear-gradient(135deg, rgb(29.4, 33.6, 83.3), #2a3077, rgb(29.4, 33.6, 83.3))}.app-sidebar .app-sidebar__header .app-sidebar__header__avatar{width:65px;height:65px;object-fit:contain;border-radius:50%;border:2px solid #fff;margin:.5rem auto}.app-sidebar .app-sidebar__header .app-sidebar__header__info-wrapper{width:100%}.app-sidebar .app-sidebar__header .app-sidebar__header__info-wrapper .c-dropdown__header{border-color:hsla(0,0%,100%,.2);color:#fff}.app-sidebar .app-sidebar__header .app-sidebar__header__info-wrapper .c-dropdown__header:active{background:hsla(0,0%,100%,.15)}.app-sidebar .app-sidebar__header .app-sidebar__header__info-wrapper .c-dropdown__list{background:#2a3077;box-shadow:0 10px 20px rgba(0,0,0,.4);border:1px solid hsla(0,0%,100%,.1)}.app-sidebar .app-sidebar__header .app-sidebar__header__info-wrapper .c-dropdown__item{color:hsla(0,0%,100%,.8);border-bottom:1px solid hsla(0,0%,100%,.05)}.app-sidebar .app-sidebar__header .app-sidebar__header__info-wrapper .c-dropdown__item:hover{background:hsla(0,0%,100%,.1);color:#fff}.app-sidebar .app-sidebar__header .app-sidebar__header__info-wrapper .app-sidebar__info__user{margin:5px;color:#f8f8f8;padding:.5rem 0rem .5rem .7rem;font-size:.8rem}.app-sidebar nav{flex:1 1 auto;overflow-y:auto;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}.app-sidebar nav::-webkit-scrollbar{width:4px}.app-sidebar nav::-webkit-scrollbar-thumb{background:rgba(0,0,0,.1);border-radius:10px}.app-sidebar .app-menu{list-style:none;padding:10px 0;margin:0;display:flex;flex-direction:column;min-height:100%}.app-sidebar .app-menu .menu-footer-wrapper{margin-top:auto;width:100%}.app-sidebar .app-menu__item{display:flex;align-items:center;padding:14px 20px;color:#555;text-decoration:none;transition:all .2s ease;border-left:4px solid rgba(0,0,0,0);cursor:pointer}.app-sidebar .app-menu__item i{font-size:1.2rem;margin-right:15px;min-width:25px;color:#777}.app-sidebar .app-menu__item.active{color:#2a3077;background-color:rgb(234.3634782609,235.4039751553,247.7165217391);border-left-color:#2a3077}.app-sidebar .app-menu__item.active i{color:#2a3077}.app-sidebar .app-menu__item:hover:not(.active){background-color:#eee;color:#333}.app-sidebar .app-menu__item.logout{margin-top:auto;border-top:1px solid #e0e0e0;background-color:#fff;color:#d63031;position:sticky;bottom:0}.app-sidebar .app-menu__item.logout i{color:#d63031}.app-sidebar .app-menu__item.logout:hover{background-color:#fff0f0}.app-sidebar .app-menu li{flex:0 0 auto}.app-sidebar__overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.5);z-index:900;display:none}.app-sidebar__overlay.is-active{display:block}.menu-separator{height:1px;background:#e0e0e0;margin:10px 20px;list-style:none}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#f5f6fa;padding:1rem}.login-box{background:#fff;padding:1rem;border-radius:.5rem;width:100%;max-width:400px;box-shadow:0 4px 10px rgba(0,0,0,.1);overflow:hidden;min-height:520px;transition:min-height .3s ease}.login-box.login-box-error{min-height:580px}.login-box .header{text-align:center;margin-bottom:1rem}.login-box .header .login-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:1.5rem 0}.login-box .header .login-logo img{width:50px;height:50px;object-fit:contain}.login-box .header .login-logo h1{font-size:1.8rem;color:#333;margin:0}.login-box .login-form{position:relative;transition:all .25s ease}.login-box .login-form .step-1,.login-box .login-form .step-2{transition:opacity .25s ease,transform .25s ease,height .25s ease}.login-box .login-form.step-initial .step-1{opacity:1;transform:translateY(0);pointer-events:auto;height:auto}.login-box .login-form.step-initial .step-2{opacity:0;transform:translateY(20px);pointer-events:none;height:0;display:none}.login-box .login-form.step-password .step-1{opacity:0;transform:translateY(-20px);pointer-events:none;height:0;display:none}.login-box .login-form.step-password .step-2{opacity:1;transform:translateY(0);pointer-events:auto;height:auto}.app{display:flex;flex-direction:column;min-height:100vh;background-color:#f5f6fa}.app-content{flex:1;margin-top:60px;transition:margin-left .3s ease;width:100%}@media(min-width: 768px){.app-content{margin-left:280px;width:calc(100% - 280px)}}.attendance-layout .topics-column{flex:1;overflow-y:auto;background:#fff;-webkit-overflow-scrolling:touch}@media(min-width: 768px){.attendance-layout .topics-column{max-width:410px;border-right:1px solid rgb(253.6,253.6,253.6)}}.attendance-layout .topics-column{background:#fff;border-right:1px solid #eee;height:100%;overflow-y:auto}.attendance-layout .topic-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;width:100%;background:#fff;border:none;border-bottom:1px solid #eee;text-align:left;cursor:pointer}.attendance-layout .topic-item__left{display:flex;align-items:center;gap:15px}.attendance-layout .topic-item--disabled-dark{opacity:.5;background-color:#d1d1d1;cursor:initial}.attendance-layout .topic-item--disabled-dark .topic-stats{visibility:hidden}.attendance-layout .topic-item--disabled-dark .topic-stats .stat-absent-visible{visibility:hidden}.attendance-layout .topic-item--disabled-light{opacity:.5;cursor:initial}.attendance-layout .topic-item--disabled-light .bi-chevron-right{visibility:hidden}.attendance-layout .topic-item .topic-name{font-size:.9rem;font-weight:600;letter-spacing:-0.02em;line-height:1.2;color:#333;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:225px}.attendance-layout .topic-item .topic-date{font-size:.75rem;letter-spacing:-0.01em;color:#888;font-weight:400}.attendance-layout .topic-item .topic-pending-wrapper{text-align:right}.attendance-layout .topic-item .topic-pending-wrapper .topic-pending{display:inline-block;background-color:#d62828;color:#fff;border-radius:50%;font-size:13px;text-align:center;width:23px;line-height:23px}.attendance-layout .topic-item .topic-pending-wrapper .topic-pending-visible{visibility:visible}.attendance-layout .topic-item .topic-pending-wrapper .topic-pending-hidden{visibility:hidden}.attendance-layout .topic-item .topic-stats{font-size:.75rem;letter-spacing:-0.01em;margin-top:1px}.attendance-layout .topic-content{flex:1;display:flex;flex-direction:column;min-width:0}.attendance-layout .liturgical-indicator{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem}.attendance-layout .liturgical-indicator.color-ordinary{background-color:#2d6a4f}.attendance-layout .liturgical-indicator.color-preparation{background-color:#8d31d8}.attendance-layout .liturgical-indicator.color-celebration{background-color:#f2ff39}.attendance-layout .liturgical-indicator.color-pentecost{background-color:#fd2a2a}.attendance-layout .liturgical-indicator.color-bi-ordinary{color:#2d6a4f}.attendance-layout .liturgical-indicator.color-bi-preparation{color:#8d31d8}.attendance-layout .liturgical-indicator.color-bi-celebration{color:#f2ff39}.attendance-layout .liturgical-indicator.color-bi-pentecost{color:#fd2a2a}.attendance-layout .liturgical-indicator i{font-size:40px}.attendance-layout .topic-stats{display:flex;gap:10px;font-size:.75rem;margin-top:4px}.attendance-layout .topic-stats .stat-present{color:#2d6a4f;font-weight:bold}.attendance-layout .topic-stats .stat-absent{color:#d62828;font-weight:bold}.attendance-layout .topic-stats .stat-absent-visible{visibility:visible}.attendance-layout .topic-stats .stat-absent-hidden{visibility:hidden}#desktopTitle{margin-bottom:1rem}.topics-column #childrenList{display:none}.topics-column.show-children #topicsList{display:none}.topics-column.show-children #childrenList{display:flex;flex-direction:column}.attendance-layout{width:100%}.attendance-layout .topics-column{flex:1 1 100%;width:100%}.attendance-layout .details-column{display:none}.attendance-layout .topics-column{flex:0 0 400px;border-right:1px solid #dee2e6;overflow-y:auto;background:#fff}@media(min-width: 768px){.attendance-layout{display:flex;flex-direction:row;overflow:hidden;height:calc(100vh - 60px);width:calc(100vw - 280px - 15px)}.attendance-layout .topics-column{flex:0 0 400px;border-right:1px solid #dee2e6;overflow-y:auto}.attendance-layout .details-column{display:flex;flex-direction:column;flex:2;overflow:hidden;background:#f5f6fa;padding:1rem}}.attendance-layout .details-column .details-header{border-bottom:1px solid #eee;position:sticky;top:0;z-index:10}.attendance-layout .details-column .people-grid{flex:1;overflow-y:auto;padding:20px;display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:15px;align-content:start;align-items:start}.attendance-layout .details-column #childReport{display:none}.attendance-layout .details-column.show-report .details-header,.attendance-layout .details-column.show-report #peopleGrid{display:none}.attendance-layout .details-column.show-report #childReport{display:flex;flex-direction:column;flex:1;overflow-x:hidden;overflow-y:auto}.child-report-panel{overflow-y:auto;height:100%;padding:1rem 1.5rem}.report-hero{display:flex;align-items:center;gap:1rem;padding-bottom:.75rem}.report-hero .report-avatar{width:72px;height:72px;border-radius:50%;overflow:hidden;background:#f1f3f5;display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-hero .report-avatar img{width:100%;height:100%;object-fit:cover}.report-hero .report-avatar i{font-size:3rem;color:#adb5bd}.report-hero .report-name{font-size:1.2rem;font-weight:700;margin:0;color:#333}.repor-cycles{margin-bottom:1rem}.repor-cycles .report-cycle-group{display:block;font-size:.8rem;font-weight:400;color:#666}.report-table{width:100%;border-collapse:collapse;font-size:.85rem}.report-table thead tr{background:#eef2f7;border-bottom:2px solid #dee2e6}.report-table th,.report-table td{padding:.4rem .5rem;vertical-align:middle}.report-table tbody tr:nth-child(even){background:#f8f9fa}.report-col-topic{text-align:left;color:#444;width:99%}.report-col-cycle{text-align:center;white-space:nowrap;min-width:80px;color:#036;font-weight:600}.report-col-cycle .report-cycle-label{display:block;font-size:.8rem}.report-col-symbol{text-align:center;white-space:nowrap}.ra-check{color:#2d6a4f;font-size:1rem}.ra-absent,.ra-pending{color:#d62828;font-weight:700;font-size:.9rem}.ra-dash{color:#adb5bd}.admin-page{padding:calc(60px + 1.25rem) 1rem 2rem}.admin-header{display:flex;align-items:center;gap:1rem;max-width:1040px;margin:0 auto 1.25rem}.admin-back-link{color:#2a3077;font-size:.88rem;white-space:nowrap}.admin-back-link i{margin-right:.2rem}.admin-title{font-size:1.2rem;font-weight:600;color:#036;margin:0}.admin-layout{display:grid;grid-template-columns:260px 1fr;gap:1.25rem;max-width:1040px;margin:0 auto;align-items:start}@media(max-width: 767px){.admin-layout{grid-template-columns:1fr}}.admin-sidebar{background:#fff;border-radius:.5rem;box-shadow:0 1px 4px rgba(0,0,0,.08);overflow:hidden}.admin-sidebar-title{background:#2a3077;color:#fff;padding:.6rem 1rem;font-size:.82rem;font-weight:600;letter-spacing:.03em;display:flex;align-items:center;gap:.4rem}.church-list{list-style:none;margin:0;padding:.25rem 0}.church-item{display:flex;flex-direction:column;gap:.15rem;padding:.7rem 1rem;cursor:pointer;border-bottom:1px solid #f0f0f0;border-left:3px solid rgba(0,0,0,0);transition:background .15s}.church-item:last-child{border-bottom:none}.church-item:hover{background:#f8f9ff}.church-item.is-active{background:#eff6ff;border-left-color:#2a3077}.church-name{font-size:.88rem;font-weight:500;color:#333}.church-role{font-size:.7rem;color:#6c757d}.admin-main{background:#fff;border-radius:.5rem;box-shadow:0 1px 4px rgba(0,0,0,.08);padding:1.25rem;min-height:200px}.admin-nav-row{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding-bottom:.85rem;border-bottom:1px solid #f0f0f0;flex-wrap:wrap}.admin-back-btn{display:inline-flex;align-items:center;gap:.25rem;background:rgba(0,0,0,0);border:none;color:#2a3077;font-size:.85rem;cursor:pointer;padding:.2rem 0;white-space:nowrap}.admin-back-btn:hover{text-decoration:underline}.admin-breadcrumb{font-size:.85rem;color:#6c757d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-breadcrumb.is-current{color:#333;font-weight:500}.admin-sep{font-size:.7rem;color:#ccc}.admin-section{margin-bottom:1.5rem}.admin-section:last-child{margin-bottom:0}.admin-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6c757d;margin-bottom:.75rem}.admin-actions-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(110px, 1fr));gap:.75rem}.admin-action-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.9rem .5rem;background:#f8f9ff;border:1px solid #e0e7ff;border-radius:.5rem;cursor:pointer;transition:background .15s;text-align:center}.admin-action-card i{font-size:1.35rem;color:#2a3077}.admin-action-card span{font-size:.8rem;font-weight:500;color:#333}.admin-action-card small{font-size:.68rem;color:#6c757d}.admin-action-card:hover:not(:disabled){background:#eff6ff}.admin-action-card:disabled{opacity:.45;cursor:default}.admin-action-card:disabled i{color:#6c757d}.admin-list{list-style:none;margin:0;padding:0;border:1px solid #f0f0f0;border-radius:.5rem;overflow:hidden}.admin-list-item{border-bottom:1px solid #f0f0f0}.admin-list-item:last-child{border-bottom:none}.level-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;transition:background .15s}.level-item span{font-size:.9rem;color:#333}.level-item:hover{background:#f8f9ff}.level-item .bi-chevron-right{font-size:.82rem;color:#6c757d}.group-item{padding:.8rem 1rem}.group-info{display:flex;align-items:center;gap:.65rem;margin-bottom:.55rem}.group-title{font-size:.9rem;font-weight:500;color:#333}.group-status{font-size:.68rem;font-weight:600;padding:.15rem .45rem;border-radius:999px}.group-status.status-opened{background:#d1fae5;color:#065f46}.group-status.status-ready_to_close{background:#fef3c7;color:#92400e}.group-status.status-closed{background:#f3f4f6;color:#6b7280}.group-status.status-created,.group-status.status-configured{background:#eff6ff;color:#2a3077}.group-actions{display:flex;gap:.5rem;flex-wrap:wrap}.admin-action-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;padding:.28rem .65rem;border-radius:.5rem;border:1px solid currentColor;background:rgba(0,0,0,0);cursor:pointer;color:#2a3077;transition:background .15s}.admin-action-btn.btn-schedule:hover{background:#eff6ff}.admin-action-btn:disabled{opacity:.38;cursor:default;color:#6c757d}.schedule-list{border:1px solid #f0f0f0;border-radius:.5rem;overflow:hidden}.schedule-row{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-bottom:1px solid #f0f0f0;flex-wrap:wrap}.schedule-row:last-child{border-bottom:none}.topic-date{font-size:.8rem;color:#6c757d;white-space:nowrap;min-width:85px}.topic-title{flex:1;font-size:.88rem;color:#333;min-width:0}.topic-badge{font-size:.7rem;font-weight:600;padding:.18rem .5rem;border-radius:999px;white-space:nowrap}.topic-badge.badge-active{background:#d1fae5;color:#065f46}.topic-badge.badge-canceled{background:#fee2e2;color:#b91c1c}.btn-topic-action{display:inline-flex;align-items:center;gap:.25rem;font-size:.78rem;padding:.25rem .65rem;border-radius:.5rem;border:1px solid currentColor;background:rgba(0,0,0,0);cursor:pointer;white-space:nowrap}.btn-topic-action.btn-cancel{color:#b91c1c}.btn-topic-action.btn-cancel:hover{background:#fee2e2}.btn-topic-action.btn-restore{color:#2a3077}.btn-topic-action.btn-restore:hover{background:#eff6ff}.btn-topic-action:disabled{opacity:.4;cursor:default}.admin-loading,.admin-empty,.admin-error,.admin-select-prompt{text-align:center;color:#6c757d;padding:2rem 1rem;font-size:.88rem}.admin-error{color:#b91c1c}@media(max-width: 767px){.admin-sidebar.mob-hidden{display:none}.admin-main{display:none}.admin-main.mob-visible{display:block}.mob-only{display:inline}}@media(min-width: 768px){.mob-only{display:none}}body.offline .btn-topic-action,body.offline .btn-schedule,body.offline .admin-action-btn:not(:disabled){opacity:.35;pointer-events:none}.module-picker-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f0f4f8;padding:2rem}.module-picker-box{background:#fff;border-radius:12px;padding:2.5rem;max-width:420px;width:100%;box-shadow:0 4px 24px rgba(0,0,0,.1);text-align:center}.module-picker-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.75rem}.module-picker-logo img{width:44px;height:44px;border-radius:8px;object-fit:cover}.module-picker-logo h1{font-size:1.35rem;font-weight:700;color:#1f2937;margin:0}.module-picker-subtitle{color:#6b7280;margin-bottom:1.25rem;font-size:.9rem}.module-cards{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.module-card{display:flex;align-items:center;gap:.875rem;padding:.9rem 1.1rem;border:1.5px solid #e5e7eb;border-radius:10px;text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s;text-align:left}.module-card:hover{border-color:#036;box-shadow:0 2px 8px rgba(0,51,102,.1)}.module-card .module-card-icon{font-size:1.6rem;color:#036;flex-shrink:0}.module-card .module-card-name{flex:1;font-weight:600;font-size:.95rem;color:#1f2937}.module-card .module-card-arrow{color:#9ca3af;font-size:.85rem}.module-picker-empty{color:#9ca3af;font-size:.9rem;padding:1rem 0}.module-picker-logout{color:#9ca3af;font-size:.82rem;background:none;border:none;cursor:pointer;text-decoration:underline;padding:0}.module-picker-logout:hover{color:#6b7280}.altar-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f0f4f8;padding:2rem}.coming-soon-box{background:#fff;border-radius:12px;padding:3rem 2.5rem;max-width:380px;width:100%;box-shadow:0 4px 24px rgba(0,0,0,.1);text-align:center}.coming-soon-box .coming-soon-icon{font-size:3.5rem;color:#d1d5db;display:block;margin-bottom:1.25rem}.coming-soon-box h1{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.coming-soon-box p{color:#6b7280;margin-bottom:1.5rem}.coming-soon-box a{color:#036;text-decoration:none;font-size:.9rem}.coming-soon-box a:hover{text-decoration:underline}/*# sourceMappingURL=app.css.map */
