*,:after,:before{box-sizing:border-box}*{margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:#f5f3ef;color:#1e293b;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}canvas,img,picture,svg,video{display:block;max-width:100%}button,input,select,textarea{font:inherit}h1,h2,h3,h4,h5,h6,p{overflow-wrap:break-word}#root{min-height:100vh}::-webkit-scrollbar{height:10px;width:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::selection{background:#c9a227;color:#fff}::-moz-selection{background:#c9a227;color:#fff}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:600;gap:8px;justify-content:center;position:relative;text-align:center;text-decoration:none;transition:all .2s ease}.btn:active{transform:translateY(1px)}.btn-primary{background:#1e3a5f;color:#fff}.btn-primary:hover:not(:disabled){background:#2d5a8a}.btn-secondary{background:#e2e8f0;color:#1e293b}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-gold{background:#c9a227;color:#1e3a5f}.btn-gold:hover:not(:disabled){background:#e6c55a}.btn-outline{background:#0000;border:2px solid #1e3a5f;color:#1e3a5f}.btn-outline:hover:not(:disabled){background:#1e3a5f;color:#fff}.btn-google{background:#fff;border:1px solid #ddd;color:#333}.btn-google:hover:not(:disabled){background:#f8f8f8;box-shadow:0 2px 8px #0000001a}.btn-apple{background:#000;color:#fff}.btn-apple:hover:not(:disabled){background:#333}.btn-small{font-size:.875rem;padding:6px 12px}.btn-medium{font-size:1rem;padding:10px 20px}.btn-large{font-size:1.125rem;padding:14px 28px}.btn-full-width{width:100%}.btn-disabled,.btn:disabled{cursor:not-allowed;opacity:.5}.btn-loading{color:#0000}.btn-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;position:absolute;width:16px}.btn-icon{align-items:center;display:flex}.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.input-label{color:#1e293b;font-size:.875rem;font-weight:600}.input-required{color:#dc2626;margin-left:4px}.input-wrapper{align-items:center;display:flex;position:relative}.input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-family:inherit;font-size:1rem;padding:12px 16px;transition:all .2s ease;width:100%}.input:focus{border-color:#c9a227;box-shadow:0 0 0 3px #c9a2271a;outline:none}.input-with-icon{padding-left:44px}.input-icon{align-items:center;color:#64748b;display:flex;left:14px;pointer-events:none;position:absolute}.input-error,.input-error:focus{border-color:#dc2626}.input-error:focus{box-shadow:0 0 0 3px #dc26261a}.input-error-message{color:#dc2626;font-size:.875rem}.input:disabled{background:#f1f5f9;cursor:not-allowed;opacity:.6}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;transition:all .2s ease}.card-hoverable:hover{box-shadow:0 8px 16px #0000001f;transform:translateY(-2px)}.card-clickable{cursor:pointer}.card-header{border-bottom:1px solid #e2e8f0;margin-bottom:16px;padding-bottom:12px}.card-title{color:#1e3a5f;font-size:1.125rem;font-weight:700;margin-bottom:4px}.card-subtitle{color:#64748b;font-size:.875rem}.card-body{color:#1e293b}.card-padding-small{padding:12px}.card-padding-medium{padding:20px}.card-padding-large{padding:32px}.card-padding-none .card-body{padding:0}.loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:40px 20px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#c9a227;height:50px;width:50px}.loading-message{color:#64748b;font-size:.875rem}.auth-form-container{margin:0 auto;max-width:450px;padding:24px;width:100%}.auth-form-header{margin-bottom:32px;text-align:center}.auth-form-header h2{color:#1e3a5f;font-size:1.75rem;font-weight:700;margin-bottom:8px}.auth-form-header p{color:#64748b;font-size:.9375rem}.auth-form{display:flex;flex-direction:column;gap:8px}.auth-form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.auth-error-banner{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c00;font-size:.875rem;margin-bottom:16px;padding:12px 16px}.auth-form-footer{align-items:center;display:flex;justify-content:space-between;margin:8px 0 24px}.auth-remember{align-items:center;color:#475569;cursor:pointer;display:flex;font-size:.875rem;gap:8px}.auth-remember input[type=checkbox]{accent-color:#c9a227;cursor:pointer;height:16px;width:16px}.auth-link{color:#1e3a5f;font-size:.875rem;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-switch{color:#64748b;font-size:.9375rem;margin-top:24px;text-align:center}.auth-link-bold{color:#1e3a5f;font-weight:600;text-decoration:none}.auth-link-bold:hover{text-decoration:underline}@media (max-width:640px){.auth-form-container{padding:16px}.auth-form-row{gap:8px;grid-template-columns:1fr}.auth-form-header h2{font-size:1.5rem}.auth-form-footer{align-items:flex-start;flex-direction:column;gap:12px}}.social-auth-container{margin-top:24px}.social-auth-divider{margin:24px 0;position:relative;text-align:center}.social-auth-divider:before{background:#e2e8f0;content:"";height:1px;left:0;position:absolute;right:0;top:50%;z-index:0}.social-auth-divider span{background:#fff;color:#64748b;display:inline-block;font-size:.875rem;padding:0 16px;position:relative;z-index:1}.social-auth-buttons{display:flex;flex-direction:column;gap:12px}.google-button-wrapper{display:flex;justify-content:center;width:100%}.google-button-wrapper iframe,.google-button-wrapper>div{width:100%!important}.navigation{background:#fff;border-top:1px solid var(--border);bottom:0;box-shadow:0 -2px 10px #0000000d;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;z-index:100}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 8px}.nav-brand{display:none}.nav-links{display:flex;flex:1 1;justify-content:space-around;padding:6px 0}.nav-link{align-items:center;background:#0000;border:none;color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;font-family:inherit;font-size:inherit;gap:2px;padding:6px 8px;text-decoration:none;transition:all .2s}.nav-link:hover{color:var(--gold)}.nav-link.active{color:var(--primary);font-weight:600}.nav-link-icon{font-size:1.35rem}.nav-link-text{font-size:.65rem}.nav-profile-photo{border:2px solid #0000;border-radius:50%;height:26px;object-fit:cover;width:26px}.nav-link.active .nav-profile-photo{border-color:var(--primary)}@media (min-width:769px){.navigation{bottom:auto;padding-bottom:0;top:0}.nav-container{padding:0 16px}.nav-brand{align-items:center;color:var(--primary);display:flex;font-weight:700;gap:8px}.nav-icon{font-size:1.5rem}.nav-links{flex:0 1;gap:4px}.nav-link{border-radius:8px;flex-direction:row;gap:8px;padding:10px 14px}.nav-link-icon{font-size:1.2rem}.nav-link-text{font-size:.875rem}.nav-link:hover{background:var(--bg-secondary)}.nav-link.active{background:#f0f9ff}.nav-profile-photo{height:28px;width:28px}}.events-container{margin:0 auto;max-width:1200px;padding:24px}.events-header{margin-bottom:32px;text-align:center}.events-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;margin-bottom:8px}.events-header p{color:#64748b}.events-search{margin-bottom:24px}.events-search-input{border:2px solid #e2e8f0;border-radius:24px;font-size:1rem;max-width:500px;padding:12px 20px;transition:all .2s;width:100%}.events-search-input:focus{border-color:#c9a227;box-shadow:0 0 0 3px #c9a2271a;outline:none}.events-filters{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:32px}.event-filter-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:24px;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.event-filter-btn:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.event-filter-btn.active{background:#f8fafc;border-width:2px;font-weight:600}.events-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.event-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;cursor:pointer;overflow:hidden;position:relative;transition:all .3s}.event-card:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-4px)}.event-card-header{background:linear-gradient(135deg,#1e3a5f,#2d5a8a);color:#fff;padding:20px 20px 16px}.event-card-date{text-align:center}.event-card-day{font-size:2rem;font-weight:700;line-height:1}.event-card-month{font-size:.75rem;letter-spacing:1px;opacity:.9}.event-card-category{align-items:center;border-radius:12px;display:flex;font-size:.75rem;font-weight:600;gap:4px;padding:4px 12px}.event-card-body{padding:20px}.event-card-title{color:#1e3a5f;font-size:1.125rem;font-weight:700;margin-bottom:4px}.event-card-title-en{color:#64748b;font-size:.875rem;font-style:italic;margin-bottom:16px}.event-card-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.event-card-meta-item{align-items:center;color:#475569;display:flex;font-size:.875rem;gap:8px}.meta-icon{font-size:1rem}.event-card-description{color:#64748b;font-size:.875rem;line-height:1.6}.event-card-badge{background:#fbbf24;border-radius:12px;color:#78350f;font-size:.75rem;font-weight:600;padding:4px 10px;position:absolute;right:12px;top:12px}.event-modal-overlay{align-items:center;animation:fadeIn .2s;background:#0009;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.event-modal{animation:slideUp .3s;background:#fff;border-radius:16px;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.event-modal-close{align-items:center;background:#0000001a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;position:absolute;right:16px;top:16px;transition:background .2s;width:40px;z-index:1}.event-modal-close:hover{background:#0003}.event-modal-header{background:linear-gradient(180deg,#f8fafc 0,#fff);border-top:4px solid;padding:32px 24px 24px}.event-modal-category{align-items:center;border-radius:16px;color:#fff;display:inline-flex;font-size:.875rem;font-weight:600;gap:6px;margin-bottom:16px;padding:6px 14px}.event-modal-title{color:#1e3a5f;font-size:1.75rem;font-weight:700;margin-bottom:8px}.event-modal-title-en{color:#64748b;font-size:1rem;font-style:italic}.event-modal-body{padding:24px}.event-modal-info{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.event-modal-info-item{align-items:flex-start;display:flex;gap:12px}.info-icon{font-size:1.5rem}.info-label{color:#64748b;font-size:.75rem;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.info-value{color:#1e293b;font-size:1rem;font-weight:500}.info-value-secondary{color:#64748b;font-size:.875rem;margin-top:4px}.event-modal-description{background:#f8fafc;border-radius:12px;margin-bottom:16px;padding:20px}.event-modal-description h3{color:#1e3a5f;font-size:1rem;font-weight:600;margin-bottom:12px}.event-modal-description p{color:#475569;line-height:1.6;margin-bottom:12px}.description-en{color:#64748b;font-style:italic}.event-modal-source{border-top:1px solid #e2e8f0;color:#94a3b8;font-size:.75rem;padding:12px;text-align:center}.events-empty,.events-error{padding:60px 20px;text-align:center}.events-empty-icon,.events-error-icon{font-size:4rem;margin-bottom:16px}.events-empty h3,.events-error h3{color:#1e3a5f;font-size:1.5rem;margin-bottom:8px}.events-empty p,.events-error p{color:#64748b}.event-feed-card{background:#fff;border:1px solid var(--border);border-radius:8px;cursor:pointer;overflow:hidden;transition:all .2s}.event-feed-card:hover{box-shadow:var(--shadow-elevated)}.event-feed-header{align-items:center;display:flex;gap:12px;padding:14px 16px}.event-feed-category{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:1.25rem;height:42px;justify-content:center;width:42px}.event-feed-header-info{display:flex;flex-direction:column}.event-feed-category-label{color:var(--text-primary);font-size:.9rem;font-weight:600}.event-feed-date{color:var(--text-muted);font-size:.8rem;text-transform:capitalize}.event-feed-image{aspect-ratio:1;background:#f5f5f5;overflow:hidden;width:100%}.event-feed-image img{height:100%;object-fit:cover;width:100%}.event-feed-content{padding:14px 16px}.event-feed-title{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:4px}.event-feed-title-en{color:var(--text-muted);font-size:.875rem;font-style:italic;margin-bottom:8px}.event-feed-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px}.event-feed-meta-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.8rem;gap:4px}.event-feed-description{color:var(--text-secondary);font-size:.875rem;line-height:1.5}.event-feed-highlight{align-items:center;background:#fef3c7;border-radius:12px;color:#92400e;display:inline-flex;font-size:.75rem;font-weight:600;gap:4px;margin-top:8px;padding:4px 10px}.event-feed-actions{border-top:1px solid var(--border-light);padding:12px 16px}.event-feed-action{align-items:center;background:var(--primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;justify-content:center;padding:10px;transition:background .2s;width:100%}.event-feed-action:hover{background:var(--primary-light)}@media (max-width:768px){.events-container{padding:16px}.events-header h1{font-size:1.5rem}.events-grid{gap:16px;grid-template-columns:1fr}.event-modal{border-radius:16px 16px 0 0;max-height:85vh}.event-modal-title{font-size:1.5rem}}.attend-button{align-items:center;display:flex;font-weight:600;gap:.5rem;justify-content:center;margin:1rem 0}.attend-icon{font-size:1.2rem;font-weight:700}.attend-privacy-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.privacy-modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:400px;padding:2rem;width:100%}.privacy-modal-content h3{color:#333;font-size:1.5rem;margin:0 0 .5rem}.privacy-modal-content p{color:#666;font-size:.95rem;margin:0 0 1.5rem}.privacy-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.privacy-cancel{background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;font-size:.95rem;padding:.75rem;transition:background-color .2s;width:100%}.privacy-cancel:hover{background:#f5f5f5}.privacy-cancel:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.privacy-modal-content{padding:1.5rem}.privacy-modal-content h3{font-size:1.25rem}}.attendee-list-container{margin:1.5rem 0}.attendee-count{align-items:center;background:linear-gradient(135deg,#c5a572,#b8935a);border-radius:8px;color:#fff;display:flex;font-weight:600;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.count-icon{font-size:1.25rem}.count-text{font-size:.95rem}.attendee-list-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:2rem}.attendee-list-loading .spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#c5a572;height:40px;margin-bottom:1rem;width:40px}.attendee-list-card{overflow:hidden;padding:0}.attendee-list{max-height:400px;overflow-y:auto}.attendee-item{align-items:center;border-bottom:1px solid #eee;display:flex;gap:1rem;padding:1rem;transition:background-color .2s}.attendee-item:last-child{border-bottom:none}.attendee-item:hover{background:#f9f9f9}.attendee-avatar{background:#f0f0f0;border-radius:50%;flex-shrink:0;height:48px;overflow:hidden;width:48px}.attendee-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#c5a572,#b8935a);color:#fff;display:flex;font-size:1rem;font-weight:600;height:100%;justify-content:center;text-transform:uppercase;width:100%}.attendee-info{flex:1 1;min-width:0}.attendee-name{color:#333;font-weight:600;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attendee-time{color:#888;font-size:.85rem}.show-more-btn{border:none;transition:background-color .2s}.show-more-btn:hover{background:#f0f0f0}.no-attendees{background:#f9f9f9;border:2px dashed #ddd;border-radius:8px;color:#888;padding:2rem;text-align:center}.no-attendees p{font-size:.95rem;margin:0}.attendee-list::-webkit-scrollbar{width:6px}.attendee-list::-webkit-scrollbar-track{background:#f1f1f1}.attendee-list::-webkit-scrollbar-thumb{background:#c5a572;border-radius:3px}.attendee-list::-webkit-scrollbar-thumb:hover{background:#b8935a}@media (max-width:768px){.attendee-avatar{height:40px;width:40px}.avatar-placeholder{font-size:.9rem}.attendee-name{font-size:.95rem}.attendee-time{font-size:.8rem}}.volunteer-role-card{border:2px solid #0000;padding:1.25rem;position:relative;transition:all .2s}.volunteer-role-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.volunteer-role-card.signed-up{background:linear-gradient(to bottom right,#fff,#f0fff4);border-color:#28a745}.volunteer-role-card.full{opacity:.7}.role-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.role-name{color:#333;flex:1 1;font-size:1.15rem;margin:0}.role-capacity{align-items:baseline;background:linear-gradient(135deg,#c5a572,#b8935a);border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:600;padding:.25rem .75rem}.capacity-filled{font-size:1.1rem}.capacity-separator{margin:0 .25rem;opacity:.7}.capacity-total{opacity:.9}.volunteer-role-card.full .role-capacity{background:linear-gradient(135deg,#dc3545,#c82333)}.volunteer-role-card.signed-up .role-capacity{background:linear-gradient(135deg,#28a745,#218838)}.role-description{color:#666;font-size:.9rem;line-height:1.5;margin:0 0 1rem}.role-time-slot{align-items:center;background:#f9f9f9;border-radius:6px;color:#555;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem}.approval-notice{margin-bottom:1rem}.role-card-footer{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.signup-status{align-items:center;border-radius:6px;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.5rem .75rem}.signup-status.pending{background:#fff3cd;border:1px solid #ffc107;color:#856404}.signup-status.confirmed{background:#d4edda;border:1px solid #28a745;color:#155724}.signup-status.rejected{background:#f8d7da;border:1px solid #dc3545;color:#721c24}.status-icon{font-size:1rem}.full-overlay{position:absolute;right:1rem;top:1rem}.full-badge{background:#dc3545;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:.25rem .75rem}@media (max-width:768px){.volunteer-role-card{padding:1rem}.role-name{font-size:1.05rem}.role-capacity{font-size:.85rem}}.volunteer-signup-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.signup-modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{border-bottom:1px solid #eee}.modal-header h2{color:#333}.close-btn{color:#999;font-size:2rem;height:32px;line-height:1;transition:all .2s;width:32px}.close-btn:hover{background:#f5f5f5;color:#333}.close-btn:disabled{cursor:not-allowed;opacity:.5}.modal-body{padding:1.5rem}.opportunity-summary{background:#f9f9f9;border-left:4px solid #c5a572;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.opportunity-summary h3{color:#333;font-size:1.25rem;margin:0 0 .5rem}.summary-description{color:#666;font-size:.9rem;line-height:1.5;margin:0 0 1rem}.summary-time{align-items:center;color:#555;display:flex;font-size:.9rem;font-weight:600;gap:.5rem}.time-icon{font-size:1rem}.approval-notice{align-items:center;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;display:flex;font-size:.85rem;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem}.approval-icon{font-size:1rem}.form-group label{color:#333;font-size:.95rem;font-weight:600}.form-group textarea{border:1px solid #ddd;border-radius:8px;font-family:inherit;font-size:.95rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group textarea:focus{border-color:#c5a572;outline:none}.form-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.char-count{color:#888;font-size:.8rem;margin-top:.25rem;text-align:right}.error-message{align-items:center;background:#f8d7da;border:1px solid #dc3545;color:#721c24;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem}.error-icon{font-size:1rem}.form-actions{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.signup-success{padding:3rem 2rem;text-align:center}.success-icon{align-items:center;animation:successPop .5s ease-out;background:linear-gradient(135deg,#28a745,#20c997);border-radius:50%;color:#fff;display:flex;font-size:3rem;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}@keyframes successPop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.signup-success h2{color:#333;font-size:1.5rem;margin:0 0 1rem}.signup-success p{color:#666;font-size:.95rem;line-height:1.6;margin:0}.signup-modal-content::-webkit-scrollbar{width:8px}.signup-modal-content::-webkit-scrollbar-track{background:#f1f1f1}.signup-modal-content::-webkit-scrollbar-thumb{background:#c5a572;border-radius:4px}.signup-modal-content::-webkit-scrollbar-thumb:hover{background:#b8935a}@media (max-width:768px){.signup-modal-content{border-radius:12px 12px 0 0;max-height:95vh;max-width:100%}.modal-header{padding:1.25rem}.modal-header h2{font-size:1.25rem}.modal-body{padding:1.25rem}.form-actions{grid-template-columns:1fr}.signup-success{padding:2rem 1.5rem}.success-icon{font-size:2.5rem;height:60px;width:60px}}.volunteer-opportunities-container{margin:2rem 0}.volunteer-header{margin-bottom:1.5rem}.volunteer-title{align-items:center;color:#333;display:flex;font-size:1.5rem;gap:.75rem;margin:0 0 .5rem}.volunteer-icon{font-size:1.75rem}.volunteer-subtitle{color:#666;font-size:.95rem;margin:0}.opportunities-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.volunteer-opportunities-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem}.volunteer-opportunities-loading .spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#c5a572;height:40px;margin-bottom:1rem;width:40px}.volunteer-opportunities-error{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;padding:1.5rem;text-align:center}.volunteer-opportunities-error p{margin:0}.no-volunteer-opportunities{background:#f9f9f9;border:2px dashed #ddd;border-radius:12px;padding:3rem 1rem;text-align:center}.no-opportunities-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.no-volunteer-opportunities h3{color:#333;font-size:1.25rem;margin:0 0 .5rem}.no-volunteer-opportunities p{color:#666;font-size:.95rem;margin:0}@media (max-width:768px){.opportunities-grid{grid-template-columns:1fr}.volunteer-title{font-size:1.25rem}.volunteer-icon{font-size:1.5rem}}.auth-page{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2d5a8a);display:flex;justify-content:center;min-height:100vh}.auth-page-content{max-width:500px;width:100%}.auth-page-brand{color:#fff;margin-bottom:40px;text-align:center}.auth-page-icon{font-size:4rem;margin-bottom:16px}.auth-page-brand h1{font-size:2rem;font-weight:700;margin-bottom:8px}.auth-page-brand p{font-size:1rem;opacity:.9}.home-page{margin:0 auto;max-width:600px;padding-bottom:100px;padding-top:60px}.home-feed{display:flex;flex-direction:column}.feed-header{background:#fff;border-bottom:1px solid var(--border);margin-bottom:1px;padding:20px 16px 24px;text-align:center}.feed-header h1{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:4px}.feed-subtitle{color:var(--text-muted);font-size:.875rem}.home-events-feed{display:flex;flex-direction:column;gap:12px;padding:12px 0}.placeholder-page{margin:0 auto;max-width:800px;padding:80px 24px 100px;text-align:center}.placeholder-icon{font-size:5rem;margin-bottom:24px}.placeholder-page h1{color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:12px}.placeholder-page p{color:var(--text-muted);font-size:1rem;line-height:1.6;margin:0 auto;max-width:400px}@media (max-width:768px){.home-page{padding-top:16px}.feed-header{padding:16px}.feed-header h1{font-size:1.25rem}.home-events-feed{gap:8px;padding:8px}.auth-page-brand h1{font-size:1.5rem}.auth-page-icon{font-size:3rem}.placeholder-page{padding:40px 16px 100px}.placeholder-icon{font-size:4rem}.placeholder-page h1{font-size:1.5rem}}.attendance-card{margin-bottom:1rem;overflow:hidden;padding:1rem;position:relative;transition:all .2s}.attendance-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.attendance-card.upcoming-event{border-left:4px solid #c5a572}.attendance-card.past-event{border-left:4px solid #999;opacity:.85}.attendance-card-header{display:flex;gap:1rem;margin-bottom:1rem}.event-date-badge{align-items:center;background:linear-gradient(135deg,#c5a572,#b8935a);border-radius:8px;box-shadow:0 2px 8px #c5a5724d;color:#fff;display:flex;flex-direction:column;flex-shrink:0;height:60px;justify-content:center;width:60px}.past-event .event-date-badge{background:linear-gradient(135deg,#999,#777);box-shadow:0 2px 8px #9999994d}.date-month{font-size:.75rem;font-weight:600;line-height:1;margin-bottom:2px}.date-day{font-size:1.5rem;font-weight:700;line-height:1}.event-main-info{flex:1 1;min-width:0}.event-title{font-size:1.1rem;margin:0 0 .5rem}.event-details{color:#666;flex-wrap:wrap;font-size:.85rem;gap:1rem}.event-location,.event-time{align-items:center;display:flex;gap:.25rem}.event-details .icon{font-size:.9rem}.attendance-card-footer{align-items:center;border-top:1px solid #eee;display:flex;font-size:.85rem;justify-content:space-between;padding-top:.75rem}.attendance-meta{display:flex;gap:1rem}.attendance-status{color:#28a745;font-weight:600}.past-event .attendance-status{color:#999}.attendance-visibility{color:#666}.attendance-registered{color:#888;font-size:.8rem}.event-category-tag{background:#f0f0f0;border-radius:12px;color:#666;font-size:.75rem;font-weight:600;padding:.25rem .75rem;position:absolute;right:1rem;text-transform:uppercase;top:1rem}.event-category-tag.liturgy{background:#e3f2fd;color:#1976d2}.event-category-tag.social{background:#f3e5f5;color:#7b1fa2}.event-category-tag.education{background:#e8f5e9;color:#388e3c}.event-category-tag.service{background:#fff3e0;color:#f57c00}@media (max-width:768px){.attendance-card-header{gap:.75rem}.event-date-badge{height:50px;width:50px}.date-month{font-size:.7rem}.date-day{font-size:1.25rem}.event-title{font-size:1rem}.event-details{flex-direction:column;gap:.25rem}.attendance-card-footer{align-items:flex-start;flex-direction:column;gap:.5rem}.event-category-tag{display:inline-block;margin-top:.5rem;position:static}}.upcoming-events-section{margin:2rem 0}.upcoming-events-loading{color:#666;padding:2rem;text-align:center}.no-upcoming-events{background:#f9f9f9;border-radius:8px;color:#888;padding:2rem;text-align:center}.no-upcoming-events p{margin:0}.upcoming-events-list{display:flex;flex-direction:column;gap:1rem}.attendance-history-section{margin:2rem 0}.section-title{margin:0 0 1rem}.attendance-history-loading{color:#666;padding:2rem;text-align:center}.no-attendance-history{background:#f9f9f9;border-radius:8px;color:#888;padding:2rem;text-align:center}.no-attendance-history p{margin:0}.attendance-history-list{display:flex;flex-direction:column;gap:1rem}.volunteer-badge{margin-bottom:1rem;overflow:hidden;padding:1rem;position:relative;transition:all .2s}.volunteer-badge:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.volunteer-badge.confirmed.upcoming{border-left:4px solid #28a745}.volunteer-badge.confirmed.past{border-left:4px solid #6c757d}.volunteer-badge.pending{border-left:4px solid #ffc107}.volunteer-badge.rejected{border-left:4px solid #dc3545;opacity:.7}.badge-header{align-items:flex-start;display:flex;gap:.75rem;margin-bottom:.75rem}.badge-icon{align-items:center;background:#f9f9f9;border-radius:50%;display:flex;flex-shrink:0;font-size:1.5rem;height:48px;justify-content:center;width:48px}.volunteer-badge.confirmed .badge-icon{background:linear-gradient(135deg,#28a745,#20c997)}.volunteer-badge.pending .badge-icon{background:linear-gradient(135deg,#ffc107,#ffb300)}.volunteer-badge.rejected .badge-icon{background:linear-gradient(135deg,#dc3545,#c82333)}.badge-main-info{flex:1 1;min-width:0}.event-title{color:#333;font-size:1.05rem;font-weight:600;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-name{color:#c5a572;font-size:.9rem;font-weight:600}.hours-badge{align-items:center;background:linear-gradient(135deg,#c5a572,#b8935a);border-radius:8px;box-shadow:0 2px 8px #c5a5724d;color:#fff;display:flex;flex-direction:column;flex-shrink:0;height:50px;justify-content:center;width:50px}.hours-value{font-size:1.25rem;font-weight:700;line-height:1}.hours-label{font-size:.7rem;margin-top:2px}.badge-details{color:#666;display:flex;flex-wrap:wrap;font-size:.85rem;gap:1rem;margin-bottom:.75rem}.badge-date,.badge-location{align-items:center;display:flex;gap:.25rem}.detail-icon{font-size:.9rem}.badge-footer{align-items:center;border-top:1px solid #eee;display:flex;font-size:.85rem;justify-content:space-between;padding-top:.75rem}.badge-status .status{align-items:center;border-radius:12px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.25rem;padding:.25rem .75rem}.badge-status .status.confirmed{background:#d4edda;color:#155724}.volunteer-badge.past .badge-status .status.confirmed{background:#e2e6ea;color:#6c757d}.badge-status .status.pending{background:#fff3cd;color:#856404}.badge-status .status.rejected{background:#f8d7da;color:#721c24}.badge-timestamp{color:#888;font-size:.8rem}@media (max-width:768px){.badge-header{gap:.5rem}.badge-icon{font-size:1.25rem;height:40px;width:40px}.event-title{font-size:1rem}.role-name{font-size:.85rem}.hours-badge{height:45px;width:45px}.hours-value{font-size:1.1rem}.badge-details{flex-direction:column;gap:.25rem}.badge-footer{align-items:flex-start;flex-direction:column;gap:.5rem}}.volunteer-history-section{margin:2rem 0}.volunteer-history-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.section-title{align-items:center;color:#333;display:flex;font-size:1.25rem;gap:.5rem;margin:0}.title-icon{font-size:1.5rem}.total-hours-badge{background:linear-gradient(135deg,#c5a572,#b8935a);border-radius:12px;box-shadow:0 2px 8px #c5a5724d;color:#fff;flex-shrink:0;padding:.75rem 1.25rem;text-align:center}.hours-number{font-size:1.5rem;font-weight:700;line-height:1;margin-bottom:2px}.hours-label{font-size:.75rem;opacity:.9}.volunteer-history-loading{color:#666;padding:2rem;text-align:center}.no-volunteer-history{background:#f9f9f9;border-radius:8px;color:#888;padding:2rem;text-align:center}.no-volunteer-history p{margin:0}.volunteer-history-list{display:flex;flex-direction:column;gap:1rem}.show-more-btn{background:#f9f9f9;border:2px dashed #c5a572;border-radius:8px;color:#c5a572;cursor:pointer;font-weight:600;margin-top:1rem;padding:.75rem;transition:all .2s;width:100%}.show-more-btn:hover{background:#c5a572;border-style:solid;color:#fff}@media (max-width:768px){.volunteer-history-header{align-items:flex-start;flex-direction:column}.total-hours-badge{align-self:stretch}}.ministry-badges-container{display:flex;flex-direction:column;gap:1rem}.ministry-badges-empty,.ministry-badges-loading{align-items:center;display:flex;flex-direction:column;gap:.75rem;justify-content:center;padding:1.5rem}.ministry-badges-empty p{color:var(--text-muted);font-size:.9rem;margin:0}.browse-ministries-btn{background:var(--primary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background .2s ease}.browse-ministries-btn:hover{background:var(--primary-light)}.ministry-section{display:flex;flex-direction:column;gap:.75rem}.ministry-section-title{align-items:center;color:var(--text-secondary);display:flex;font-size:.85rem;font-weight:600;gap:.5rem;letter-spacing:.5px;margin:0;text-transform:uppercase}.section-icon{font-size:1rem}.ministry-badges-grid{display:flex;flex-wrap:wrap;gap:1rem}.ministry-badge-item{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;width:70px}.ministry-badge-item:hover .badge-image-container{transform:scale(1.05)}.ministry-badge-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-primary);display:-webkit-box;font-size:.7rem;font-weight:500;line-height:1.2;max-width:70px;overflow:hidden;text-align:center;text-overflow:ellipsis}.badge-image-container{border-radius:50%;cursor:pointer;overflow:visible;position:relative;transition:transform .2s}.badge-image-container.size-normal{height:56px;width:56px}.badge-image-container.size-small{height:44px;width:44px}.badge-image-container.size-large{height:72px;width:72px}.badge-svg{object-fit:contain}.badge-fallback,.badge-svg{border-radius:50%;height:100%;width:100%}.badge-fallback{align-items:center;background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);display:flex;font-size:1.5rem;justify-content:center}.badge-image-container.size-small .badge-fallback{font-size:1.25rem}.badge-image-container.size-large .badge-fallback{font-size:2rem}.leader-ring{border:3px solid #c9a227;border-radius:50%;box-shadow:0 0 8px #c9a22766;inset:-3px;pointer-events:none;position:absolute}.badge-image-container.size-small .leader-ring{border-width:2px;inset:-2px}.badge-image-container.size-large .leader-ring{border-width:4px;inset:-4px}.compact-badge-row{-webkit-overflow-scrolling:touch;display:flex;gap:12px;overflow-x:auto;padding:4px 0;scrollbar-width:none}.compact-badge-row::-webkit-scrollbar{display:none}.browse-more-btn{align-self:center;background:#0000;border:1px solid var(--border);border-radius:6px;color:var(--primary);cursor:pointer;font-size:.85rem;font-weight:500;margin-top:.5rem;padding:.5rem 1rem;transition:all .2s ease}.browse-more-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}@media (max-width:768px){.ministry-badges-grid{gap:.75rem}.ministry-badge-item{width:60px}.badge-image-container.size-normal{height:48px;width:48px}.ministry-badge-name{font-size:.65rem;max-width:60px}}.devotions-container{padding:.5rem 0}.devotions-empty,.devotions-loading{padding:2rem;text-align:center}.devotions-empty p{color:var(--text-secondary);margin-bottom:1rem}.devotion-category{margin-bottom:1.5rem}.category-title{color:var(--text-secondary);font-size:.9rem;font-weight:600;letter-spacing:.05em;margin-bottom:.75rem;text-transform:uppercase}.devotion-badges{display:flex;flex-wrap:wrap;gap:.5rem}.devotion-badge{background:var(--surface);border:1px solid var(--border);display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease;-webkit-user-select:none;user-select:none}.devotion-badge.admin-editable{cursor:pointer}.devotion-badge.admin-editable:active{transform:scale(.98)}.devotion-badge.clickable{cursor:pointer}.devotion-badge.clickable:hover{background:#c9a2271a;border-color:#c9a227;border-color:var(--gold,#c9a227);box-shadow:0 2px 8px #c9a22733;transform:translateY(-1px)}.devotion-badge.clickable:active{transform:scale(.98) translateY(0)}.badge-icon{font-size:1.2rem}.badge-photo{border-radius:50%;height:24px;object-fit:cover;width:24px}.badge-name{color:var(--text-primary);font-weight:500}.manage-devotions-btn{margin-top:1rem;width:100%}.devotions-selector{position:relative}.devotions-selector-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.devotions-selector-header h3{font-size:1.1rem;margin:0}.devotions-grid{grid-gap:.75rem;display:grid;gap:.75rem;margin:-.5rem;max-height:500px;overflow-y:auto;padding:.5rem}.devotion-item{background:var(--surface);border:2px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.devotion-item.added,.devotion-item:hover{background:var(--primary-light);border-color:var(--primary)}.devotion-item.admin-editable:active{transform:scale(.98)}.devotion-icon{flex-shrink:0;font-size:2rem}.devotion-photo{border-radius:8px;flex-shrink:0;height:48px;object-fit:cover;width:48px}.devotion-name{color:var(--text-primary);font-weight:600;margin-bottom:.25rem}.devotion-name-es{color:var(--text-secondary);font-size:.85rem}.check-mark{color:var(--primary);font-size:1.5rem;font-weight:700}.devotions-selector-footer{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1rem}@media (max-width:768px){.devotion-badge{font-size:.85rem;padding:.4rem .8rem}.badge-icon{font-size:1rem}}.image-cropper-modal{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;overflow:hidden;padding:1rem;position:fixed;right:0;top:0;touch-action:none;z-index:10000}.image-cropper-content{background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;padding:1.5rem;width:100%}.image-cropper-content h3{color:#1e3a5f;font-size:1.25rem;margin:0 0 .5rem}.crop-instructions{color:#64748b;font-size:.875rem;margin:0 0 1rem}.image-cropper-container{background:#1a1a1a;border-radius:8px;height:400px;margin-bottom:1rem;overflow:hidden;position:relative;touch-action:none;-webkit-user-select:none;user-select:none;width:100%}.image-cropper-image{left:0;max-height:none;max-width:none;pointer-events:auto;position:absolute;top:0;transform-origin:0 0}.crop-box-static{border:3px solid #c9a227;box-shadow:0 0 0 9999px #00000080;left:50%;padding-bottom:70%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:70%;z-index:10}.crop-box-static:before{height:1px;left:0;right:0;top:50%}.crop-box-static:after,.crop-box-static:before{background:#c9a22780;content:"";position:absolute}.crop-box-static:after{bottom:0;left:50%;top:0;width:1px}.crop-box-static.crop-box-circle{border-radius:50%}.corner,.crop-box,.crop-box-border,.crop-box-corners,.crop-box-static.crop-box-circle:after,.crop-box-static.crop-box-circle:before{display:none}.zoom-controls{align-items:center;background:#f1f5f9;background:var(--surface,#f1f5f9);border-radius:8px;display:flex;gap:1rem;justify-content:center;margin-bottom:1rem;padding:.75rem}.zoom-btn{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:6px;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.zoom-btn:hover{background:#f8f9fa;border-color:#c9a227}.zoom-btn:active{transform:scale(.95)}.zoom-level{color:#1e3a5f;color:var(--text-primary,#1e3a5f);font-weight:600;min-width:60px;text-align:center}.image-cropper-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-cancel,.btn-crop{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.btn-cancel{background:#e2e8f0;color:#475569}.btn-cancel:hover{background:#cbd5e1}.btn-crop{background:#c9a227;color:#fff}.btn-crop:hover{background:#b8921f}.image-cropper-loading{align-items:center;color:#64748b;display:flex;justify-content:center;padding:3rem}@media (max-width:768px){.image-cropper-content{max-height:95vh;padding:1rem}.image-cropper-container{height:300px}.crop-box-static{padding-bottom:80%;width:80%}.zoom-controls{flex-wrap:wrap;gap:.5rem}.zoom-btn{flex:1 1;min-width:100px}.image-cropper-actions{flex-direction:column}.btn-cancel,.btn-crop{width:100%}}.reading-container{padding:.5rem 0}.reading-empty,.reading-loading{padding:2rem;text-align:center}.reading-empty p{color:var(--text-secondary);margin-bottom:1rem}.reading-tabs{border-bottom:2px solid var(--border);display:flex;gap:.5rem;margin-bottom:1.5rem}.tab{background:none;border:none;border-bottom:3px solid #0000;color:var(--text-secondary);cursor:pointer;flex:1 1;font-weight:500;margin-bottom:-2px;padding:.75rem 1rem;transition:all .2s ease}.tab:hover{background:var(--surface);color:var(--text-primary)}.tab.active{border-bottom-color:var(--primary);color:var(--primary)}.books-list{margin-bottom:1rem}.no-books{color:var(--text-secondary);padding:2rem;text-align:center}.book-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:.75rem;overflow:hidden;transition:all .3s ease}.book-item:hover{border-color:var(--primary);box-shadow:0 2px 8px #0000001a}.book-compact-view{align-items:center;cursor:pointer;display:flex;gap:1rem;padding:1rem;-webkit-user-select:none;user-select:none}.book-compact-view:hover{background:#00000005}.book-thumbnail{align-items:center;background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border-radius:6px;display:flex;flex-shrink:0;height:48px;justify-content:center;overflow:hidden;width:48px}.book-thumbnail img{height:100%;object-fit:cover;width:100%}.book-emoji{font-size:2rem}.book-title-compact{color:var(--text-primary);flex:1 1;font-size:1rem;font-weight:600}.expand-arrow{color:var(--text-secondary);font-size:.875rem;transition:transform .3s ease}.book-item.expanded .expand-arrow{transform:rotate(180deg)}.book-expanded-content{animation:expandContent .3s ease;padding:0 1rem 1rem}@keyframes expandContent{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.book-full-image{background:var(--surface);border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem;overflow:hidden}.book-full-image img{display:block;height:auto;max-height:400px;object-fit:contain;width:100%}.book-expanded-content>div{margin-bottom:.75rem}.book-expanded-content>div:last-child{margin-bottom:0}.book-author{font-size:.9rem}.book-author,.book-notes{color:var(--text-secondary);line-height:1.5}.book-notes{font-size:.85rem}.book-link a{color:var(--primary);text-decoration:none}.book-link a:hover{text-decoration:underline}.book-bookmarks{background:var(--surface);border-radius:6px;margin-top:.75rem;padding:.75rem}.book-bookmarks strong{color:var(--text-primary);display:block;margin-bottom:.5rem}.bookmarks-list{list-style:none;margin:.5rem 0;padding:0}.bookmark-item{background:#fff;border:1px solid var(--border);border-radius:4px;justify-content:space-between;margin-bottom:.25rem;padding:.5rem}.bookmark-info,.bookmark-item{align-items:center;display:flex}.bookmark-info{flex:1 1;gap:.75rem}.bookmark-page{color:var(--text-secondary);font-size:.875rem}.bookmark-delete-btn{background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;padding:.25rem .5rem;transition:all .2s ease}.bookmark-delete-btn:hover{background:#fee2e2;color:#dc2626}.no-bookmarks{color:var(--text-secondary);font-size:.875rem;margin:.5rem 0}.bookmark-form{background:#fff;border:1px solid var(--border);border-radius:6px;margin-top:.75rem;padding:.75rem}.bookmark-form-fields{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.bookmark-form-fields input{border:1px solid var(--border);border-radius:4px;font-size:.875rem;padding:.5rem}.bookmark-form-fields input:focus{border-color:var(--primary);outline:none}.bookmark-form-actions{display:flex;gap:.5rem}.bookmark-cancel-btn,.bookmark-save-btn{border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.bookmark-save-btn{background:var(--primary);border-color:var(--primary);color:#fff}.bookmark-save-btn:hover{opacity:.9}.bookmark-cancel-btn{background:#fff;color:var(--text-primary)}.bookmark-cancel-btn:hover{background:var(--surface)}.add-bookmark-btn{background:#fff;border:1px solid var(--border);border-radius:4px;color:var(--primary);cursor:pointer;font-size:.875rem;margin-top:.5rem;padding:.5rem 1rem;transition:all .2s ease}.add-bookmark-btn:hover{background:#e0f2fe;border-color:var(--primary)}.book-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;margin-top:1rem;padding-top:.75rem}.delete-btn,.edit-btn{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.edit-btn:hover{background:#e0f2fe;border-color:#0369a1;color:#0369a1}.delete-btn:hover{background:#fee2e2;border-color:#dc2626;color:#dc2626}.add-book-btn{margin-top:.5rem;width:100%}.book-form{padding:.5rem 0}.form-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.form-header h3{font-size:1.1rem;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:2rem;justify-content:center;padding:0;transition:all .2s ease;width:2rem}.close-btn:hover{background:var(--surface);color:var(--text-primary)}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-primary)}.field-help{color:var(--text-secondary);display:block;font-size:.75rem;margin-top:.25rem}.checkbox-group{margin-bottom:1rem}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:.5rem}.checkbox-label input[type=checkbox]{cursor:pointer;width:auto}.checkbox-label span{font-size:.95rem}.form-group input,.form-group select,.form-group textarea{-webkit-appearance:none;appearance:none;background-color:#fff;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .2s ease;width:100%}.form-group select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1em;cursor:pointer;padding-right:2.5rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-group input[type=file]{cursor:pointer;padding:.5rem}.photo-preview{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-top:1rem;padding:.75rem}.photo-preview img{border-radius:6px;display:block;margin:0 auto;max-height:200px;max-width:100%}.photo-preview small{color:var(--text-secondary);display:block;font-size:.75rem;margin-top:.5rem;text-align:center}.form-actions{border-top:1px solid var(--border);gap:1rem;margin-top:1.5rem;padding-top:1rem}.spinner{animation:spin 1s ease-in-out infinite;border:3px solid #0000001a;border-radius:50%;border-top:3px solid var(--primary);height:40px;margin:0 auto 1rem;width:40px}@media (max-width:768px){.book-compact-view{gap:.75rem;padding:.75rem}.book-thumbnail{height:40px;width:40px}.book-emoji{font-size:1.5rem}.book-title-compact{font-size:.9rem}.book-expanded-content{padding:0 .75rem .75rem}.book-actions{flex-direction:column;gap:.5rem}.delete-btn,.edit-btn{width:100%}.reading-tabs{flex-direction:column;gap:0}.tab{border-bottom:1px solid var(--border)}.tab.active{background:var(--surface)}}.notification-item{align-items:flex-start;border-bottom:1px solid #eee;cursor:pointer;display:flex;gap:1rem;padding:1rem;position:relative;transition:background-color .2s}.notification-item:hover{background:#f9f9f9}.notification-item:last-child{border-bottom:none}.notification-item.unread{background:#f0f7ff}.notification-item.unread:hover{background:#e6f2ff}.notification-icon{align-items:center;background:#f0f0f0;border-radius:50%;display:flex;flex-shrink:0;font-size:1.25rem;height:40px;justify-content:center;width:40px}.notification-item.unread .notification-icon{background:linear-gradient(135deg,#c5a572,#b8935a)}.notification-content{flex:1 1;min-width:0}.notification-header{align-items:baseline;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.25rem}.notification-title{color:#333;font-size:.95rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-time{color:#888;flex-shrink:0;font-size:.75rem}.notification-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.9rem;line-height:1.4;margin:0;overflow:hidden}.unread-dot{background:#007bff;border-radius:50%;height:8px;position:absolute;right:3rem;top:1.25rem;width:8px}.notification-delete{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;flex-shrink:0;font-size:1.5rem;height:24px;justify-content:center;line-height:1;transition:all .2s;width:24px}.notification-delete:hover{background:#f0f0f0;color:#dc3545}@media (max-width:768px){.notification-item{gap:.75rem;padding:.75rem}.notification-icon{font-size:1.1rem;height:36px;width:36px}.notification-title{font-size:.9rem}.notification-message{font-size:.85rem}.notification-time{font-size:.7rem}}.notification-center-overlay{align-items:flex-start;background:#0000004d;bottom:0;display:flex;justify-content:center;left:0;padding-top:60px;position:fixed;right:0;top:0;z-index:1000}.notification-center{animation:slideDown .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:80vh;max-width:500px;width:90%}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.notification-center-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1rem 1.5rem}.notification-center-header h3{color:#333;font-size:1.25rem;margin:0}.notification-close{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.notification-close:hover{background:#f0f0f0;color:#333}.notification-tabs{border-bottom:1px solid #eee;display:flex;padding:0 1.5rem}.notification-tab{background:none;border:none;border-bottom:2px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:500;padding:.75rem 1rem;transition:all .2s}.notification-tab:hover{background:#f9f9f9;color:#333}.notification-tab.active{border-bottom-color:#c5a572;color:#c5a572}.notification-actions{border-bottom:1px solid #eee;display:flex;justify-content:flex-end;padding:.75rem 1.5rem}.notification-action-btn{background:none;border:none;border-radius:4px;color:#007bff;cursor:pointer;font-size:.85rem;padding:.25rem .5rem;transition:background-color .2s}.notification-action-btn:hover{background:#f0f0f0}.notification-list{flex:1 1;overflow-y:auto}.notification-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem}.notification-loading .spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#c5a572;height:40px;margin-bottom:1rem;width:40px}.notification-error{color:#dc3545;padding:2rem;text-align:center}.notification-error button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;margin-top:1rem;padding:.5rem 1rem}.notification-empty{align-items:center;color:#888;display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem}.empty-icon{font-size:3rem;opacity:.5}.notification-empty p{font-size:.95rem;margin:0}.notification-center-footer{border-top:1px solid #eee;padding:1rem 1.5rem}.notification-preferences-btn{align-items:center;background:#f9f9f9;border:1px solid #ddd;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem;transition:all .2s;width:100%}.notification-preferences-btn:hover{background:#f0f0f0;border-color:#c5a572}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f1f1f1}.notification-list::-webkit-scrollbar-thumb{background:#c5a572;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#b8935a}@media (max-width:768px){.notification-center-overlay{align-items:flex-end;padding-top:0}.notification-center{border-radius:12px 12px 0 0;max-height:90vh;max-width:100%;width:100%}.notification-actions,.notification-center-footer,.notification-center-header,.notification-tabs{padding-left:1rem;padding-right:1rem}@keyframes slideDown{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}}.notification-bell{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:relative;transition:background-color .2s}.notification-bell:hover{background:#0000000d}.notification-bell:active{background:#0000001a}.bell-icon{display:block;font-size:1.5rem}.notification-badge{align-items:center;animation:badgePulse 2s ease-in-out infinite;background:linear-gradient(135deg,#dc3545,#c82333);border-radius:9px;box-shadow:0 2px 4px #0003;color:#fff;display:flex;font-size:.7rem;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 4px;position:absolute;right:0;top:0}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width:768px){.bell-icon{font-size:1.25rem}.notification-badge{border-radius:8px;font-size:.65rem;height:16px;min-width:16px}}.profile-view-container.instagram-style{margin:0 auto;max-width:600px;padding-bottom:100px}.profile-top-bar{align-items:center;background:#fff;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.profile-top-bar-left{width:40px}.profile-top-bar-title{color:var(--text-primary);font-size:1.1rem;font-weight:600}.hamburger-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;width:40px}.hamburger-lines{color:var(--text-primary);font-size:1.5rem}.profile-header.instagram{background:#fff;margin-bottom:0;padding:20px 16px;text-align:left}.profile-header-top{align-items:center;display:flex;gap:24px;margin-bottom:16px}.profile-photo-container{flex-shrink:0}.profile-photo-container .profile-photo{border:3px solid var(--gold);border-radius:50%;height:86px;object-fit:cover;width:86px}.profile-photo-container .profile-photo-placeholder{align-items:center;background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);border:3px solid var(--gold);border-radius:50%;color:#fff;display:flex;font-size:1.75rem;font-weight:700;height:86px;justify-content:center;width:86px}.profile-stats{display:flex;flex:1 1;justify-content:space-around}.profile-stat{align-items:center;display:flex;flex-direction:column}.stat-number{color:var(--text-primary);font-size:1.25rem;font-weight:700}.stat-label{color:var(--text-muted);font-size:.75rem}.profile-info{margin-bottom:16px}.profile-name{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:4px}.profile-bio{color:var(--text-secondary);font-size:.875rem;line-height:1.4;margin:0}.bio-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.875rem;font-weight:500;padding:0}.bio-toggle:hover{color:var(--primary)}.profile-actions{display:flex;gap:8px}.edit-profile-btn{flex:1 1;padding:8px 16px!important}.profile-badges-row{background:#fff;border-bottom:1px solid var(--border);border-top:1px solid var(--border-light);overflow-x:auto;padding:12px 16px}.profile-sections{background:#fff}.profile-section{border-bottom:1px solid var(--border-light)}.profile-section-header{align-items:center;background:#fff;border:none;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px;transition:background .2s;width:100%}.profile-section-header:hover{background:var(--bg-secondary)}.profile-section-title{align-items:center;display:flex;gap:10px}.profile-section-title .section-icon{font-size:1.25rem}.profile-section-title h3{color:var(--text-primary);font-size:.95rem;font-weight:600;margin:0}.section-arrow{color:var(--text-muted);font-size:1.25rem;font-weight:300}.profile-section-content{padding:0 16px 16px}.hamburger-overlay{animation:fadeIn .2s;background:#00000080;inset:0;position:fixed;z-index:200}.hamburger-menu{animation:slideInRight .3s;background:#fff;bottom:0;display:flex;flex-direction:column;max-width:85vw;position:fixed;right:0;top:0;width:280px;z-index:201}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hamburger-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 20px}.hamburger-header h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0}.hamburger-close{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:1.75rem;height:36px;justify-content:center;width:36px}.hamburger-section{border-bottom:1px solid var(--border-light);padding:12px 0}.hamburger-section-title{color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:8px 20px;text-transform:uppercase}.hamburger-item{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:.95rem;gap:14px;padding:14px 20px;text-align:left;text-decoration:none;transition:background .2s;width:100%}.hamburger-item:hover{background:var(--bg-secondary)}.hamburger-icon{font-size:1.25rem}.hamburger-item.logout{color:#dc2626}.hamburger-footer{border-bottom:none;border-top:1px solid var(--border);margin-top:auto}.profile-edit-container{margin:0 auto;max-width:600px;padding:24px 16px 100px}.profile-edit-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.profile-edit-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:700}.profile-form{display:flex;flex-direction:column;gap:8px}.profile-form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.profile-textarea{font-family:inherit;min-height:100px;resize:vertical}.profile-form-actions{border-top:1px solid var(--border);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.profile-error-banner{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c00}.profile-error-banner,.profile-success-banner{font-size:.875rem;margin-bottom:20px;padding:12px 16px}.profile-success-banner{background:#d1fae5;border:1px solid #86efac;border-radius:8px;color:#065f46}.profile-info-grid{grid-gap:16px;display:grid;gap:16px}.profile-info-item{align-items:flex-start;background:var(--bg-secondary);border-radius:8px;display:flex;gap:12px;padding:12px}.profile-info-icon{font-size:1.25rem}.profile-info-label{color:var(--text-muted);font-size:.7rem;letter-spacing:.5px;margin-bottom:2px;text-transform:uppercase}.profile-info-value{color:var(--text-primary);font-size:.9rem;font-weight:500}@media (max-width:640px){.profile-view-container.instagram-style{padding-bottom:80px}.profile-header-top{gap:16px}.profile-photo-container .profile-photo,.profile-photo-container .profile-photo-placeholder{font-size:1.5rem;height:70px;width:70px}.stat-number{font-size:1.1rem}.stat-label{font-size:.7rem}.profile-form-row{gap:8px;grid-template-columns:1fr}.profile-form-actions{flex-direction:column-reverse}.profile-form-actions button{width:100%}}@media (min-width:769px){.profile-view-container.instagram-style{padding-top:60px}.profile-top-bar{border-left:1px solid var(--border);border-right:1px solid var(--border);left:50%;max-width:600px;position:fixed;top:60px;transform:translateX(-50%);width:100%}.profile-photo-container .profile-photo,.profile-photo-container .profile-photo-placeholder{font-size:2rem;height:100px;width:100px}}.photo-upload-container{align-items:center;display:flex;gap:32px;padding:20px}.photo-upload-preview{flex-shrink:0}.photo-preview-img{border:3px solid #c9a227;border-radius:50%;height:120px;object-fit:cover;width:120px}.photo-preview-placeholder{align-items:center;background:#f1f5f9;border:2px dashed #cbd5e1;border-radius:50%;display:flex;flex-direction:column;gap:8px;height:120px;justify-content:center;width:120px}.photo-preview-icon{font-size:2rem}.photo-preview-placeholder p{color:#64748b;font-size:.75rem}.photo-upload-controls{display:flex;flex:1 1;flex-direction:column;gap:12px}.photo-upload-input{display:none}.photo-upload-hint{color:#64748b;font-size:.875rem}.photo-upload-error{background:#fee;border:1px solid #fcc;border-radius:6px;color:#c00;font-size:.875rem;padding:8px 12px}.photo-upload-success{background:#d1fae5;border:1px solid #86efac;border-radius:6px;color:#065f46;font-size:.875rem;padding:8px 12px}@media (max-width:640px){.photo-upload-container{align-items:center;flex-direction:column;gap:20px;text-align:center}}.notification-preferences-container{margin:0 auto;max-width:800px;padding:1.5rem}.preferences-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.back-button{background:none;border:none;border-radius:50%;cursor:pointer;font-size:1.5rem;padding:.5rem;transition:background-color .2s}.back-button:hover{background:#f0f0f0}.preferences-header h1{color:#333;font-size:1.75rem;margin:0}.preferences-intro{color:#666;font-size:.95rem;line-height:1.5;margin:0 0 1.5rem}.preferences-list{display:flex;flex-direction:column;gap:1.5rem}.preference-item{border:1px solid #eee;border-radius:8px;padding:1rem;transition:border-color .2s}.preference-item:hover{border-color:#c5a572}.preference-header{align-items:flex-start;display:flex;gap:1rem}.preference-toggle{display:inline-block;flex-shrink:0;height:28px;position:relative;width:50px}.preference-toggle input{height:0;opacity:0;width:0}.toggle-slider{background-color:#ccc;border-radius:28px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:"";height:20px;left:4px;position:absolute;transition:.3s;width:20px}.preference-toggle input:checked+.toggle-slider{background-color:#c5a572}.preference-toggle input:checked+.toggle-slider:before{transform:translateX(22px)}.preference-info{flex:1 1}.preference-info h3{color:#333;font-size:1.05rem;margin:0 0 .25rem}.preference-info p{color:#666;font-size:.9rem;line-height:1.4;margin:0}.preference-delivery{border-top:1px solid #eee;margin-top:1rem;padding-top:1rem}.preference-delivery label{color:#555;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.delivery-options{display:flex;gap:.75rem}.delivery-option{align-items:center;background:#f9f9f9;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all .2s}.delivery-option:hover:not(:disabled){background:#fff;border-color:#c5a572}.delivery-option.active{background:linear-gradient(135deg,#c5a572,#b8935a);border-color:#c5a572;color:#fff}.delivery-option:disabled{cursor:not-allowed;opacity:.5}.preferences-actions{align-items:center;border-top:1px solid #eee;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}.save-message{border-radius:6px;flex:1 1;font-size:.9rem;font-weight:500;padding:.75rem}.save-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.save-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.notification-preferences-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:4rem 1rem}.notification-preferences-loading .spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#c5a572;height:40px;margin-bottom:1rem;width:40px}@media (max-width:768px){.notification-preferences-container{padding:1rem}.preferences-header h1{font-size:1.5rem}.delivery-options{flex-direction:column}.preferences-actions{flex-direction:column-reverse}.preferences-actions button{width:100%}.save-message{text-align:center;width:100%}}.admin-dashboard{margin:0 auto;max-width:1400px;padding:1.5rem}.admin-dashboard.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:2rem;margin:0 0 .5rem}.dashboard-subtitle{color:#666;color:var(--text-secondary,#666);font-size:1rem;margin:0}.quick-actions-section{margin-bottom:2rem}.quick-actions-section h2{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.25rem;margin-bottom:1rem}.quick-actions-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:1.5rem}.quick-action-card{padding:1.5rem!important}.quick-action-card.urgent{border-left:4px solid #dc3545;border-left:4px solid var(--danger,#dc3545)}.quick-action-content{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.quick-action-icon{font-size:2.5rem}.quick-action-info h3{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:2rem;margin:0 0 .25rem}.quick-action-info p{color:#666;color:var(--text-secondary,#666);font-size:.875rem;margin:0}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.stat-card{padding:1.5rem!important}.stat-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border,#e0e0e0);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.stat-header h2{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.25rem;margin:0}.stat-metrics{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.stat-metric{display:flex;flex-direction:column;gap:.25rem}.stat-metric.primary .metric-value{color:#06c;color:var(--primary,#06c);font-size:2.5rem;font-weight:700}.stat-metric.warning .metric-value{color:#ff9800;color:var(--warning,#ff9800)}.stat-metric.growth .metric-value{color:#28a745;color:var(--success,#28a745)}.metric-value{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.75rem;font-weight:600}.metric-label{color:#666;color:var(--text-secondary,#666);font-size:.875rem}.management-section{border-top:2px solid #e0e0e0;border-top:2px solid var(--border,#e0e0e0);margin-top:2rem;padding-top:2rem}.management-section h2{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.25rem;margin-bottom:1rem}.management-links{display:flex;flex-wrap:wrap;gap:1rem}@media (max-width:768px){.admin-dashboard{padding:1rem}.dashboard-header h1{font-size:1.5rem}.stat-metrics{grid-template-columns:1fr}.management-links{flex-direction:column}.management-links button{width:100%}}.user-management{margin:0 auto;max-width:1400px;padding:1.5rem}.user-management.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.page-header h1{margin:0 0 .5rem}.subtitle{color:#666;color:var(--text-secondary,#666);font-size:1rem}.filters-card{margin-bottom:1.5rem;padding:1rem!important}.filters{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.search-input{flex:1 1;min-width:250px}.filter-select,.search-input{border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:4px;font-size:1rem;padding:.75rem}.filter-select{background:#fff;min-width:150px}.users-table-card{overflow:hidden;padding:0!important}.users-table-wrapper{overflow-x:auto}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:#f5f5f5;background:var(--bg-secondary,#f5f5f5)}.users-table th{border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--border,#e0e0e0);color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.users-table td{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border,#e0e0e0);padding:1rem}.users-table tr:hover{background:#fafafa;background:var(--bg-hover,#fafafa)}.inactive-row{opacity:.6}.user-name{align-items:center;display:flex;gap:.75rem}.user-avatar{border-radius:50%;height:32px;object-fit:cover;width:32px}.role-badge,.status-badge{border-radius:12px;display:inline-block;font-size:.875rem;font-weight:500;padding:.25rem .75rem;white-space:nowrap}.role-badge{background:#f5f5f5;background:var(--bg-secondary,#f5f5f5);color:#1a1a1a;color:var(--text-primary,#1a1a1a)}.role-admin,.role-super_admin{background:#e3f2fd;color:#1565c0}.role-ministry_leader{background:#f3e5f5;color:#7b1fa2}.status-badge{background:#f5f5f5;background:var(--bg-secondary,#f5f5f5);color:#666;color:var(--text-secondary,#666)}.status-active{background:#e8f5e9;color:#2e7d32}.status-inactive{background:#fafafa;color:#757575}.status-suspended{background:#ffebee;color:#c62828}.action-buttons{display:flex;gap:.5rem}.action-btn{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:4px;cursor:pointer;font-size:1rem;padding:.5rem;transition:all .2s}.action-btn:hover:not(:disabled){background:#f5f5f5;background:var(--bg-secondary,#f5f5f5);transform:scale(1.1)}.action-btn:disabled{cursor:not-allowed;opacity:.5}.no-users{color:#666;color:var(--text-secondary,#666);padding:3rem;text-align:center}.modal{border-radius:8px;box-shadow:0 4px 20px #00000026;padding:2rem}.modal h2{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.5rem;margin:0 0 1rem}.modal p{color:#666;color:var(--text-secondary,#666);margin:0 0 1.5rem}.form-group{margin-bottom:1.5rem}.role-select{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:4px;font-size:1rem;padding:.75rem;width:100%}@media (max-width:768px){.user-management{padding:1rem}.page-header{flex-direction:column;gap:1rem}.page-header button{align-self:flex-start}.filters{align-items:stretch;flex-direction:column}.filter-select,.search-input{width:100%}.users-table{font-size:.875rem}.users-table td,.users-table th{padding:.75rem .5rem}.user-name{align-items:flex-start;flex-direction:column;gap:.5rem}.modal{padding:1.5rem}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.event-approval{margin:0 auto;max-width:1400px;padding:1.5rem}.event-approval.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.empty-state{padding:4rem 2rem!important}.empty-content{align-items:center;display:flex;flex-direction:column;gap:1rem;text-align:center}.empty-content h2{color:#1a1a1a;color:var(--text-primary,#1a1a1a);margin:0}.empty-content p{color:#666;color:var(--text-secondary,#666)}.pending-events-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.event-card{display:flex;flex-direction:column;gap:1rem;padding:1.5rem!important}.event-card-header{align-items:flex-start;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border,#e0e0e0);display:flex;gap:1rem;justify-content:space-between;padding-bottom:1rem}.event-card-header h3{color:#1a1a1a;color:var(--text-primary,#1a1a1a);flex:1 1;font-size:1.25rem;margin:0}.visibility-badge{border-radius:12px;display:inline-block;font-size:.875rem;font-weight:500;padding:.25rem .75rem;white-space:nowrap}.visibility-public{background:#e8f5e9;color:#2e7d32}.visibility-ministry{background:#f3e5f5;color:#7b1fa2}.visibility-private{background:#fff3e0;color:#e65100}.event-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{gap:.5rem}.detail-label{color:#666;color:var(--text-secondary,#666);font-weight:500;min-width:100px}.detail-value{color:#1a1a1a;color:var(--text-primary,#1a1a1a);flex:1 1}.event-description{border-top:1px solid #e0e0e0;border-top:1px solid var(--border,#e0e0e0);margin-top:.5rem;padding-top:.75rem}.event-description .detail-label{display:block;margin-bottom:.5rem}.event-description p{color:#1a1a1a;color:var(--text-primary,#1a1a1a);line-height:1.5;margin:0}.privacy-info{background:#f5f5f5;background:var(--bg-secondary,#f5f5f5);border-radius:4px;color:#666;color:var(--text-secondary,#666);font-size:.875rem;padding:.75rem}.privacy-info strong{color:#1a1a1a;color:var(--text-primary,#1a1a1a)}.event-actions{border-top:1px solid #e0e0e0;border-top:1px solid var(--border,#e0e0e0);display:flex;gap:1rem;margin-top:auto;padding-top:1rem}.event-actions button{flex:1 1}.rejection-textarea{border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:4px;font-family:inherit;font-size:1rem;padding:.75rem;resize:vertical;width:100%}.rejection-textarea:focus{border-color:#06c;border-color:var(--primary,#06c);outline:none}@media (max-width:768px){.event-approval{padding:1rem}.pending-events-grid{grid-template-columns:1fr}.event-card-header{align-items:flex-start}.event-actions,.event-card-header{flex-direction:column}.event-actions button{width:100%}}.admin-devotions{margin:0 auto;max-width:1200px;padding:2rem 1rem}.admin-devotions.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.page-header{gap:1rem;margin-bottom:2rem}.page-header h1{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:2rem;margin:0}.page-header .subtitle{color:#666;color:var(--text-secondary,#666);margin:.5rem 0 0}.devotions-list-card{margin-bottom:2rem}.devotions-list{display:flex;flex-direction:column;gap:1rem}.devotion-item{align-items:center;border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.devotion-item:hover{background-color:#f5f5f5;background-color:var(--bg-hover,#f5f5f5);border-color:#ccc;border-color:var(--border-hover,#ccc)}.devotion-thumbnail{align-items:center;background-color:#f0f0f0;background-color:var(--bg-secondary,#f0f0f0);border-radius:8px;display:flex;flex-shrink:0;height:60px;justify-content:center;overflow:hidden;width:60px}.devotion-thumbnail img{height:100%;object-fit:cover;width:100%}.devotion-icon-fallback{align-items:center;display:flex;font-size:2rem;justify-content:center}.devotion-info{flex:1 1;min-width:0}.devotion-info h3{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.1rem;margin:0 0 .25rem}.devotion-name-es{color:#666;color:var(--text-secondary,#666);display:block;font-size:.9rem;font-style:italic;margin:0 0 .5rem}.devotion-category{background-color:#e3f2fd;background-color:var(--bg-badge,#e3f2fd);border-radius:12px;color:#1976d2;color:var(--text-badge,#1976d2);display:inline-block;font-size:.85rem;padding:.25rem .75rem;text-transform:capitalize}.modal-overlay{background-color:#00000080}.devotion-edit-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:100%}.modal-header{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);padding:1.5rem}.modal-header h2{font-size:1.5rem}.modal-close{border-radius:4px;color:#666;color:var(--text-secondary,#666);font-size:2rem;height:32px;line-height:1;transition:all .2s ease;width:32px}.modal-close:hover{background-color:#f5f5f5;background-color:var(--bg-hover,#f5f5f5);color:#1a1a1a;color:var(--text-primary,#1a1a1a)}.modal-content{flex:1 1;overflow-y:auto}.modal-actions{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color,#e0e0e0);padding:1.5rem}.form-section{margin-bottom:2rem}.form-section:last-child{margin-bottom:0}.form-section h3{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.2rem;margin:0 0 1rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.section-header h3{margin:0}.thumbnail-upload{align-items:center;display:flex;gap:1rem}.thumbnail-preview{align-items:center;background-color:#f0f0f0;background-color:var(--bg-secondary,#f0f0f0);border:2px solid #e0e0e0;border:2px solid var(--border-color,#e0e0e0);border-radius:8px;display:flex;height:100px;justify-content:center;overflow:hidden;width:100px}.thumbnail-preview img{height:100%;object-fit:cover;width:100%}.thumbnail-placeholder{align-items:center;display:flex;font-size:3rem;justify-content:center}.form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1/-1}.form-group label{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:.9rem}.form-input,.form-select,.form-textarea{border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:6px;font-family:inherit;font-size:1rem;padding:.75rem;transition:all .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#c5a572;border-color:var(--primary-color,#c5a572);box-shadow:0 0 0 3px #c5a5721a;outline:none}.form-textarea{min-height:60px}.prayers-list{gap:1.5rem}.no-prayers{background-color:#f5f5f5;background-color:var(--bg-secondary,#f5f5f5);border-radius:8px;color:#666;color:var(--text-secondary,#666)}.prayer-item{background-color:#f9f9f9;background-color:var(--bg-secondary,#f9f9f9);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px}.prayer-header{align-items:center}.prayer-number{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-weight:600}.remove-prayer-btn{background:none;border:none;border-radius:4px;color:#666;color:var(--text-secondary,#666);cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem .5rem;transition:all .2s ease}.error-message,.remove-prayer-btn:hover{background-color:#ffebee;background-color:var(--error-bg,#ffebee);color:#d32f2f;color:var(--error-color,#d32f2f)}.error-message,.success-message{border-radius:6px;margin-top:1rem}.success-message{background-color:#e8f5e9;background-color:var(--success-bg,#e8f5e9);color:#2e7d32;color:var(--success-color,#2e7d32)}.expanded-sections{border-top:2px solid #e0e0e0;border-top:2px solid var(--border-color,#e0e0e0);margin-top:2rem;padding-top:2rem}.expanded-header{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.3rem;margin:0 0 .5rem}.expanded-subtitle{color:#666;color:var(--text-secondary,#666);font-size:.9rem;margin:0 0 1.5rem}.collapsible-section{border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;margin-bottom:.75rem;overflow:hidden}.section-toggle{align-items:center;background:#f9f9f9;background:var(--bg-secondary,#f9f9f9);border:none;color:#1a1a1a;color:var(--text-primary,#1a1a1a);cursor:pointer;display:flex;font-size:1rem;font-weight:500;justify-content:space-between;padding:1rem;transition:background-color .2s ease;width:100%}.section-toggle:hover{background:#f0f0f0;background:var(--bg-hover,#f0f0f0)}.toggle-icon{color:#666;color:var(--text-secondary,#666);font-size:1.25rem;font-weight:300}.section-content{background:#fff;border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color,#e0e0e0);padding:1rem}.section-content>button{margin-bottom:1rem}.array-item{background:#f9f9f9;background:var(--bg-secondary,#f9f9f9);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;margin-top:1rem;padding:1rem}.item-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.5rem}.item-header span{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-weight:600}.remove-btn{background:none;border:none;border-radius:4px;color:#666;color:var(--text-secondary,#666);cursor:pointer;font-size:1.25rem;line-height:1;padding:.25rem .5rem;transition:all .2s ease}.remove-btn:hover{background-color:#ffebee;background-color:var(--error-bg,#ffebee);color:#d32f2f;color:var(--error-color,#d32f2f)}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media (max-width:600px){.form-row{grid-template-columns:1fr}}@media (max-width:768px){.page-header{flex-direction:column}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:1}.devotion-item{flex-wrap:wrap}.devotion-info{flex-basis:calc(100% - 140px);flex-grow:1;flex-shrink:1}.devotion-edit-modal{max-height:95vh}.thumbnail-upload{align-items:flex-start;flex-direction:column}}.admin-prayers{margin:0 auto;max-width:1000px;padding:1.5rem 1.5rem 100px}.admin-prayers.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:50vh}.admin-prayers .spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-top-color:#c9a227;border:3px solid var(--border,#e2e8f0);border-radius:50%;border-top-color:var(--gold,#c9a227);height:40px;width:40px}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{color:#1e3a5f;color:var(--text-primary,#1e3a5f);margin:0 0 .25rem}.subtitle{color:#64748b;color:var(--text-secondary,#64748b);margin:0}.filter-card{margin-bottom:1.5rem}.filter-tabs{gap:.5rem}.filter-tab{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:8px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.filter-tab:hover{color:#c9a227;color:var(--gold,#c9a227)}.filter-tab.active,.filter-tab:hover{border-color:#c9a227;border-color:var(--gold,#c9a227)}.filter-tab.active{background:#c9a227;background:var(--gold,#c9a227);color:#fff}.error-message{background:#fef2f2;color:#dc2626}.error-message,.success-message{border-radius:8px;margin-bottom:1rem;padding:1rem}.success-message{background:#f0fdf4;color:#16a34a}.prayers-list-card{overflow:hidden;padding:0}.prayers-list{display:flex;flex-direction:column}.prayer-item{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border,#e2e8f0);padding:1.5rem}.prayer-item:last-child{border-bottom:none}.prayer-item.status-pending{background:#fffbeb}.prayer-item.status-approved{background:#f0fdf4}.prayer-item.status-rejected{background:#fef2f2}.prayer-header{margin-bottom:1rem}.prayer-meta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.devotion-badge{align-items:center;background:#1e3a5f1a;border-radius:20px;color:#1e3a5f;color:var(--text-primary,#1e3a5f);display:inline-flex;font-size:.75rem;gap:.25rem;padding:.25rem .75rem}.devotion-badge .icon{font-size:.875rem}.status-badge{border-radius:20px;display:inline-block;font-size:.75rem;padding:.25rem .75rem}.prayer-info h3{color:#1e3a5f;color:var(--text-primary,#1e3a5f);font-size:1.1rem;margin:0 0 .25rem}.submitted-by{color:#64748b;color:var(--text-secondary,#64748b);font-size:.875rem;margin:0}.prayer-content{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:8px;margin-bottom:1rem;padding:1rem}.prayer-content p{color:#475569;color:var(--text-primary,#475569);line-height:1.6;margin:0;white-space:pre-wrap}.rejection-info{background:#fee2e2;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.prayer-actions{display:flex;gap:.75rem}.empty-state{color:#64748b;color:var(--text-secondary,#64748b);padding:3rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border,#e2e8f0);display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.modal-header h2{color:#1e3a5f;color:var(--text-primary,#1e3a5f);font-size:1.25rem;margin:0}.modal-close{align-items:center;background:none;border:none;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:flex;font-size:1.5rem;height:2rem;justify-content:center;padding:0;width:2rem}.modal-close:hover{color:#1e3a5f;color:var(--text-primary,#1e3a5f)}.modal-content{padding:1.5rem}.reject-warning{color:#475569;color:var(--text-secondary,#475569);line-height:1.6;margin:0 0 1.5rem}.form-group label{color:#1e3a5f;color:var(--text-primary,#1e3a5f)}.form-textarea{border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:8px;box-sizing:border-box;font-size:1rem;min-height:100px;padding:.75rem;width:100%}.form-textarea:focus{border-color:#c9a227;border-color:var(--gold,#c9a227);outline:none}.modal-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--border,#e2e8f0);display:flex;gap:1rem;justify-content:flex-end;padding:1rem 1.5rem}@media (max-width:768px){.page-header{gap:1rem}.page-header,.prayer-actions{flex-direction:column}.prayer-actions button{width:100%}.modal-actions{flex-direction:column}}.admin-ministries{margin:0 auto;max-width:1200px;padding:24px 16px 100px}.admin-ministries.loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:50vh}.admin-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.admin-header-left{align-items:center;display:flex;gap:16px}.back-btn{color:var(--primary);font-size:1rem;padding:8px 0}.back-btn:hover{text-decoration:underline}.admin-header h1{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.message{align-items:center;border-radius:8px;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.message.success{background:#d1fae5;border:1px solid #86efac;color:#065f46}.message.error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.message button{background:none;border:none;cursor:pointer;font-size:1.25rem;opacity:.7}.message button:hover{opacity:1}.filters-row{align-items:center;gap:16px;justify-content:space-between;margin-bottom:24px}.filter-tabs,.filters-row{display:flex;flex-wrap:wrap}.filter-tabs{gap:8px}.filter-tabs button{background:#fff;border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);cursor:pointer;font-size:.85rem;padding:8px 16px;transition:all .2s}.filter-tabs button:hover{border-color:var(--primary);color:var(--primary)}.filter-tabs button.active{background:var(--primary);border-color:var(--primary);color:#fff}.search-input{width:250px}.ministries-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:24px}.ministry-card{padding:16px}.ministry-card-header{gap:16px;margin-bottom:12px}.ministry-badge-preview{background:var(--bg-secondary);border-radius:50%;flex-shrink:0;height:60px;overflow:hidden;width:60px}.badge-preview-img{height:100%;object-fit:contain;width:100%}.badge-fallback-preview{align-items:center;background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);border-radius:50%;display:flex;font-size:1.5rem;height:100%;justify-content:center;width:100%}.ministry-card-info{flex:1 1;min-width:0}.ministry-type-badge{background:var(--bg-secondary);border-radius:4px;color:var(--text-muted);display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.5px;margin-bottom:4px;padding:2px 8px;text-transform:uppercase}.ministry-card-info h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 4px}.ministry-name-en{color:var(--text-muted);font-size:.8rem;font-style:italic;margin:0}.ministry-card-details{border-bottom:1px solid var(--border-light);border-top:1px solid var(--border-light);margin-bottom:12px;padding:12px 0}.detail-row{display:flex;font-size:.85rem;gap:8px;margin-bottom:4px}.detail-row:last-child{margin-bottom:0}.detail-label{color:var(--text-muted);flex-shrink:0}.detail-value{color:var(--text-primary)}.badge-upload-form,.ministry-card-actions{display:flex;gap:8px}.badge-upload-form{flex-direction:column;width:100%}.badge-upload-form input[type=file]{font-size:.85rem}.empty-state{color:var(--text-muted);padding:48px 24px;text-align:center}.instructions-card{background:var(--bg-secondary);margin-top:32px;padding:20px}.instructions-card h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 12px}.instructions-card ul{margin:0 0 16px;padding-left:20px}.instructions-card li{color:var(--text-secondary);font-size:.9rem;margin-bottom:4px}.badge-folders{border-top:1px solid var(--border);padding-top:12px}.badge-folders h4{color:var(--text-primary);font-size:.9rem;font-weight:600;margin:0 0 8px}.badge-folders code{background:#fff;border-radius:4px;color:var(--primary);display:inline-block;font-size:.8rem;margin-right:4px;padding:2px 6px}@media (max-width:768px){.admin-ministries{padding:16px 12px 80px}.filters-row{align-items:stretch;flex-direction:column}.filter-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto;padding-bottom:8px}.search-input{width:100%}.ministries-grid{grid-template-columns:1fr}.ministry-card-header{align-items:center;flex-direction:column;text-align:center}.ministry-type-badge{align-self:center}}.devotion-detail-page{background:#fff;background:var(--bg,#fff);min-height:100vh;padding-bottom:100px}.devotion-detail-page.error,.devotion-detail-page.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:2rem}.devotion-detail-page .spinner{animation:spin .8s linear infinite;border:2px solid #dbdbdb;border-top-color:#c9a227;border:2px solid var(--border,#dbdbdb);border-radius:50%;border-top-color:var(--gold,#c9a227);height:32px;margin-bottom:1rem;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.error-card{background:#fff;border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:8px;padding:2rem;text-align:center}.devotion-hero-header{background:#fff;border-bottom:1px solid #dbdbdb;border-bottom:1px solid var(--border,#dbdbdb);padding:1rem}.back-btn{align-items:center;background:none;border:none;color:#262626;color:var(--text,#262626);cursor:pointer;display:flex;font-size:1.5rem;margin:-.5rem -.5rem 1rem;padding:.5rem}.back-btn:hover{color:#c9a227;color:var(--gold,#c9a227)}.hero-content{align-items:center;display:flex;gap:1rem}.devotion-hero-photo{border:2px solid #c9a227;border:2px solid var(--gold,#c9a227);border-radius:50%;height:80px;object-fit:cover;width:80px}.devotion-hero-icon{align-items:center;background:linear-gradient(135deg,#c9a227,#d4af37);background:linear-gradient(135deg,var(--gold,#c9a227) 0,#d4af37 100%);border-radius:50%;display:flex;flex-shrink:0;font-size:2.5rem;height:80px;justify-content:center;width:80px}.hero-info{flex:1 1;min-width:0}.devotion-title{color:#262626;color:var(--text,#262626);font-size:1.25rem;font-weight:600;line-height:1.3;margin:0 0 .25rem}.devotion-title-es{font-size:.875rem;font-style:italic;margin:0 0 .5rem}.category-badge,.devotion-title-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e)}.category-badge{background:#fafafa;background:var(--bg-secondary,#fafafa);border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:20px;display:inline-block;font-size:.75rem;padding:.25rem .75rem;text-transform:capitalize}.tab-navigation{background:#fff;border-bottom:1px solid #dbdbdb;border-bottom:1px solid var(--border,#dbdbdb);position:-webkit-sticky;position:sticky;top:0;z-index:100}.tab-scroll{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;display:flex;overflow-x:auto;scrollbar-width:none}.tab-scroll::-webkit-scrollbar{display:none}.tab-btn{background:none;border:none;border-bottom:2px solid #0000;color:#8e8e8e;color:var(--text-secondary,#8e8e8e);cursor:pointer;flex-shrink:0;font-size:.875rem;font-weight:500;padding:1rem 1.25rem;transition:all .2s ease}.tab-btn.active,.tab-btn:hover{color:#262626;color:var(--text,#262626)}.tab-btn.active{border-bottom-color:#262626;border-bottom-color:var(--text,#262626)}.tab-content{padding:1rem}.content-section{background:#fff;border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:8px;margin-bottom:1rem;overflow:hidden}.content-section:first-child{background:#0000;border:none;margin-bottom:1.5rem}.description-text{color:#262626;color:var(--text,#262626);font-size:1rem;line-height:1.6;margin:0 0 .75rem}.description-text-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.9rem;font-style:italic;line-height:1.5;margin:0}.section-header-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;padding:1rem;text-align:left;width:100%}.section-header-btn h2{color:#262626;color:var(--text,#262626);font-size:1rem;font-weight:600;margin:0}.expand-icon{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:1.25rem;font-weight:300}.section-body{border-top:1px solid #efefef;border-top:1px solid var(--border-light,#efefef);padding:0 1rem 1rem}.history-text{color:#262626;color:var(--text,#262626);font-size:.9375rem;line-height:1.7;margin:1rem 0 .75rem}.history-text-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.875rem;font-style:italic;line-height:1.6;margin:0}.apparition-card{border-bottom:1px solid #efefef;border-bottom:1px solid var(--border-light,#efefef);padding:1rem 0}.apparition-card:first-child{padding-top:1rem}.apparition-card:last-child{border-bottom:none;padding-bottom:0}.apparition-header{align-items:baseline;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.5rem}.apparition-header h3{color:#262626;color:var(--text,#262626);font-size:.9375rem;font-weight:600;margin:0}.apparition-date{color:#c9a227;color:var(--gold,#c9a227);font-size:.8125rem;font-weight:500;white-space:nowrap}.apparition-card p{color:#262626;color:var(--text,#262626);font-size:.875rem;line-height:1.6;margin:0}.text-es{color:#8e8e8e!important;color:var(--text-secondary,#8e8e8e)!important;font-style:italic;margin-top:.5rem!important}.saints-grid{grid-gap:1rem;display:grid;gap:1rem;padding-top:1rem}.saint-card{background:#fafafa;background:var(--bg-secondary,#fafafa);border-radius:8px;padding:1rem}.saint-card h3{color:#262626;color:var(--text,#262626);font-size:.9375rem;font-weight:600;margin:0 0 .25rem}.saint-name-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.8125rem;font-style:italic;margin:0 0 .25rem}.saint-years{color:#c9a227;color:var(--gold,#c9a227);font-size:.8125rem;font-weight:500;margin:0 0 .5rem}.saint-role{color:#262626;color:var(--text,#262626);font-size:.875rem;line-height:1.5;margin:0 0 .75rem}.saint-feast{display:flex;font-size:.8125rem;gap:.5rem}.feast-label{color:#8e8e8e;color:var(--text-secondary,#8e8e8e)}.feast-date{color:#262626;color:var(--text,#262626);font-weight:500}.practice-card{border-bottom:1px solid #efefef;border-bottom:1px solid var(--border-light,#efefef);padding:1rem 0}.practice-card:first-child{padding-top:1rem}.practice-card:last-child{border-bottom:none;padding-bottom:0}.practice-card h3{font-size:.9375rem;font-weight:600;margin:0 0 .5rem}.practice-card h3,.practice-card p{color:#262626;color:var(--text,#262626)}.practice-card p{font-size:.875rem;line-height:1.6;margin:0}.feast-card{border-bottom:1px solid #efefef;border-bottom:1px solid var(--border-light,#efefef);padding:1rem 0}.feast-card:first-child{padding-top:1rem}.feast-card:last-child{border-bottom:none;padding-bottom:0}.feast-card h3{color:#262626;color:var(--text,#262626);font-size:.9375rem;font-weight:600;margin:0 0 .25rem}.feast-name-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.8125rem;font-style:italic;margin:0 0 .25rem}.feast-date-rule{color:#262626;color:var(--text,#262626);font-size:.875rem;margin:0 0 .5rem}.liturgical-rank{background:#c9a227;background:var(--gold,#c9a227);border-radius:4px;color:#fff;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.promises-content{margin:0 auto;max-width:600px}.promises-intro{margin-bottom:1.5rem;text-align:center}.promises-intro h2{color:#262626;color:var(--text,#262626);font-size:1.25rem;margin:0 0 .5rem}.promises-intro p{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.875rem;margin:0}.promises-list{display:flex;flex-direction:column;gap:.75rem}.promise-card{background:#fff;border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:8px;display:flex;gap:1rem;padding:1rem}.promise-number{align-items:center;background:linear-gradient(135deg,#c9a227,#d4af37);background:linear-gradient(135deg,var(--gold,#c9a227) 0,#d4af37 100%);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:32px;justify-content:center;width:32px}.promise-text{flex:1 1}.promise-text p{color:#262626;color:var(--text,#262626);font-size:.9375rem;line-height:1.6;margin:0}.promise-text .text-es{font-size:.875rem}.prayers-content{margin:0 auto;max-width:600px}.add-prayer-header{margin-bottom:1rem}.prayer-form{background:#fff;border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.form-intro{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.875rem;line-height:1.5;margin:0 0 1rem}.form-group{margin-bottom:1rem}.form-group label{color:#262626;color:var(--text,#262626);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-input,.form-textarea{background:#fafafa;background:var(--bg-secondary,#fafafa);border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:6px;box-sizing:border-box;color:#262626;color:var(--text,#262626);font-size:.9375rem;padding:.75rem;transition:border-color .2s ease,background-color .2s ease;width:100%}.form-input:focus,.form-textarea:focus{background:#fff;border-color:#262626;border-color:var(--text,#262626);outline:none}.form-textarea{font-family:inherit;line-height:1.5;min-height:120px;resize:vertical}.form-error{background:#fef2f2;color:#dc2626}.form-error,.form-success{border-radius:6px;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.form-success{background:#f0fdf4;color:#16a34a}.form-actions{display:flex;justify-content:flex-end}.prayers-section{margin-bottom:1.5rem}.prayers-section h3{color:#262626;color:var(--text,#262626);font-size:1rem;font-weight:600;margin:0 0 1rem}.prayer-card{background:#fff;border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:8px;margin-bottom:.75rem;padding:1rem}.prayer-card h4{color:#262626;color:var(--text,#262626);font-size:.9375rem;font-weight:600;margin:0 0 .25rem}.prayer-title-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.8125rem;font-style:italic;margin:0 0 .75rem}.prayer-text-container{margin-top:.75rem}.prayer-text{color:#262626;color:var(--text,#262626);font-size:.9375rem;line-height:1.7;margin:0;white-space:pre-wrap}.litany-es-details,.prayer-es-details{margin-top:1rem}.litany-es-details summary,.prayer-es-details summary{color:#c9a227;color:var(--gold,#c9a227);cursor:pointer;font-size:.875rem;font-weight:500}.prayer-text-es{font-style:italic;margin-top:.75rem}.no-prayers,.prayer-text-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e)}.no-prayers{font-size:.9375rem;padding:2rem;text-align:center}.user-prayers-section{background:#fef9c3;border-radius:8px;margin-top:1.5rem;padding:1rem}.user-prayers-section h3{color:#262626;color:var(--text,#262626);font-size:1rem;font-weight:600;margin:0 0 .25rem}.section-subtitle{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.8125rem;margin:0 0 1rem}.user-prayer{background:#fff}.user-prayer.pending{border-left:3px solid #f59e0b}.user-prayer.approved{border-left:3px solid #22c55e}.user-prayer.rejected{border-left:3px solid #ef4444}.prayer-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.5rem}.prayer-header h4{flex:1 1;margin:0}.status-badge{border-radius:4px;font-size:.6875rem;font-weight:500;letter-spacing:.025em;padding:.25rem .5rem;text-transform:uppercase}.status-badge.pending{background:#fef3c7;color:#d97706}.status-badge.approved{background:#dcfce7;color:#16a34a}.rejection-reason,.status-badge.rejected{background:#fee2e2;color:#dc2626}.rejection-reason{border-radius:4px;font-size:.8125rem;font-style:italic;margin:.75rem 0 0;padding:.5rem}.litanies-content{margin:0 auto;max-width:600px}.litany-card{background:#fff;border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:8px;margin-bottom:1rem;padding:1rem}.litany-card h3{color:#262626;color:var(--text,#262626);font-size:1rem;font-weight:600;margin:0 0 .25rem}.litany-title-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.8125rem;font-style:italic;margin:0 0 1rem}.litany-text{background:#fafafa;background:var(--bg-secondary,#fafafa);border-radius:6px;max-height:400px;overflow-y:auto;padding:1rem}.litany-text pre{color:#262626;color:var(--text,#262626);font-family:inherit;font-size:.875rem;line-height:1.8;margin:0;white-space:pre-wrap}.novenas-content{margin:0 auto;max-width:600px}.novena-card{background:#fff;border:1px solid #dbdbdb;border:1px solid var(--border,#dbdbdb);border-radius:8px;margin-bottom:1rem;padding:1rem}.novena-card h3{color:#262626;color:var(--text,#262626);font-size:1rem;font-weight:600;margin:0 0 .25rem}.novena-title-es{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);font-size:.8125rem;font-style:italic;margin:0 0 1rem}.novena-structure,.novena-when{margin-bottom:.75rem}.novena-structure strong,.novena-when strong{color:#8e8e8e;color:var(--text-secondary,#8e8e8e);display:block;font-size:.8125rem;margin-bottom:.25rem}.novena-structure p,.novena-when p{color:#262626;color:var(--text,#262626);font-size:.9375rem;line-height:1.5;margin:0}@media (max-width:600px){.devotion-hero-header{padding:.75rem}.devotion-hero-icon,.devotion-hero-photo{height:64px;width:64px}.devotion-hero-icon{font-size:2rem}.devotion-title{font-size:1.125rem}.tab-btn{font-size:.8125rem;padding:.875rem 1rem}.tab-content{padding:.75rem}.saints-grid{grid-template-columns:1fr}.promise-card{padding:.75rem}.promise-number{font-size:.8125rem;height:28px;width:28px}}.ministries-page{margin:0 auto;max-width:1200px;padding:1rem}.ministries-page.loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:50vh}.ministries-page .page-header{margin-bottom:2rem;text-align:center}.ministries-page .page-header h1{color:var(--text-primary);font-size:2rem;margin-bottom:.5rem}.ministries-page .subtitle{color:var(--text-secondary);font-size:1rem;margin:0}.ministries-content{display:flex;flex-direction:column;gap:3rem}.ministry-group{display:flex;flex-direction:column;gap:1rem}.group-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;gap:.75rem;padding-bottom:.75rem}.group-icon{font-size:1.75rem}.group-header h2{color:var(--text-primary);flex:1 1;font-size:1.5rem;margin:0}.group-count{color:var(--text-secondary);font-size:.9rem;font-weight:500}.ministries-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.ministry-card{cursor:pointer;display:flex;flex-direction:column;gap:.75rem;min-height:160px;transition:all .2s ease}.ministry-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.ministry-card-header{align-items:center;display:flex;gap:.75rem}.ministry-badge-img{object-fit:cover}.ministry-badge-fallback,.ministry-badge-img{border-radius:50%;flex-shrink:0;height:40px;width:40px}.ministry-badge-fallback{align-items:center;background:var(--background-secondary);display:flex;font-size:1.25rem;justify-content:center}.ministry-card-header h3{color:var(--primary-color);flex:1 1;font-size:1.1rem;margin:0}.privacy-badge{background:var(--secondary-color);border-radius:12px;color:#fff;font-size:.75rem;padding:.25rem .5rem;white-space:nowrap}.ministry-description{color:var(--text-secondary);flex:1 1;font-size:.9rem;line-height:1.4;margin:0}.ministry-schedule{align-items:center;background:var(--background-secondary);border-radius:6px;color:var(--text-secondary);display:flex;font-size:.85rem;gap:.5rem;padding:.5rem}.schedule-icon{font-size:1rem}.schedule-text{flex:1 1}.ministry-card-footer{border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;padding-top:.5rem}.view-details{color:var(--primary-color);font-size:.9rem;font-weight:500}.empty-state .empty-content{padding:3rem 2rem;text-align:center}.empty-icon{display:block;font-size:4rem;margin-bottom:1rem}.empty-content h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:.5rem}.empty-content p{color:var(--text-secondary);font-size:1rem;margin:0}@media (max-width:768px){.ministries-page{padding:.75rem}.ministries-page .page-header h1{font-size:1.5rem}.ministries-grid{grid-template-columns:1fr}.group-header h2{font-size:1.25rem}.ministries-content{gap:2rem}}.leader-profile{align-items:center;background:var(--background-secondary);border-radius:8px;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.leader-profile:hover{background:#fff;box-shadow:0 2px 8px #0000001a;transform:translateX(4px)}.leader-avatar{border-radius:50%;flex-shrink:0;height:48px;overflow:hidden;width:48px}.leader-avatar img{height:100%;object-fit:cover;width:100%}.leader-avatar-placeholder{align-items:center;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;display:flex;font-size:1.1rem;font-weight:600;height:100%;justify-content:center;width:100%}.leader-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.leader-name{color:var(--text-primary);font-size:1rem;font-weight:600}.leader-role{color:var(--text-secondary);font-size:.85rem}.leader-arrow{color:var(--primary-color);font-size:1.25rem;opacity:0;transition:opacity .2s ease}.leader-profile:hover .leader-arrow{opacity:1}@media (max-width:768px){.leader-profile{padding:.75rem}.leader-avatar{height:40px;width:40px}}.ministry-detail{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:900px;padding:1rem}.ministry-detail.loading{align-items:center;justify-content:center;min-height:50vh}.ministry-detail .page-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.edit-actions{display:flex;gap:.5rem}.ministry-info-card{display:flex;flex-direction:column;gap:1rem}.ministry-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.ministry-header h1{color:var(--primary-color);font-size:2rem;margin:0 0 .25rem}.ministry-subtitle{color:var(--text-secondary);font-size:1.1rem;font-style:italic;margin:0}.type-badge{background:var(--primary-color);border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;padding:.5rem 1rem;white-space:nowrap}.ministry-main-description{color:var(--text-primary);font-size:1.1rem;line-height:1.6;margin:0}.ministry-spanish-description{color:var(--text-secondary);font-size:1rem;font-style:italic;line-height:1.5;margin:0}.privacy-notice{align-items:center;background:var(--background-secondary);border-left:3px solid var(--secondary-color);border-radius:4px;color:var(--text-secondary);display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem}.privacy-icon{font-size:1.25rem}.schedule-card h2{color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem}.schedule-text{color:var(--text-primary);font-size:1rem;line-height:1.6;margin:0}.schedule-input{border:1px solid var(--border-color);border-radius:6px;font-family:inherit;font-size:1rem;padding:.75rem;resize:vertical;width:100%}.schedule-input:focus{border-color:var(--primary-color);outline:none}.about-card h2{color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem}.about-content{color:var(--text-primary);font-size:1rem;line-height:1.7}.about-text{margin:0;white-space:pre-wrap}.about-empty{color:var(--text-secondary);font-style:italic;margin:0}.about-input{border:1px solid var(--border-color);border-radius:6px;font-family:inherit;font-size:1rem;line-height:1.6;min-height:200px;padding:.75rem;resize:vertical;width:100%}.about-input:focus{border-color:var(--primary-color);outline:none}.leaders-card h2{color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem}.profile-section{margin-bottom:1.5rem}.profile-section:last-child{margin-bottom:0}.profile-section-title{border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-size:1rem;font-weight:600;margin:0 0 .75rem;padding-bottom:.5rem}.leaders-profiles{display:flex;flex-direction:column;gap:.75rem}.leaders-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.leaders-loading p{color:var(--text-secondary);margin:0}.error-state{padding:3rem 2rem;text-align:center}.error-state h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.error-state p{color:var(--text-secondary);font-size:1rem;margin-bottom:1.5rem}@media (max-width:768px){.ministry-detail{padding:.75rem}.ministry-header{align-items:flex-start;flex-direction:column}.ministry-header h1{font-size:1.5rem}.type-badge{align-self:flex-start}.page-header{align-items:stretch;flex-direction:column}.edit-actions{width:100%}.edit-actions button{flex:1 1}}:root{--primary:#1e3a5f;--primary-light:#2d5a8a;--gold:#c9a227;--gold-light:#e6c55a;--bg:#fff;--bg-secondary:#fafafa;--surface:#fff;--text:#262626;--text-primary:#262626;--text-secondary:#8e8e8e;--text-muted:#8e8e8e;--border:#dbdbdb;--border-light:#efefef;--shadow:0 1px 3px #00000014;--shadow-elevated:0 4px 12px #00000026}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;background:var(--bg);color:#262626;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0}.app{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1 1;padding-bottom:calc(70px + env(safe-area-inset-bottom));padding-top:env(safe-area-inset-top)}.loading-screen{align-items:center;color:#8e8e8e;color:var(--text-muted);display:flex;font-size:1.125rem;justify-content:center;min-height:100vh}.page-container{min-height:calc(100vh - 70px);padding:24px}@media (max-width:768px){.app-main{padding-bottom:calc(60px + env(safe-area-inset-bottom))}.page-container{padding:16px}}
/*# sourceMappingURL=main.4738bdcd.css.map*/