/* Sticky Footer using Flexbox - works dynamically on all pages */

.activity-th { background-color: #283754; }
.add-to-cart-btn { background: #3b82f6; color: white; border: none; border-radius: 8px; padding: 12px; font-size: 0.95em; font-weight: 600; cursor: pointer; transition: all 0.2s ease; width: 120px; display: block; text-align: center; box-sizing: border-box; }
.add-to-cart-btn:active { transform: scale(0.98); }
.add-to-cart-btn:hover { background: #2563eb; transform: scale(1.05); }
.baby-blue { color: #BFDBF7; }
.back-link { display: inline-flex; align-items: center; gap: 0.5rem; color: #64748b; text-decoration: none; font-size: 0.9rem; margin-bottom: 1.25rem; transition: color 0.2s; }
.back-link:hover { color: #3b82f6; text-decoration: none; }
.badge-active { background: linear-gradient(135deg, #10b981 0%, #059669 100%); color: white; }
.badge-completed { background: #94a3b8; color: white; }
.bg-baby-blue { background-color: #BFDBF7; color: #fff; }
.bg-gray { background-color: #f0f0f0; }
.bg-navy { background-color: #202A44; color: #fff; }
.bg-yellow { background-color: #FAAE4C; }
.breakdown-divider { margin: 0 0.5rem; color: #cbd5e1; }
.breakdown-item { display: inline; }
.btn-baby-blue { background-color: #BFDBF7; color: #202A44; border-radius: 30px; font-weight: 700; font-size: 20px; padding: 10px 40px; }
.btn-baby-blue-auto { background-color: #BFDBF7; color: #202A44; border-radius: 30px; font-weight: 700; font-size: 18px; padding: 10px 30px; display: inline-block; width: auto; }
.btn-baby-blue-auto:hover { color: #fff; }
.btn-baby-blue:hover { color: #fff; }
.btn-cancel { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.btn-cancel:hover { background: #fee2e2; color: #b91c1c; text-decoration: none; }
.btn-copy { background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0; }
.btn-copy-large { padding: 0.75rem 1.5rem; font-size: 1rem; }
.btn-copy.copied { background: #166534; color: white; border-color: #166534; }
.btn-copy:hover { background: #dcfce7; color: #14532d; text-decoration: none; }
.btn-donors { background: #f1f5f9; color: #475569; border: 1px solid #e2e8f0; }
.btn-donors:hover { background: #e2e8f0; color: #1e293b; text-decoration: none; }
.btn-email { background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); color: white; }
.btn-email:hover { background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%); color: white; text-decoration: none; transform: translateY(-1px); }
.btn-group-toggle .btn-outline-primary { height: 60px; width: 70px; margin-right: 9px; padding: 0; padding-top: 12px; border-radius: .25rem; background-color: #e9ecef; border: solid #ccc 1px; color: #053c79; font-size: 23px; font-weight: 600; }
.btn-group-toggle>.btn, .btn-group-toggle>.btn-group>.btn { margin-bottom: 9px; }
.btn-group>.btn-group:not(:first-child)>.btn, .btn-group>.btn:not(:first-child) { border-radius: .25rem; }
.btn-group>.btn-group:not(:last-child)>.btn, .btn-group>.btn:not(:last-child):not(.dropdown-toggle) { border-radius: .25rem; }
.btn-info { color: #fff; background-color: #283754; border-color: #283754; }
.btn-modern { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.6rem 1.25rem; border-radius: 8px; font-size: 0.875rem; font-weight: 600; text-decoration: none; transition: all 0.2s ease; border: none; cursor: pointer; }
.btn-navy { background-color: #202A44; color: #fff; border-radius: 30px; font-weight: 700; font-size: 20px; padding: 10px 40px; }
.btn-navy:hover { color: #BFDBF7; }
.btn-secondary { color: #fff; background-color: #283754; border-color: #283754; }
.btn-text { background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%); color: white; }
.btn-text:hover { background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%); color: white; text-decoration: none; transform: translateY(-1px); }
.btn-view-all { display: inline-flex; align-items: center; gap: 0.5rem; background: #f1f5f9; border: none; padding: 0.625rem 1.25rem; border-radius: 8px; color: #3b82f6; font-weight: 600; font-size: 0.9rem; cursor: pointer; transition: all 0.2s; }
.btn-view-all:hover { background: #e2e8f0; }
.btn-white { background-color: transparent; color: #fff; border-color: #fff; border-radius: 30px; font-weight: 700; font-size: 20px; padding: 10px 40px; }
.btn-white:hover { background-color: #fff; color: #202A44; }
.btnSub { background: #007bff; color: #ffffff; font-family: Arial, sans-serif; border-radius: 0 0 4px 4px; border: 0; padding: 12px 16px; font-size: 16px; font-weight: 600; cursor: pointer; display: block; transition: all 0.2s ease; box-shadow: 0px 4px 5.5px 0px rgba(0, 0, 0, 0.07); width: 100%; }
.btnSub:disabled { background-color: gray; cursor: default; }
.btnSub:hover { filter: contrast(115%); }
.buy-now { width: auto; }
body { min-height: 100%; display: flex; flex-direction: column; }
.calendar-container { max-width: 1200px; margin: 0 auto; padding: 20px; background: white; border-radius: 16px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); }
.calendar-container h2 { text-align: center; font-size: 2.5em; margin-bottom: 40px; color: #1a1a1a; font-weight: 700; }
.calendar-day { background: #ffffff; border: 2px solid #e5e7eb; border-radius: 12px; padding: 24px 16px; min-height: 160px; display: flex; flex-direction: column; align-items: center; justify-content: space-between; transition: all 0.3s ease; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06); }
.calendar-day.purchased { background: #f8fafc; border-color: #cbd5e1; }
.calendar-day.purchased .day-number { color: #64748b; }
.calendar-day.purchased:hover { transform: none; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06); }
.calendar-day:hover { border-color: #3b82f6; box-shadow: 0 4px 12px rgba(59, 130, 246, 0.15); transform: translateY(-2px); }
.calendar-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 16px; margin-bottom: 40px; }
.chart-container { position: relative; width: 100%; max-height: 350px; }
.chart-container-full { position: relative; width: 100%; }
.contact-section { background: linear-gradient(180deg, #e2e8f0 0%, #f8fafc 100%); padding: 3rem 0 4rem 0; text-align: center; }
.contact-section .btn-contact { display: inline-flex; align-items: center; gap: 0.5rem; background: #0f172a; color: #fff; padding: 0.875rem 2rem; border-radius: 12px; font-size: 1rem; font-weight: 700; text-decoration: none; transition: all 0.3s ease; }
.contact-section .btn-contact:hover { background: #1e293b; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,0.15); color: #fff; text-decoration: none; }
.contact-section h2 { color: #0f172a; font-size: 1.75rem; font-weight: 700; margin-bottom: 0.5rem; }
.contact-section p { color: #64748b; font-size: 1rem; margin-bottom: 1.5rem; }
.cta-card { background: linear-gradient(135deg, #FAAE4C 0%, #f59e0b 100%); border-radius: 24px; overflow: hidden; display: grid; grid-template-columns: 1fr 1fr; min-height: 300px; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.15); }
.cta-content { padding: 3rem; display: flex; flex-direction: column; justify-content: center; }
.cta-content .btn-cta { display: inline-flex; align-items: center; gap: 0.75rem; background: #0f172a; color: #fff; padding: 1rem 2rem; border-radius: 12px; font-size: 1.1rem; font-weight: 700; text-decoration: none; transition: all 0.3s ease; width: fit-content; }
.cta-content .btn-cta:hover { background: #1e293b; transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,0.2); color: #fff; text-decoration: none; }
.cta-content h2 { color: #0f172a; font-size: 2.25rem; font-weight: 800; margin-bottom: 0.75rem; }
.cta-content p { color: rgba(15,23,42,0.8); font-size: 1.1rem; margin-bottom: 1.5rem; }
.cta-image { background: url("/img/team.jpg") center/cover; }
.cta-section { background: linear-gradient(180deg, #f8fafc 0%, #e2e8f0 100%); padding: 4rem 0 0 0; }
.custom-toggler .navbar-toggler-icon { background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.9)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E"); }
.custom-toggler.navbar-toggler { border-color: #fff; }
.d-amt { text-align: center; padding: 20px 10px; font-size: 25px; margin-bottom: 0; color: #053c79; }
.d-amt-a:hover { text-decoration: none; }
.day-number { font-size: 2.5em; font-weight: 700; color: #1a1a1a; margin-bottom: 16px; }
.donation-amount { font-size: 1.5rem; font-weight: 700; color: #10b981; }
.donation-amount.zero { color: #94a3b8; }
.donation-amt { border-radius: 5px; display: inline-block; border: solid #ccc 1px; background-color: #e9ecef; margin-bottom: 15px; margin-left: 5px; margin-right: 5px; width: 75px; }
.donation-breakdown { font-size: 0.9rem; color: #64748b; margin-top: 0.5rem; }
.donation-cell { padding: .5rem; }
.donation-table { max-height: 400px; overflow: auto; }
.donations-card { background: #fff; border-radius: 20px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); overflow: hidden; }
.donations-count { background: #3b82f6; color: #fff; padding: 0.25rem 0.75rem; border-radius: 999px; font-size: 0.85rem; font-weight: 600; }
.donations-header { padding: 1.25rem 1.5rem; background: #f8fafc; border-bottom: 1px solid #e2e8f0; display: flex; justify-content: space-between; align-items: center; }
.donations-header h3 { font-size: 1.1rem; font-weight: 700; color: #1e293b; margin: 0; display: flex; align-items: center; gap: 0.5rem; }
.donations-section { margin-top: 0; }
.donations-section-inline { padding: 0; border-top: 1px solid #e2e8f0; }
.donations-section-inline .donation-item { padding: 0.875rem 1.5rem; }
.donations-section-inline .donations-header { padding: 1.25rem 1.5rem; background: #f8fafc; border-bottom: 1px solid #e2e8f0; display: flex; justify-content: space-between; align-items: center; }
.donations-section-inline .donations-header h3 { font-size: 1.1rem; font-weight: 700; color: #1e293b; margin: 0; display: flex; align-items: center; gap: 0.5rem; }
.donate-about-section { padding: 2rem; }
.donate-about-section h3 { font-size: 1.1rem; font-weight: 700; color: #1e293b; margin-bottom: 1rem; display: flex; align-items: center; gap: 0.5rem; }
.donate-about-section p { color: #475569; line-height: 1.7; margin: 0; }
.donate-about-wrapper { background: #fff; border-radius: 20px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); overflow: hidden; }
.donate-amount-btn { padding: 1rem; border: 2px solid #e2e8f0; border-radius: 12px; background: #fff; font-size: 1.25rem; font-weight: 700; color: #1e293b; cursor: pointer; transition: all 0.2s; }
.donate-amount-btn.active { border-color: #3b82f6; background: #3b82f6; color: #fff; }
.donate-amount-btn:hover { border-color: #3b82f6; background: #eff6ff; }
.donate-amount-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 1.5rem; }
.donate-anon-checkbox { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1.5rem; cursor: pointer; }
.donate-anon-checkbox input { width: 20px; height: 20px; accent-color: #3b82f6; cursor: pointer; }
.donate-anon-checkbox span { color: #475569; font-size: 0.95rem; }
.donate-btn { width: 100%; padding: 1.25rem; background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); color: #fff; border: none; border-radius: 14px; font-size: 1.1rem; font-weight: 700; cursor: pointer; transition: all 0.3s; display: flex; align-items: center; justify-content: center; gap: 0.75rem; }
.donate-btn:active { transform: translateY(0); }
.donate-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 25px rgba(59,130,246,0.4); }
.donate-calendar-section { padding: 1.5rem; }
.donate-calendar-section .calendar-day { min-height: 120px; padding: 12px 8px; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; }
.donate-calendar-section .calendar-day .add-to-cart-btn { font-size: 0.75em; padding: 8px 6px; width: auto; min-width: 70px; max-width: 100%; margin-top: auto; }
.donate-calendar-section .calendar-day .buy-now { display: flex; justify-content: center; align-items: center; margin-top: auto; width: 100%; }
.donate-calendar-section .calendar-day .day-number { font-size: 1.5em; margin-bottom: 10px; flex-shrink: 0; }
.donate-calendar-section .calendar-day .in-cart-state { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; color: #16a34a; margin-top: auto; }
.donate-calendar-section .calendar-day .in-cart-state i { font-size: 1.5rem; margin-bottom: 4px; }
.donate-calendar-section .calendar-day .in-cart-state small { font-size: 0.75rem; font-weight: 600; }
.donate-calendar-section .calendar-day .purchased-label { font-size: 0.7em; padding: 6px 8px; text-align: center; width: 100%; box-sizing: border-box; max-width: 100%; word-wrap: break-word; margin-top: auto; }
.donate-calendar-section .calendar-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 8px; margin: 0 0 1.5rem; align-items: stretch; }
.donate-calendar-section h3 { font-size: 1.25rem; font-weight: 700; color: #1e293b; text-align: center; margin-bottom: 1rem; }
.donate-card { background: #fff; border-radius: 20px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); overflow: hidden; }
.donate-card-body { padding: 2rem; }
.donate-container { max-width: 1200px; margin: 0 auto; padding: 2rem 1rem; }
.donate-custom-amount-group { margin-bottom: 1.5rem; }
.donate-custom-amount-input { width: 100%; padding: 1rem; border: 2px solid #e2e8f0; border-radius: 12px; font-size: 1.25rem; font-weight: 600; text-align: center; transition: all 0.2s; }
.donate-custom-amount-input:focus { outline: none; border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.1); }
.donate-custom-amount-label { font-size: 0.9rem; font-weight: 600; color: #475569; margin-bottom: 0.5rem; display: block; }
.donate-days-left { text-align: right; margin-top: 0.5rem; font-size: 0.9rem; color: #64748b; }
.donate-days-left strong { color: #1e293b; }
.donate-ended-notice { background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%); border: 1px solid #f59e0b; border-radius: 12px; padding: 1.5rem; text-align: center; margin-bottom: 1.5rem; }
.donate-ended-notice h4 { color: #92400e; margin: 0 0 0.5rem 0; font-size: 1.1rem; }
.donate-ended-notice p { color: #a16207; margin: 0; font-size: 0.95rem; }
.donate-form-section { padding: 2rem; }
.donate-form-section h3 { font-size: 1.1rem; font-weight: 700; color: #1e293b; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 0.5rem; }
.donate-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: start; }
.donate-grid-equal { align-items: stretch; }
.donate-grid-equal .donate-card { display: flex; flex-direction: column; }
.donate-grid-equal .donations-section-inline { flex: 1; display: flex; flex-direction: column; }
.donate-grid-equal .donations-section-inline .donations-list { flex: 1; }
.donate-hero { background: linear-gradient(135deg, #1e3a5f 0%, #0f172a 100%); padding: 2.5rem 0; position: relative; border-bottom: 4px solid #22c55e; }
.donate-hero::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.donate-hero h1 { color: #fff; font-size: clamp(1.5rem, 4vw, 2.25rem); font-weight: 700; margin: 0; display: inline-block; }
.donate-hero-badge { display: inline-flex; align-items: center; gap: 0.4rem; background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%); color: #fff; padding: 0.35rem 0.85rem; border-radius: 999px; font-size: 0.8rem; font-weight: 600; }
.donate-hero-badge.ended { background: #64748b; }
.donate-hero-badge.coming-soon { background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%); }
.donate-hero-content { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; position: relative; z-index: 1; }
.donate-image { width: 100%; aspect-ratio: 4/3; object-fit: contain; background: #ffffff; padding: 1.5rem; }
.donate-image-section { position: relative; }
.donate-left-column { display: flex; flex-direction: column; gap: 1.5rem; }
.donate-no-donations { padding: 3rem; text-align: center; color: #94a3b8; }
.donate-no-donations svg { margin-bottom: 1rem; opacity: 0.5; }
.donate-page { background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%); min-height: 100vh; }
.donate-player-select-label { font-size: 0.85rem; font-weight: 600; color: #64748b; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.5rem; }
.donate-player-select-modern { width: 100%; padding: 0.875rem 1rem; border: 2px solid #e2e8f0; border-radius: 12px; font-size: 1rem; font-weight: 500; color: #1e293b; background: #fff; cursor: pointer; transition: all 0.2s; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; background-size: 1.25rem; }
.donate-player-select-modern:focus { outline: none; border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.1); }
.donate-player-select-section { padding: 1.5rem 2rem; background: #f8fafc; border-bottom: 1px solid #e2e8f0; }
.donate-progress-amount { font-size: 2rem; font-weight: 800; color: #16a34a; }
.donate-progress-bar { height: 12px; background: #d1fae5; border-radius: 6px; overflow: hidden; }
.donate-progress-fill { height: 100%; background: linear-gradient(90deg, #22c55e 0%, #16a34a 100%); border-radius: 6px; transition: width 0.5s ease; }
.donate-progress-goal { color: #64748b; font-size: 1rem; }
.donate-progress-percent { font-size: 1.25rem; font-weight: 700; color: #166534; }
.donate-progress-section { padding: 1.5rem 2rem; background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%); border-bottom: 1px solid #bbf7d0; }
.donate-progress-stats { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 0.75rem; flex-wrap: wrap; gap: 0.5rem; }
.donate-secure-note { text-align: center; margin-top: 1rem; color: #64748b; font-size: 0.85rem; display: flex; align-items: center; justify-content: center; gap: 0.5rem; }
.donate-starting-notice { background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%); border: 1px solid #3b82f6; border-radius: 12px; padding: 1.5rem; text-align: center; }
.donate-starting-notice h4 { color: #1e40af; margin: 0 0 0.5rem 0; font-size: 1.1rem; }
.donate-starting-notice p { color: #1d4ed8; margin: 0; font-size: 0.95rem; }
.donate-status-badge-large { position: absolute; top: 1rem; right: 1rem; padding: 0.5rem 1rem; border-radius: 999px; font-size: 0.85rem; font-weight: 600; display: flex; align-items: center; gap: 0.5rem; }
.donate-status-badge-large.active { background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%); color: #fff; }
.donate-status-badge-large.ended { background: #64748b; color: #fff; }
.donate-tip-help { font-size: 0.8rem; color: #64748b; margin-top: 0.5rem; }
.donate-tip-label { font-size: 0.9rem; font-weight: 600; color: #475569; margin-bottom: 0.5rem; display: flex; align-items: center; gap: 0.5rem; }
.donate-tip-section { background: #f8fafc; border-radius: 12px; padding: 1.25rem; margin-bottom: 1.5rem; }
.donate-tip-select { width: 100%; padding: 0.875rem 1rem; border: 2px solid #e2e8f0; border-radius: 10px; font-size: 1rem; background: #fff; cursor: pointer; transition: all 0.2s; }
.donate-tip-select:focus { outline: none; border-color: #3b82f6; }
.donate-tip-warning { background: #fef2f2; border: 1px solid #fecaca; color: #dc2626; padding: 1rem; border-radius: 10px; margin-top: 0.75rem; font-size: 0.85rem; display: none; }
.donate-total-amount { color: #fff; font-size: 1.75rem; font-weight: 800; }
.donate-total-label { color: rgba(255,255,255,0.7); font-size: 0.95rem; font-weight: 500; }
.donate-total-section { background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); border-radius: 12px; padding: 1.25rem; margin-bottom: 1.5rem; display: flex; justify-content: space-between; align-items: center; }
.donate-view-all-btn { background: none; border: none; color: #3b82f6; font-weight: 600; font-size: 0.9rem; cursor: pointer; display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.5rem 1rem; border-radius: 8px; transition: all 0.2s; }
.donate-view-all-btn:hover { background: #eff6ff; }
.donate-view-all-donations { padding: 1rem 1.5rem; text-align: center; border-top: 1px solid #e2e8f0; }
.donation-amount-item { font-weight: 700; color: #16a34a; font-size: 1rem; }
.donation-item { display: flex; justify-content: space-between; align-items: center; padding: 0.875rem 1.5rem; border-bottom: 1px solid #f0f0f0; transition: background 0.2s; }
.donation-item.hidden-donation { display: none; }
.donation-item:hover { background: #f8fafc; }
.donation-item:last-child { border-bottom: none; }
.donor-name { font-weight: 600; color: #1e293b; font-size: 0.95rem; }
.empty-section { text-align: center; padding: 3rem 1rem; color: #64748b; }
.empty-section svg { margin-bottom: 1rem; opacity: 0.5; }
.empty-state { text-align: center; padding: 3rem 2rem; background: #f8fafc; border-radius: 16px; border: 2px dashed #e2e8f0; }
.empty-state .btn { margin-top: 1rem; }
.empty-state-small { text-align: center; padding: 2rem; color: #94a3b8; }
.empty-state.small-empty { padding: 2rem 1rem; background: transparent; border: 1px dashed #e2e8f0; }
.empty-state h5 { color: #64748b; font-weight: 500; margin-bottom: 1rem; }
.error { color: red; }
.error-card { background: #fef2f2; border: 2px solid #fecaca; border-radius: 16px; padding: 3rem 2rem; text-align: center; display: flex; flex-direction: column; align-items: center; }
.error-card .error-icon { margin-bottom: 1rem; }
.error-card h4 { color: #dc2626; margin-bottom: 0.5rem; }
.error-card p { color: #b91c1c; margin-bottom: 1.5rem; }
.error-card.inline .error-icon { margin-bottom: 0; margin-right: 1rem; flex-shrink: 0; }
.fab-signup { position: fixed; bottom: 24px; right: 24px; width: 56px; height: 56px; background: linear-gradient(135deg, #BFDBF7 0%, #9fc5ed 100%); border-radius: 50%; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2), 0 2px 4px rgba(0, 0, 0, 0.1); color: #202A44; text-decoration: none; z-index: 1000; transition: all 0.25s ease; }
.fab-signup:active { transform: scale(0.95); }
.fab-signup:hover { transform: scale(1.1); box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25); color: #202A44; text-decoration: none; }
.feature-card h3 { color: #0f172a; font-size: 1.2rem; font-weight: 700; margin-bottom: 0.75rem; }
.feature-card p { color: #64748b; font-size: 0.95rem; line-height: 1.6; margin: 0; }
.feature-card { background: #fff; border-radius: 16px; padding: 2rem 1.5rem; text-align: center; box-shadow: 0 4px 20px rgba(0,0,0,0.05); border: 1px solid #e2e8f0; transition: all 0.3s ease; }
.feature-card:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(0,0,0,0.1); border-color: #BFDBF7; }
.feature-card:hover .feature-icon-modern { transform: scale(1.1) rotate(-5deg); }
.feature-icon { width: 180px; height: 180px; background: #202A44; border-radius: 30px; }
.feature-icon-modern { width: 64px; height: 64px; background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); border-radius: 16px; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.25rem; color: #FAAE4C; font-size: 1.5rem; box-shadow: 0 10px 25px rgba(15,23,42,0.2); transition: all 0.3s ease; }
.features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; max-width: 1100px; margin: 0 auto; }
.features-header { text-align: center; margin-bottom: 3rem; }
.features-header h2 { color: #0f172a; font-size: 2.25rem; font-weight: 800; margin-bottom: 0.75rem; }
.features-header p { color: #64748b; font-size: 1.1rem; max-width: 600px; margin: 0 auto; }
.features-section { background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%); padding: 4rem 0; }
.filter-actions { justify-content: flex-end; }
.filter-badge { font-size: 0.75rem; font-weight: 500; background: #e0f2fe; color: #0369a1; padding: 0.25rem 0.5rem; border-radius: 6px; margin-left: 0.5rem; }
.filter-buttons { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.filter-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; align-items: end; }
.filter-item { display: flex; flex-direction: column; gap: 0.5rem; }
.filter-label { font-size: 0.85rem; font-weight: 500; color: #64748b; }
.footer { border-top: #dee2e6 solid 2px; height: 2.5rem; padding-top: 5px; padding-left: 10px; font-size: 14px; padding-right: 10px; width: 90%; }
.footer-container { flex-shrink: 0; }
.footer-mob { border-top: #dee2e6 solid 2px; height: 2.5rem; padding-top: 5px; font-size: 14px; }
.footer-mob2 { font-size: 14px; }
.footer2 { font-size: 14px; width: 90%; }
#footer-con { flex-shrink: 0; }
.form-actions-mobile { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid #f0f0f0; }
.form-actions-mobile .btn-modern { flex: 1 1 auto; justify-content: center; min-width: 120px; }
.form-card { background: #ffffff; border-radius: 16px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 4px 12px rgba(0, 0, 0, 0.05); padding: 2rem; margin-bottom: 1.5rem; border: 1px solid #f0f0f0; }
.form-intro { color: #64748b; font-size: 1rem; margin-bottom: 1.5rem; line-height: 1.6; }
.form-label { font-weight: 600; color: #202A44; font-size: 0.9rem; margin-bottom: 0.5rem; display: block; }
.form-label .required { color: #ef4444; }
.fund-bg-img { min-height: 265px; }
.fund-card { width: 610px; height: 529px; border-radius: 60px; background: #fff; }
.fund-card2 { width: 386px; height: 507px; border-radius: 60px; background: #fff; }
.fund-desc { padding-bottom: 40px; }
.fund-player { font-size: 28px; }
.fundraiser-card { background: #ffffff; border-radius: 16px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 4px 12px rgba(0, 0, 0, 0.05); padding: 1.5rem; margin-bottom: 1rem; transition: all 0.25s ease; border: 1px solid #f0f0f0; position: relative; overflow: hidden; }
.fundraiser-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.5rem; margin-bottom: 3rem; }
.fundraiser-card-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; padding-top: 1rem; border-top: 1px solid #f0f0f0; }
.fundraiser-card-header { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 1rem; margin-bottom: 1rem; }
.fundraiser-card-meta { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.fundraiser-card-title { font-size: 1.2rem; font-weight: 600; color: #3b82f6; text-decoration: none; transition: color 0.2s ease; display: inline-flex; align-items: center; gap: 0.4rem; }
.fundraiser-card-title::after { content: ''; display: inline-block; width: 14px; height: 14px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%233b82f6'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M10 6H6a2 2 0 00-2 2v10a2 2 0 002 2h10a2 2 0 002-2v-4M14 4h6m0 0v6m0-6L10 14'/%3E%3C/svg%3E"); background-size: contain; opacity: 0.7; transition: opacity 0.2s ease; }
.fundraiser-card-title:hover { color: #1d4ed8; text-decoration: underline; }
.fundraiser-card-title:hover::after { opacity: 1; }
.fundraiser-card.active-card::before { background: linear-gradient(180deg, #10b981 0%, #059669 100%); opacity: 1; }
.fundraiser-card.completed-card::before { background: #94a3b8; opacity: 0.5; }
.fundraiser-card::before { content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%; background: linear-gradient(180deg, #3b82f6 0%, #1d4ed8 100%); opacity: 0; transition: opacity 0.25s ease; }
.fundraiser-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1), 0 8px 24px rgba(0, 0, 0, 0.08); }
.fundraiser-card:hover::before { opacity: 1; }
.fundraiser-name { font-size: 40px; font-weight: bold; }
.fundraisers-content { background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%); min-height: 60vh; padding: 2.5rem 1rem 4rem; }
.fundraisers-header { text-align: center; margin-bottom: 2.5rem; }
.fundraisers-header h2 { color: #fff; font-size: 2.25rem; font-weight: 800; margin-bottom: 0.75rem; }
.fundraisers-header p { color: rgba(255,255,255,0.6); font-size: 1.1rem; }
.fundraisers-hero { background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%); padding: 3rem 1rem 2.5rem; text-align: center; border-bottom: 1px solid #cbd5e1; }
.fundraisers-hero h1 { color: #1e3a5f; font-weight: 700; font-size: 2.25rem; margin-bottom: 0.75rem; }
.fundraisers-hero p { color: #64748b; font-size: 1.1rem; max-width: 600px; margin: 0 auto; }
.fundraisers-section { background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); padding: 4rem 0; }
.fund-card-modern { background: #fff; border-radius: 20px; overflow: hidden; box-shadow: 0 4px 15px rgba(0,0,0,0.08); transition: all 0.3s ease; display: flex; flex-direction: column; height: 100%; width: 100%; max-width: 380px; }
.fund-card-modern .btn-view { display: flex; align-items: center; justify-content: center; gap: 0.5rem; width: 100%; padding: 0.875rem 1.5rem; background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); color: #fff; font-weight: 600; font-size: 0.95rem; border-radius: 12px; text-decoration: none; transition: all 0.2s; }
.fund-card-modern .btn-view:hover { background: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(59,130,246,0.4); color: #fff; text-decoration: none; }
.fund-card-modern .card-action { margin-top: auto; }
.fund-card-modern .card-body { padding: 1.25rem 1.5rem 1.5rem; display: flex; flex-direction: column; flex: 1; }
.fund-card-modern .card-image { position: relative; height: 200px; overflow: hidden; background: #f1f5f9; display: flex; align-items: center; justify-content: center; }
.fund-card-modern .card-image img { width: 100%; height: 100%; object-fit: contain; padding: 1rem; transition: transform 0.3s ease; }
.fund-card-modern .card-stats { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 1.25rem; padding-bottom: 1rem; border-bottom: 1px solid #e2e8f0; }
.fund-card-modern .card-title { font-size: 1.1rem; font-weight: 700; color: #1e293b; margin-bottom: 1rem; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.fund-card-modern .end-date { text-align: right; font-size: 0.875rem; color: #64748b; }
.fund-card-modern .end-date strong { display: block; color: #475569; font-weight: 600; }
.fund-card-modern .raised-amount { font-size: 1.75rem; font-weight: 700; color: #f97316; line-height: 1; }
.fund-card-modern .raised-label { font-size: 0.75rem; color: #64748b; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.25rem; }
.fund-card-modern .status-badge { position: absolute; top: 1rem; right: 1rem; padding: 0.35rem 0.85rem; border-radius: 999px; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.025em; display: flex; align-items: center; gap: 0.35rem; }
.fund-card-modern:hover { transform: translateY(-6px); box-shadow: 0 12px 30px rgba(0,0,0,0.15); }
.fund-card-modern:hover .card-image img { transform: scale(1.08); }
.get-started { min-height: 292px; position: relative; top: -197px; width: 90%; }
.get-started-row { height: 292px; }
.goal-reached { color: #10b981; font-weight: 600; }
.goal-text { font-size: 0.9rem; color: #64748b; }
.header-second { color: #fff; }
.header-top { color: #fff; font-size: 4rem; font-weight: 700; }
.hero-badge { display: inline-flex; align-items: center; gap: 0.5rem; background: rgba(191, 219, 247, 0.15); border: 1px solid rgba(191, 219, 247, 0.3); color: #BFDBF7; padding: 0.5rem 1rem; border-radius: 999px; font-size: 0.85rem; font-weight: 600; margin-bottom: 1.5rem; backdrop-filter: blur(10px); animation: fadeInUp 0.6s ease-out; }
.hero-bg-image { position: absolute; inset: 0; background: url("/img/hands-in2.jpg") center/cover; opacity: 0.25; }
.hero-content { position: relative; z-index: 2; max-width: 900px; width: 100%; padding: 2rem; }
.hero-cta { display: inline-flex; align-items: center; gap: 0.75rem; background: linear-gradient(135deg, #BFDBF7 0%, #93c5fd 100%); color: #0f172a; padding: 1rem 2.5rem; border-radius: 999px; font-size: 1.1rem; font-weight: 700; text-decoration: none; transition: all 0.3s ease; box-shadow: 0 4px 20px rgba(191, 219, 247, 0.3); animation: fadeInUp 0.6s ease-out 0.3s backwards; }
.hero-cta:hover { transform: translateY(-3px) scale(1.02); box-shadow: 0 8px 30px rgba(191, 219, 247, 0.5); color: #0f172a; text-decoration: none; }
.hero-cta:hover svg { transform: translateX(4px); }
.hero-cta svg { transition: transform 0.3s ease; }
.hero-meta { display: flex; gap: 2rem; flex-wrap: wrap; margin-bottom: 1.5rem; padding-top: 1rem; border-top: 1px solid #e2e8f0; }
.hero-meta-item { display: flex; align-items: center; gap: 0.5rem; color: #64748b; font-size: 0.95rem; }
.hero-meta-item svg { color: #94a3b8; }
.hero-modern { position: relative; min-height: 600px; display: flex; align-items: center; justify-content: center; overflow: hidden; background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #334155 100%); }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,23,42,0.3) 0%, rgba(15,23,42,0.7) 100%); }
.hero-progress { margin-bottom: 1.5rem; }
.hero-progress-text { display: flex; justify-content: space-between; margin-top: 0.5rem; font-size: 0.9rem; color: #64748b; }
.hero-shape { position: absolute; border-radius: 50%; background: linear-gradient(135deg, rgba(191,219,247,0.1) 0%, rgba(191,219,247,0.05) 100%); animation: float 20s ease-in-out infinite; }
.hero-shape-1 { width: 400px; height: 400px; top: -100px; right: -100px; animation-delay: 0s; }
.hero-shape-2 { width: 300px; height: 300px; bottom: -50px; left: 10%; animation-delay: -5s; }
.hero-shape-3 { width: 200px; height: 200px; top: 30%; right: 20%; animation-delay: -10s; }
.hero-shapes { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.hero-stat-label { font-size: 1.1rem; color: #64748b; }
.hero-stat-main { display: flex; align-items: baseline; gap: 0.5rem; flex-wrap: wrap; }
.hero-stat-value { font-size: 2.5rem; font-weight: 800; color: #10b981; }
.hero-stat-value.zero { color: #94a3b8; }
.hero-subtitle { font-size: clamp(1rem, 2.5vw, 1.25rem); color: rgba(255,255,255,0.8); line-height: 1.6; margin-bottom: 2rem; max-width: 650px; animation: fadeInUp 0.6s ease-out 0.2s backwards; }
.hero-title { font-size: clamp(2.5rem, 6vw, 4rem); font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 1.5rem; animation: fadeInUp 0.6s ease-out 0.1s backwards; }
.hero-title .highlight { background: linear-gradient(135deg, #BFDBF7 0%, #60a5fa 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hidden { display: none !important; }
.hidden-row { display: none; }
.highlight-detail { font-size: 0.7rem; color: #94a3b8; margin-top: 0.25rem; }
.highlight-label { font-size: 0.8rem; color: #64748b; font-weight: 500; }
.highlight-name { font-size: 0.9rem; font-weight: 600; color: #1e293b; margin-bottom: 0.25rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.highlight-stat { background: #f8fafc; border-radius: 12px; padding: 1.25rem; text-align: center; border: 1px solid #e2e8f0; transition: all 0.2s ease; }
.highlight-stat.primary { background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%); border-color: #86efac; }
.highlight-stat.primary .highlight-value { color: #16a34a; }
.highlight-stat:hover { border-color: #cbd5e1; box-shadow: 0 2px 8px rgba(0,0,0,0.05); }
.highlight-subvalue { font-size: 0.9rem; font-weight: 500; color: #64748b; }
.highlight-value { font-size: 1.5rem; font-weight: 700; color: #1e293b; margin-bottom: 0.25rem; }
.highlights-card { min-height: 0; }
.highlights-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1rem; }
.history-card { background: #ffffff; border-radius: 16px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08); border: 1px solid #f0f0f0; overflow: hidden; }
.homepage-fundraisers { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1.5rem; justify-items: center; max-width: 1200px; margin: 0 auto; }
html { height: 100%; }
.join-a-team { min-height: 206px; position: relative; top: clamp(-120px, -9vw, -60px); margin-bottom: clamp(-120px, -9vw, -60px); width: 90%; }
.join-a-team + .container-fluid .row[style*="margin-top"] { margin-top: 0 !important; }
.join-card { background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); border-radius: 24px; padding: 2.5rem; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25); }
.join-card h2 { color: #BFDBF7; font-size: 1.5rem; font-weight: 700; margin-bottom: 0.75rem; display: flex; align-items: center; gap: 0.75rem; }
.join-card p { color: rgba(255,255,255,0.7); font-size: 1rem; margin-bottom: 1.5rem; }
.join-form { display: grid; grid-template-columns: 1fr auto; gap: 1rem; align-items: end; }
.join-form .btn-join { height: 50px; padding: 0 1.75rem; background: linear-gradient(135deg, #BFDBF7 0%, #93c5fd 100%); color: #0f172a; border: 2px solid transparent; border-radius: 10px; font-size: 1rem; font-weight: 700; cursor: pointer; transition: all 0.3s ease; white-space: nowrap; box-sizing: border-box; }
.join-form .btn-join:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(191,219,247,0.3); }
.join-form .form-group { margin: 0; }
.join-form input { width: 100%; height: 50px; padding: 0 1rem; border: 2px solid rgba(255,255,255,0.1); border-radius: 10px; background: rgba(255,255,255,0.05); color: #fff; font-size: 1rem; transition: all 0.3s ease; box-sizing: border-box; }
.join-form input::placeholder { color: rgba(255,255,255,0.3); }
.join-form input:focus { outline: none; border-color: #BFDBF7; background: rgba(255,255,255,0.1); box-shadow: 0 0 0 4px rgba(191,219,247,0.1); }
.join-form label { display: block; color: rgba(255,255,255,0.6); font-size: 0.75rem; font-weight: 600; margin-bottom: 0.5rem; text-transform: uppercase; letter-spacing: 0.05em; }
.join-section { background: #BFDBF7; padding: 3rem 0; }
.lb-amount { font-weight: 700; color: #10b981; font-size: 0.95rem; }
.lb-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; border: 2px solid #e2e8f0; flex-shrink: 0; }
.lb-donations { font-size: 0.75rem; color: #94a3b8; }
.lb-info { min-width: 0; }
.lb-item { display: flex; justify-content: space-between; align-items: center; padding: 0.75rem 0; border-bottom: 1px solid #f1f5f9; }
.lb-item-left { display: flex; align-items: center; gap: 0.75rem; min-width: 0; }
.lb-item-right { text-align: right; flex-shrink: 0; }
.lb-item:last-child { border-bottom: none; }
.lb-meta { font-size: 0.75rem; color: #94a3b8; }
.lb-name { font-weight: 600; color: #1e293b; font-size: 0.9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lb-pane { display: none; }
.lb-pane.active { display: block; }
.lb-rank { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; font-size: 0.85rem; font-weight: 600; color: #3b82f6; background: #eff6ff; border-radius: 8px; flex-shrink: 0; }
.lb-show-more { text-align: center; padding-top: 1rem; }
.lb-show-more a { color: #3b82f6; text-decoration: none; font-size: 0.85rem; font-weight: 500; }
.lb-show-more a:hover { text-decoration: underline; }
.lb-tab { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 1rem; background: none; border: none; font-size: 0.9rem; font-weight: 500; color: #64748b; cursor: pointer; border-radius: 8px 8px 0 0; transition: all 0.2s ease; }
.lb-tab:hover { color: #1e293b; background: #f1f5f9; }
.lb-tab.active { color: #3b82f6; background: #eff6ff; border-bottom: 2px solid #3b82f6; margin-bottom: -2px; }
.lb-tab svg { width: 16px; height: 16px; }
.leaderboard-card { display: flex; flex-direction: column; min-height: 0; }
.leaderboard-content { flex: 1; overflow: hidden; }
.leaderboard-header { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; margin-bottom: 1rem; }
.leaderboard-header h4 { margin: 0; display: flex; align-items: center; }
.leaderboard-tabs { display: flex; gap: 0.5rem; margin-bottom: 1rem; border-bottom: 2px solid #e2e8f0; padding-bottom: 0.5rem; }
.link-box { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; padding: 1rem; overflow-x: auto; }
.link-box code { font-size: 0.85rem; color: #0369a1; word-break: break-all; }
.message-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.message-box { background: #f8fafc; border: 2px solid #e2e8f0; border-radius: 12px; padding: 1.5rem; font-size: 1rem; line-height: 1.7; color: #334155; margin-bottom: 1.5rem; }
.meta-item { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; color: #64748b; }
.meta-item .icon { width: 18px; height: 18px; opacity: 0.7; }
.meta-item strong { color: #202A44; font-weight: 600; }
.mobile-signup-banner { background: linear-gradient(135deg, #BFDBF7 0%, #a8d0f5 100%); text-align: center; padding: 10px 16px; }
.mobile-signup-banner a { color: #202A44; text-decoration: none; font-size: 0.95rem; }
.mobile-signup-banner a:hover { text-decoration: underline; }
.modern-input { border: 2px solid #e2e8f0; border-radius: 8px; padding: 0.75rem 1rem; font-size: 1rem; transition: all 0.2s ease; width: 100%; box-sizing: border-box; max-width: 100%; }
.modern-input::placeholder { color: #94a3b8; }
.modern-input:focus { border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1); outline: none; }
.modern-table { width: 100%; margin: 0; }
.modern-table tbody tr:hover { background: #f8fafc; }
.modern-table tbody tr:last-child td { border-bottom: none; }
.modern-table tbody tr.current-row { background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%); }
.modern-table tbody tr.current-row:hover { background: linear-gradient(135deg, #dcfce7 0%, #bbf7d0 100%); }
.modern-table td { padding: 1rem 1.25rem; border-bottom: 1px solid #f0f0f0; color: #334155; }
.modern-table th { padding: 1rem 1.25rem; font-weight: 600; color: #475569; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.05em; border-bottom: 2px solid #e2e8f0; }
.modern-table thead { background: #f8fafc; }
.nav-border { display: inline-block; width: 8px; margin-left: 8px; height: 13px; border-right: 1px solid #6F9DCF; position: relative; bottom: -2px; }
.nav-fluid { width: 90%; }
.nav-logo-div { height: 55px; width: 388px; background: url('/img/team-donor-logo.svg'); background-repeat: no-repeat; background-size: 388px 55px; }
.navbar-brand { font-family: 'PT Serif', serif; padding-top: 0; padding-bottom: 0; font-size: 2rem; }
.navy { color: #202A44; }
.nowrap { white-space: nowrap; }
.orange { color: #F38355; }
.payout-grid { display: flex; flex-direction: column; gap: 0.75rem; }
.payout-label { color: #64748b; }
.payout-row { display: flex; justify-content: space-between; align-items: center; padding: 0.75rem 0; border-bottom: 1px solid #f1f5f9; }
.payout-row:last-child { border-bottom: none; }
.payout-row.deduction .payout-value { color: #ef4444; }
.payout-row.total { border-top: 2px solid #e2e8f0; border-bottom: none; padding-top: 1rem; margin-top: 0.5rem; }
.payout-row.total .payout-label { font-weight: 700; color: #1e293b; font-size: 1.1rem; }
.payout-row.total .payout-value { font-weight: 700; color: #10b981; font-size: 1.25rem; }
.payout-value { font-weight: 600; color: #1e293b; }
.payment-row { border: solid 1px #cccccc; padding-top: 20px; padding-left: 15px; padding-right: 15px; }
.player-dashboard { max-width: 900px; margin: 0 auto; }
.ppe-alert { padding: 1rem 1.25rem; border-radius: 10px; margin-bottom: 1.5rem; font-weight: 500; display: flex; align-items: center; gap: 0.75rem; }
.ppe-alert-error { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.ppe-alert-success { background: #dcfce7; color: #166534; border: 1px solid #bbf7d0; }
.ppe-back-link { display: inline-flex; align-items: center; gap: 0.5rem; color: #3b82f6; font-weight: 500; text-decoration: none; padding: 0.75rem 0; transition: all 0.2s; }
.ppe-back-link:hover { color: #1d4ed8; text-decoration: none; gap: 0.75rem; }
.ppe-btn-copy { padding: 0.75rem 1.25rem; background: #3b82f6; color: #fff; border: none; border-radius: 10px; font-weight: 600; cursor: pointer; transition: all 0.2s; display: flex; align-items: center; gap: 0.5rem; }
.ppe-btn-copy.copied { background: #22c55e; }
.ppe-btn-copy:hover { background: #2563eb; transform: translateY(-1px); }
.ppe-btn-save { padding: 1rem 2rem; background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%); color: #fff; border: none; border-radius: 12px; font-size: 1rem; font-weight: 600; cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; gap: 0.5rem; }
.ppe-btn-save:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(34,197,94,0.35); }
.ppe-btn-cancel-crop { margin-top: 1rem; padding: 0.75rem 1.25rem; background: #fee2e2; color: #dc2626; border: 1px solid #fecaca; border-radius: 10px; font-size: 0.9rem; font-weight: 600; cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; gap: 0.5rem; width: 100%; justify-content: center; }
.ppe-btn-cancel-crop:hover { background: #fecaca; border-color: #f87171; }
.ppe-btn-send { padding: 0.875rem 1.5rem; background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); color: #fff; border: none; border-radius: 10px; font-size: 0.95rem; font-weight: 600; cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; gap: 0.5rem; }
.ppe-btn-send:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
.ppe-btn-send:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(59,130,246,0.35); }
.ppe-current-photo { display: inline-block; margin-bottom: 1rem; }
.ppe-current-photo img { width: 140px; height: 140px; border-radius: 16px; object-fit: cover; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.ppe-email-count { padding: 0.5rem 1rem; background: #e2e8f0; color: #475569; border-radius: 8px; font-weight: 600; font-size: 0.9rem; }
.ppe-email-count.has-emails { background: #dbeafe; color: #1d4ed8; }
.ppe-email-count.max-emails { background: #fef3c7; color: #92400e; }
.ppe-email-form-column { order: 1; }
.ppe-email-history-column { order: 3; grid-column: 1; margin-top: 0; padding-top: 1.5rem; border-top: 1px solid #e2e8f0; }
.ppe-email-preview { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 12px; padding: 1.25rem; }
.ppe-email-preview-body { background: #fff; border-radius: 8px; padding: 1rem; border: 1px solid #e2e8f0; }
.ppe-email-preview-column { order: 2; }
.ppe-email-preview-header { background: #fff; padding: 0.75rem 1rem; border-radius: 8px; margin-bottom: 1rem; font-size: 0.9rem; border: 1px solid #e2e8f0; }
.ppe-email-preview-header strong { color: #64748b; }
.ppe-email-section { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.ppe-form-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 1rem; flex-wrap: wrap; gap: 1rem; }
.ppe-form-hint { font-size: 0.85rem; color: #64748b; margin-top: 0.5rem; }
.ppe-form-input { width: 100%; padding: 0.875rem 1rem; border: 2px solid #e2e8f0; border-radius: 10px; font-size: 1rem; transition: all 0.2s; }
.ppe-form-input:focus { outline: none; border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.1); }
.ppe-form-label { font-weight: 600; color: #1e293b; margin-bottom: 0.5rem; display: block; font-size: 0.95rem; }
.ppe-form-label-hint { font-weight: 400; color: #64748b; font-size: 0.85rem; }
.ppe-form-section { margin-bottom: 1.5rem; }
.ppe-form-textarea { min-height: 120px; resize: vertical; }
.ppe-history-table { width: 100%; border-collapse: collapse; }
.ppe-history-table td { padding: 0.75rem 1rem; border-bottom: 1px solid #f0f0f0; font-size: 0.9rem; }
.ppe-history-table td:last-child { text-align: center; }
.ppe-history-table th { background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); color: #fff; padding: 0.75rem 1rem; text-align: left; font-weight: 600; font-size: 0.9rem; }
.ppe-history-table th:first-child { border-radius: 8px 0 0 0; }
.ppe-history-table th:last-child { border-radius: 0 8px 0 0; text-align: center; }
.ppe-history-table tr:hover td { background: #f8fafc; }
.ppe-link-box { background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%); border: 2px dashed #3b82f6; border-radius: 12px; padding: 1.25rem; margin-bottom: 2rem; }
.ppe-link-box-input { display: flex; gap: 0.75rem; }
.ppe-link-box-input input { flex: 1; padding: 0.75rem 1rem; border: 2px solid #e2e8f0; border-radius: 10px; font-size: 0.95rem; background: #fff; color: #1e293b; }
.ppe-link-box-input input:focus { outline: none; border-color: #3b82f6; }
.ppe-link-box-label { font-weight: 600; color: #1e40af; margin-bottom: 0.75rem; display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; }
.ppe-section-title { font-size: 1.1rem; font-weight: 700; color: #1e293b; margin-bottom: 1rem; display: flex; align-items: center; gap: 0.5rem; }
.ppe-section-title i { color: #3b82f6; }
.ppe-tab-content-area { padding: 2rem; }
.player-greeting { font-size: 2rem; font-weight: 700; color: #202A44; margin-bottom: 4rem; display: flex; align-items: center; gap: 0.75rem; }
.player-greeting::before { content: '👋'; font-size: 1.75rem; }
#player-select option { font-size: 1rem; }
.profile-card { background: #fff; border-radius: 20px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); overflow: hidden; }
.profile-container { max-width: 1100px; margin: 0 auto; padding: 0 1rem 2rem; }
.profile-hero { background: linear-gradient(135deg, #1e3a5f 0%, #0f172a 100%); padding: 2rem 0; margin-bottom: 2rem; border-bottom: 4px solid #22c55e; position: relative; }
.profile-hero::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.profile-hero h1 { color: #fff; font-size: 1.75rem; font-weight: 700; margin: 0 0 0.25rem 0; }
.profile-hero p { color: rgba(255,255,255,0.7); margin: 0; font-size: 1rem; }
.profile-hero-content { position: relative; z-index: 1; }
.profile-tab { flex: 1; padding: 1.25rem 1.5rem; font-weight: 600; color: #64748b; text-align: center; cursor: pointer; border: none; background: none; transition: all 0.2s; text-decoration: none; display: flex; align-items: center; justify-content: center; gap: 0.5rem; }
.profile-tab.active { color: #3b82f6; background: #fff; border-bottom: 3px solid #3b82f6; margin-bottom: -1px; }
.profile-tab i { font-size: 1.1rem; }
.profile-tab:hover { color: #3b82f6; background: #eff6ff; text-decoration: none; }
.profile-tabs { display: flex; border-bottom: 1px solid #e2e8f0; background: #f8fafc; }
.pmt-frm-ele { margin-bottom: 16px; }
.progress-bar-container { height: 8px; background: #e2e8f0; border-radius: 4px; overflow: hidden; }
.progress-bar-fill { height: 100%; background: linear-gradient(90deg, #3b82f6, #60a5fa); border-radius: 4px; transition: width 0.5s ease; }
.progress-bar-fill.completed { background: linear-gradient(90deg, #10b981, #34d399); }
.progress-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 0.5rem; flex-wrap: wrap; gap: 0.25rem; }
.progress-header .donation-amount { font-size: 1.25rem; font-weight: 700; color: #10b981; }
.progress-header .donation-amount.zero { color: #94a3b8; }
.progress-section { margin: 1rem 0; }
.purchased-label { font-size: 0.85em; color: #64748b; text-align: center; font-weight: 500; padding: 8px 12px; background: #e2e8f0; border-radius: 6px; width: 100%; max-width: 140px; }
.report-hero-card { background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%); border: 1px solid #e2e8f0; border-radius: 16px; padding: 2rem; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06); }
.report-hero-header { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.5rem; }
.report-hero-stats { margin-bottom: 1rem; }
.report-hero-title { font-size: 1.75rem; font-weight: 700; color: #1e293b; margin: 0; }
.result-message { font-size: 18px; font-weight: bold; color: #28a745!important; margin-bottom: 50px; }
.section-divider { height: 2rem; }
.section-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1.5rem; padding-bottom: 0.75rem; border-bottom: 2px solid #e5e7eb; }
.section-title { display: flex; align-items: center; gap: 0.75rem; font-size: 1.35rem; font-weight: 700; color: #1e293b; margin-bottom: 1.5rem; }
.section-title .count-badge { background: #e0f2fe; color: #0369a1; font-size: 0.875rem; font-weight: 600; padding: 0.25rem 0.75rem; border-radius: 999px; margin-left: 0.5rem; }
.section-title svg { flex-shrink: 0; }
.section-header .badge { font-size: 0.75rem; padding: 0.35rem 0.75rem; border-radius: 50px; font-weight: 600; }
.section-header h4 { margin: 0; font-size: 1.35rem; font-weight: 600; color: #202A44; }
.school-amount-btn { padding: 0.875rem; border: 2px solid #e2e8f0; border-radius: 12px; background: #fff; font-size: 1.1rem; font-weight: 700; color: #1e293b; cursor: pointer; transition: all 0.2s; }
.school-amount-btn.active { border-color: #3b82f6; background: #3b82f6; color: #fff; }
.school-amount-btn:hover { border-color: #3b82f6; background: #eff6ff; }
.school-amount-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 1.5rem; }
.school-anon-checkbox { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1.5rem; cursor: pointer; }
.school-anon-checkbox input { width: 20px; height: 20px; accent-color: #3b82f6; cursor: pointer; }
.school-anon-checkbox span { color: #475569; font-size: 0.95rem; }
.school-days-left { text-align: right; margin-top: 0.5rem; font-size: 0.9rem; color: #64748b; }
.school-days-left strong { color: #1e293b; }
.school-donate-btn { width: 100%; padding: 1.25rem; background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); color: #fff; border: none; border-radius: 14px; font-size: 1.1rem; font-weight: 700; cursor: pointer; transition: all 0.3s; display: flex; align-items: center; justify-content: center; gap: 0.75rem; }
.school-donate-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 25px rgba(59,130,246,0.4); }
.school-donate-card { background: #fff; border-radius: 20px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); overflow: hidden; }
.school-donate-container { max-width: 1200px; margin: 0 auto; padding: 2rem 1rem; }
.school-donate-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: start; }
.school-donate-hero { background: linear-gradient(135deg, #1e3a5f 0%, #0f172a 100%); padding: 2.5rem 0; position: relative; border-bottom: 4px solid #22c55e; }
.school-donate-hero::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.school-donate-hero h1 { color: #fff; font-size: clamp(1.5rem, 4vw, 2.25rem); font-weight: 700; margin: 0; display: inline-block; position: relative; }
.school-donate-hero-content { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; position: relative; z-index: 1; }
.school-donate-left { display: flex; flex-direction: column; gap: 1.5rem; }
.school-donate-page { background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%); min-height: 100vh; }
.school-donation-amount { font-weight: 700; color: #16a34a; font-size: 1rem; white-space: nowrap; }
.school-donation-form-section { padding: 2rem; }
.school-donation-form-section h3 { font-size: 1.1rem; font-weight: 700; color: #1e293b; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 0.5rem; }
.school-donation-info { flex: 1; min-width: 0; }
.school-donation-item { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; padding: 0.875rem 0; border-bottom: 1px solid #f0f0f0; }
.school-donation-item:last-child { border-bottom: none; }
.school-donation-message { font-size: 0.85rem; color: #64748b; margin-top: 0.25rem; }
.school-donation-name { font-weight: 600; color: #1e293b; font-size: 0.95rem; }
.school-ended-notice { background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%); border: 1px solid #f59e0b; border-radius: 12px; padding: 1.5rem; text-align: center; }
.school-ended-notice h4 { color: #92400e; margin: 0 0 0.5rem 0; font-size: 1.1rem; }
.school-ended-notice p { color: #a16207; margin: 0; font-size: 0.95rem; }
.school-form-group { margin-bottom: 1.25rem; }
.school-form-input { width: 100%; padding: 0.875rem 1rem; border: 2px solid #e2e8f0; border-radius: 10px; font-size: 1rem; transition: all 0.2s; }
.school-form-input:focus { outline: none; border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.1); }
.school-form-label { font-size: 0.9rem; font-weight: 600; color: #475569; margin-bottom: 0.5rem; display: block; }
.school-form-textarea { resize: vertical; min-height: 80px; }
.school-hero-badge { display: inline-flex; align-items: center; gap: 0.4rem; background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%); color: #fff; padding: 0.35rem 0.85rem; border-radius: 999px; font-size: 0.8rem; font-weight: 600; }
.school-info-card { background: #fff; border-radius: 16px; box-shadow: 0 2px 12px rgba(0,0,0,0.06); padding: 1.5rem; }
.school-info-card h3 { font-size: 1rem; font-weight: 700; color: #1e293b; margin-bottom: 1rem; display: flex; align-items: center; gap: 0.5rem; }
.school-info-card p { color: #475569; line-height: 1.7; margin: 0; font-size: 0.95rem; }
.school-logo-fallback { object-fit: contain; padding: 0.5rem; background: #f8fafc; }
.school-logo-main { max-width: 280px; width: 100%; height: auto; border-radius: 16px; margin: 0 auto; display: block; }
.school-no-donations { text-align: center; padding: 2rem; color: #94a3b8; font-size: 0.95rem; }
.school-progress-amount { font-size: 1.75rem; font-weight: 800; color: #16a34a; }
.school-progress-bar { height: 10px; background: #e2e8f0; border-radius: 5px; overflow: hidden; }
.school-progress-fill { height: 100%; background: linear-gradient(90deg, #22c55e 0%, #16a34a 100%); border-radius: 5px; transition: width 0.5s ease; }
.school-progress-goal { color: #64748b; font-size: 0.95rem; margin-left: 0.25rem; }
.school-progress-percent { font-size: 1.1rem; font-weight: 700; color: #166534; }
.school-progress-section { padding: 1.25rem 1.5rem; background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%); border-radius: 0 0 20px 20px; }
.school-progress-stats { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 0.75rem; flex-wrap: wrap; gap: 0.5rem; }
.school-secure-note { text-align: center; margin-top: 1rem; color: #64748b; font-size: 0.85rem; display: flex; align-items: center; justify-content: center; gap: 0.5rem; }
.school-select-student-btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.875rem 1.5rem; background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%); color: #fff; border: none; border-radius: 12px; font-size: 1rem; font-weight: 600; cursor: pointer; transition: all 0.2s; }
.school-select-student-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(59,130,246,0.35); }
.school-show-more { text-align: center; padding-top: 0.75rem; }
.school-show-more-btn { background: none; border: none; color: #3b82f6; font-weight: 600; font-size: 0.9rem; cursor: pointer; padding: 0.5rem 1rem; border-radius: 8px; transition: all 0.2s; }
.school-show-more-btn:hover { background: #eff6ff; }
.school-char-count { font-weight: 400; color: #94a3b8; font-size: 0.85rem; margin-left: 0.5rem; }
.school-student-card { background: #fff; border-radius: 20px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); overflow: visible; position: relative; z-index: 10; }
.school-student-dropdown { min-width: 320px; padding: 0.75rem; }
.school-student-header { display: flex; gap: 1.25rem; padding: 1.5rem; align-items: center; }
.school-student-info { flex: 1; min-width: 0; }
.school-student-list { max-height: 320px; overflow-y: auto; }
.school-student-meta { color: #64748b; font-size: 0.95rem; margin-top: 0.25rem; }
.school-student-name-btn { background: none; border: none; padding: 0; font-size: 1.75rem; font-weight: 800; color: #1e293b; cursor: pointer; text-align: left; line-height: 1.2; }
.school-student-name-btn:hover { color: #3b82f6; }
.school-student-photo { width: 140px; height: 140px; border-radius: 16px; object-fit: cover; box-shadow: 0 4px 12px rgba(0,0,0,0.1); flex-shrink: 0; }
.school-student-select-prompt { text-align: center; padding: 2rem 1.5rem; }
.school-tip-help { font-size: 0.8rem; color: #64748b; margin-top: 0.5rem; }
.school-tip-label { font-size: 0.9rem; font-weight: 600; color: #475569; margin-bottom: 0.5rem; display: flex; align-items: center; gap: 0.5rem; }
.school-tip-section { background: #f8fafc; border-radius: 12px; padding: 1.25rem; margin-bottom: 1.5rem; }
.school-tip-warning { background: #fef2f2; border: 1px solid #fecaca; color: #dc2626; padding: 1rem; border-radius: 10px; margin-top: 0.75rem; font-size: 0.85rem; display: none; }
.school-top-donations { padding: 1.5rem 2rem; border-top: 1px solid #f0f0f0; }
.school-top-donations h4 { font-size: 1rem; font-weight: 700; color: #1e293b; margin-bottom: 1rem; display: flex; align-items: center; gap: 0.5rem; }
.school-total-amount { color: #fff; font-size: 1.75rem; font-weight: 800; }
.school-total-label { color: rgba(255,255,255,0.7); font-size: 0.95rem; font-weight: 500; }
.school-total-section { background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); border-radius: 12px; padding: 1.25rem; margin-bottom: 1.5rem; display: flex; justify-content: space-between; align-items: center; }
.site-content { flex: 1 0 auto; }
.social-share-buttons { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; }
.sort-select { width: auto; min-width: 160px; font-size: 0.85rem; padding: 0.5rem 0.75rem; }
.spinner { color: #ffffff; font-size: 22px; text-indent: -99999px; margin: 0px auto; position: relative; width: 20px; height: 20px; box-shadow: inset 0 0 0 2px; -webkit-transform: translateZ(0); -ms-transform: translateZ(0); transform: translateZ(0); }
.spinner, .spinner:after, .spinner:before { border-radius: 50%; }
.spinner:after { width: 10.4px; height: 10.2px; background: #5469d4; border-radius: 0 10.2px 10.2px 0; top: -0.1px; left: 10.2px; -webkit-transform-origin: 0px 10.2px; transform-origin: 0px 10.2px; -webkit-animation: loading 2s infinite ease; animation: loading 2s infinite ease; }
.spinner:after, .spinner:before { position: absolute; content: ""; }
.spinner:before { width: 10.4px; height: 20.4px; background: #5469d4; border-radius: 20.4px 0 0 20.4px; top: -0.2px; left: -0.2px; -webkit-transform-origin: 10.4px 10.2px; transform-origin: 10.4px 10.2px; -webkit-animation: loading 2s infinite ease 1.5s; animation: loading 2s infinite ease 1.5s; }
.started-nums { width: 71px; height: 71px; background: #202A44; border-radius: 100px; flex-shrink: 0; }
.started-nums-content { flex: 1; min-width: 0; }
.started-nums-row { display: flex; align-items: flex-start; gap: 1rem; }
.stats-leaderboard-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-top: 1.5rem; }
.status-active { background: #dcfce7; color: #166534; }
.status-badge { padding: 0.375rem 0.875rem; border-radius: 9999px; font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.025em; }
.status-badge.active { background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%); color: #fff; box-shadow: 0 2px 8px rgba(34,197,94,0.4); }
.status-badge.ended { background: rgba(255,255,255,0.95); color: #64748b; box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.status-completed { background: #e0e7ff; color: #3730a3; }
.status-not_started { background: #fef3c7; color: #92400e; }
.step-card { background: #fff; border-radius: 16px; padding: 2rem 1.5rem; text-align: center; position: relative; z-index: 1; box-shadow: 0 10px 40px rgba(0,0,0,0.08); transition: all 0.3s ease; }
.step-card:hover { transform: translateY(-6px); box-shadow: 0 15px 40px rgba(0,0,0,0.12); }
.step-card h3 { color: #0f172a; font-size: 1.2rem; font-weight: 700; margin-bottom: 0.5rem; }
.step-card p { color: #64748b; font-size: 0.95rem; line-height: 1.5; margin: 0; }
.step-icon { color: rgba(191,219,247,0.6); margin-bottom: 0.25rem; }
.step-indicator { font-size: 0.85rem; color: #64748b; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; margin-bottom: 0.5rem; }
.step-number { width: 56px; height: 56px; background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.25rem; font-size: 1.5rem; font-weight: 800; color: #BFDBF7; box-shadow: 0 8px 20px rgba(15,23,42,0.3); }
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; max-width: 1100px; margin: 0 auto; position: relative; }
.steps-grid::before { content: ""; position: absolute; top: 52px; left: 20%; right: 20%; height: 2px; background: linear-gradient(90deg, transparent, #0f172a, #0f172a, transparent); z-index: 0; }
.steps-header { text-align: center; margin-bottom: 3rem; }
.steps-header h2 { color: #0f172a; font-size: 2.25rem; font-weight: 800; margin-bottom: 0.75rem; }
.steps-header p { color: #334155; font-size: 1.15rem; max-width: 600px; margin: 0 auto; }
.steps-section { background: #BFDBF7; padding: 2rem 0 4rem 0; }
.stripe-badge { display: inline-flex; align-items: center; gap: 0.5rem; background: rgba(255,255,255,0.9); padding: 0.5rem 1rem; border-radius: 8px; margin-top: 1rem; }
.stripe-badge img { height: 24px; width: auto; }
.StripeElement { box-sizing: border-box; height: 40px; padding: 10px 12px; line-height: 1.5; border: 1px solid transparent; border-radius: 4px; background-color: white; box-shadow: 0 0 0 1px #e0e0e0, 0 2px 4px 0 rgba(0,0,0,.07), 0 1px 1.5px 0 rgba(0,0,0,.05); -webkit-transition: box-shadow 150ms ease; transition: box-shadow .08s ease-in,color .08s ease-in; }
.StripeElement--focus { box-shadow: 0 1px 3px 0 #cfd7df; }
.StripeElement--invalid { border-color: #fa755a; }
.StripeElement--webkit-autofill { background-color: #fefde5 !important; }
.subscriber-date { font-size: 0.85rem; color: #64748b; }
.subscriber-email { font-weight: 500; color: #1e293b; }
.subscriber-form { margin-bottom: 0; }
.subscriber-input-row { display: flex; gap: 0.75rem; align-items: center; flex-wrap: wrap; }
.success-card { background: #f0fdf4; border: 2px solid #bbf7d0; border-radius: 16px; padding: 3rem 2rem; text-align: center; display: flex; flex-direction: column; align-items: center; }
.success-card .success-icon { margin-bottom: 1rem; flex-shrink: 0; }
.success-card h4 { color: #166534; margin-bottom: 0.5rem; }
.success-card.inline { padding: 1rem 1.5rem; flex-direction: row; text-align: left; }
.success-card.inline .success-icon { margin-bottom: 0; margin-right: 1rem; flex-shrink: 0; }
.success-card p { color: #15803d; margin-bottom: 1.5rem; }
.table td, .table th { padding:.5rem .75rem; }
.table-responsive { overflow-x: auto; }
.tcbox { margin-top: -22px; }
.tcsub { margin-top: 0; }
.team-badge { background: #f0f9ff; border: 1px solid #bae6fd; border-radius: 8px; padding: 0.75rem 1rem; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 0.5rem; color: #0369a1; font-size: 0.95rem; }
.team-badge svg { flex-shrink: 0; }
.team-bg { background-image: url('../img/teamwork-bg.jpg'); background-position: center; background-repeat: no-repeat; background-size: cover; }
#teamcode { width: 100%; }
.text-muted { color: #94a3b8; }
.type-card { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.1); border-radius: 20px; padding: 2rem 1.75rem; backdrop-filter: blur(10px); transition: all 0.3s ease; display: flex; flex-direction: column; }
.type-card .btn-type { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.875rem 1.5rem; background: linear-gradient(135deg, #BFDBF7 0%, #93c5fd 100%); color: #0f172a; border-radius: 12px; font-weight: 700; font-size: 0.95rem; text-decoration: none; transition: all 0.3s ease; margin-top: auto; }
.type-card .btn-type:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(191,219,247,0.3); text-decoration: none; color: #0f172a; }
.type-card:hover { background: rgba(255,255,255,0.08); border-color: rgba(191,219,247,0.3); transform: translateY(-6px); }
.type-card h3 { color: #fff; font-size: 1.35rem; font-weight: 700; margin-bottom: 1rem; }
.type-card p { color: rgba(255,255,255,0.7); font-size: 1rem; line-height: 1.7; margin-bottom: 1.5rem; }
.type-features { list-style: none; padding: 0; margin: 0 0 2rem; flex: 1; }
.type-features li { color: rgba(255,255,255,0.6); font-size: 0.95rem; padding: 0.5rem 0; padding-left: 1.75rem; position: relative; }
.type-features li::before { content: ""; position: absolute; left: 0; top: 0.85rem; width: 8px; height: 8px; background: #BFDBF7; border-radius: 50%; }
.type-icon { width: 60px; height: 60px; background: linear-gradient(135deg, #BFDBF7 0%, #60a5fa 100%); border-radius: 16px; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; color: #0f172a; }
.types-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; max-width: 1200px; margin: 0 auto; }
.types-header { text-align: center; margin-bottom: 3rem; }
.types-header h2 { color: #fff; font-size: 2.25rem; font-weight: 800; margin-bottom: 0.75rem; }
.types-header p { color: rgba(255,255,255,0.6); font-size: 1.1rem; max-width: 600px; margin: 0 auto; }
.types-section { background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); padding: 4rem 0; position: relative; overflow: hidden; }
.types-section::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 100px; background: linear-gradient(180deg, #BFDBF7 0%, transparent 100%); opacity: 0.1; }
.version-date { font-size: 0.9rem; color: #475569; }
.version-subject { font-size: 0.9rem; color: #1e293b; }
.view-all-container { text-align: center; margin-top: 1rem; padding-top: 1rem; border-top: 1px solid #f1f5f9; }
.view-more-link { display: inline-flex; align-items: center; gap: 0.5rem; color: rgba(255,255,255,0.8); text-decoration: none; font-size: 1.1rem; font-weight: 600; transition: all 0.3s ease; }
.view-more-link:hover { color: #BFDBF7; transform: translateX(5px); text-decoration: none; }
.welcome-header { height:40px; line-height:40px; background-color: #6F9DCF; }
.yellow { color: #FAAE4C; }

/* ===== TESTIMONIALS SECTION ===== */
.testimonials-section { background: #fff; padding: 4rem 0; }
.testimonials-header { text-align: center; margin-bottom: 3rem; }
.testimonials-header h2 { color: #0f172a; font-size: 2.25rem; font-weight: 800; margin-bottom: 0.75rem; }
.testimonials-header p { color: #64748b; font-size: 1.1rem; max-width: 600px; margin: 0 auto; }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; max-width: 1200px; margin: 0 auto; }
.testimonial-card { background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%); border-radius: 20px; padding: 2rem; border: 1px solid #e2e8f0; transition: all 0.3s ease; display: flex; flex-direction: column; }
.testimonial-card:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(0,0,0,0.1); border-color: #BFDBF7; }
.testimonial-rating { display: flex; gap: 0.25rem; margin-bottom: 1rem; }
.testimonial-quote { font-size: 1.05rem; color: #334155; line-height: 1.7; flex: 1; margin: 0 0 1.5rem 0; font-style: italic; position: relative; padding-left: 1rem; border-left: 3px solid #BFDBF7; }
.testimonial-author { display: flex; align-items: center; gap: 1rem; margin-top: auto; padding-top: 1rem; border-top: 1px solid #e2e8f0; }
.author-avatar { width: 48px; height: 48px; background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #BFDBF7; font-weight: 700; font-size: 0.9rem; flex-shrink: 0; }
.author-info { display: flex; flex-direction: column; }
.author-info strong { color: #1e293b; font-size: 0.95rem; font-weight: 600; }
.author-info span { color: #64748b; font-size: 0.85rem; }

/* ===== FAQ SECTION ===== */
.faq-section { background: linear-gradient(180deg, #f8fafc 0%, #e2e8f0 100%); padding: 4rem 0; }
.faq-header { text-align: center; margin-bottom: 3rem; }
.faq-header h2 { color: #0f172a; font-size: 2.25rem; font-weight: 800; margin-bottom: 0.75rem; }
.faq-header p { color: #64748b; font-size: 1.1rem; max-width: 600px; margin: 0 auto; }
.faq-grid { display: flex; flex-direction: column; gap: 1.25rem; max-width: 900px; margin: 0 auto; }
.faq-item { background: #fff; border-radius: 16px; padding: 1.75rem 2rem; box-shadow: 0 2px 8px rgba(0,0,0,0.04); border: 1px solid #e2e8f0; transition: all 0.3s ease; }
.faq-item:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.08); border-color: #BFDBF7; }
.faq-question { display: flex; align-items: flex-start; gap: 0.75rem; font-size: 1.1rem; font-weight: 700; color: #1e293b; margin: 0 0 1rem 0; line-height: 1.4; }
.faq-question svg { flex-shrink: 0; color: #3b82f6; margin-top: 0.1rem; }
.faq-answer { color: #475569; font-size: 1rem; line-height: 1.7; margin: 0; padding-left: 2rem; }

@media (max-width: 900px) {
    .testimonials-grid { grid-template-columns: 1fr; max-width: 500px; }
    .faq-item { padding: 1.5rem; }
    .faq-question { font-size: 1rem; }
    .faq-answer { padding-left: 0; }
}

@media (max-width: 768px) {
    .testimonials-section { padding: 3rem 0; }
    .testimonials-header { margin-bottom: 2rem; }
    .faq-section { padding: 3rem 0; }
    .faq-header { margin-bottom: 2rem; }
}

@-webkit-keyframes loading { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); } 100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes float { 0%, 100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-30px) rotate(5deg); } }
@keyframes loading { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); } 100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }

@media (min-width: 1300px) { .navbar-expand-custom { flex-flow: row nowrap; justify-content: flex-start; } .navbar-expand-custom .navbar-collapse { display: flex !important; flex-basis: auto; } .navbar-expand-custom .navbar-nav { flex-direction: row; } .navbar-expand-custom .navbar-nav .dropdown-menu { position: absolute; } .navbar-expand-custom .navbar-nav .nav-link { padding-right: 0.5rem; padding-left: 0.5rem; } .navbar-expand-custom .navbar-toggler { display: none; } .navbar-expand-custom > .container { flex-wrap: nowrap; } }
@media (min-width: 768px) { .player-greeting { font-size: 2.25rem; } }
@media (min-width: 576px) { .form-actions-mobile { justify-content: flex-end; } .form-actions-mobile .btn-modern { flex: 0 0 auto; } }
@media (max-width: 991px) { .donate-grid { grid-template-columns: 1fr; } .donate-hero h1 { font-size: 1.5rem; } .donate-left-column { display: contents; } .donate-left-column > .donate-card { order: 1; } .donate-form-card { order: 2; } .donate-about-wrapper { order: 3; margin-bottom: 40px; } .donations-section { order: 4; } .ppe-email-section { grid-template-columns: 1fr; } .ppe-email-form-column { order: 1; } .ppe-email-preview-column { order: 2; } .ppe-email-history-column { order: 3; grid-column: 1; } .school-donate-grid { grid-template-columns: 1fr; } .school-student-header { flex-direction: column; text-align: center; } .school-student-photo { width: 120px; height: 120px; } .school-student-name-btn { font-size: 1.5rem; text-align: center; width: 100%; justify-content: center; } .stats-leaderboard-row { grid-template-columns: 1fr; } }
@media (max-width: 900px) { .calendar-container h2 { font-size: 2em; } .cta-card { grid-template-columns: 1fr; } .cta-content { padding: 3rem 2rem; text-align: center; } .cta-content .btn-cta { margin: 0 auto; } .cta-image { min-height: 250px; } .features-grid { grid-template-columns: 1fr; max-width: 400px; } .steps-grid { grid-template-columns: 1fr; max-width: 400px; } .steps-grid::before { display: none; } .types-grid { grid-template-columns: 1fr; max-width: 500px; } }
@media (max-width: 768px) { .bg-navy.container-fluid { padding-top: 0.75rem; padding-bottom: 0.75rem; } .nav-fluid { padding-left: 1rem; padding-right: 1rem; } .calendar-day { min-height: 140px; padding: 20px 12px; } .cta-section { padding: 3rem 0 0 0; } .contact-section { padding: 2rem 0 3rem 0; } .day-number { font-size: 2em; } .features-header { margin-bottom: 2rem; } .features-section { padding: 3rem 0; } .fundraiser-grid { grid-template-columns: 1fr; } .fundraisers-hero h1 { font-size: 1.75rem; } .fundraisers-section { padding: 3rem 0; } .fund-card-modern { width: 100%; } .hero-content { padding: 1.5rem 1rem; } .hero-modern { min-height: 350px; } .hero-subtitle { display: none; } .join-card { padding: 1.75rem 1.5rem; } .join-card h2 { font-size: 1.25rem; } .join-form { flex-direction: column; align-items: stretch; grid-template-columns: 1fr; } .join-form .btn-join { width: 100%; margin-top: 0; height: auto; } .join-form .form-group { min-width: 100%; } .join-form input, .join-form .btn-join { height: 44px; font-size: 0.95rem; } .join-section { padding: 2rem 0; } .payout-row { flex-direction: column; align-items: flex-start; gap: 0.25rem; } .payout-row.total { flex-direction: row; align-items: center; } .player-dashboard { padding-left: 0; padding-right: 0; } .report-hero-title { font-size: 1.35rem; } .hero-stat-value { font-size: 2rem; } .hero-meta { gap: 1rem; } .steps-header { margin-bottom: 2rem; } .steps-section { padding: 1.5rem 0 3rem 0; } .types-header { margin-bottom: 2rem; } .types-section { padding: 3rem 0; } }
@media (max-width: 767px) { .player-dashboard { padding-left: 0; padding-right: 0; } }
@media (max-width: 600px) { .btn-navy { padding: 10px 30px; } .buy-now { width: 100%; } .add-to-cart-btn { max-width: 100%; font-size: 0.9em; padding: 8px 10px; white-space: normal; line-height: 1.2; } .donate-about-section { padding: 1.25rem; } .donate-amount-grid { grid-template-columns: repeat(2, 1fr); } .donate-calendar-section .calendar-day { min-height: 110px; padding: 10px 6px; } .donate-calendar-section .calendar-day .add-to-cart-btn { font-size: 0.7em; padding: 6px 4px; min-width: 60px; } .donate-calendar-section .calendar-day .day-number { font-size: 1.25em; margin-bottom: 8px; } .donate-calendar-section .calendar-day .purchased-label { font-size: 0.65em; padding: 4px 4px; } .donate-calendar-section .calendar-grid { grid-template-columns: repeat(auto-fill, minmax(75px, 1fr)); } .donate-card-body { padding: 1.25rem; } .donate-container { padding: 1rem; } .donate-form-section { padding: 1.25rem; } .donate-progress-amount { font-size: 1.5rem; } .donate-progress-section { padding: 1.25rem; } .donation-table { max-height: 600px; overflow: auto; } form { width: 80vw; } .fund-bg-img { min-height: 250px; } .fund-card { max-width: 350px; height: 100%; } .fund-card2 { width: 350px; height: 100%; } .fundraiser-name { font-size: 28px; } .fund-player { font-size: 22px; } .header-second { font-size: 1.35rem; } .header-top { font-size: 1.85rem; } .nav-fluid { width: auto; } .nav-logo-div { height: 35px; width: 235px; background-size: 235px 35px; } .payment-row { border: none; padding: 0; } #player-select { width: 100% !important; display: block; } .school-amount-grid { grid-template-columns: repeat(2, 1fr); } .school-donate-container { padding: 1rem; } .school-donation-form-section { padding: 1.25rem; } .school-progress-amount { font-size: 1.5rem; } .school-student-photo { width: 100px; height: 100px; } .school-top-donations { padding: 1.25rem; } #teamcode { width: 85%; } }
@media (max-width: 575px) { .btn-modern { width: 100%; justify-content: center; } .filter-actions { justify-content: flex-start; } .filter-grid { grid-template-columns: 1fr; } .form-actions-mobile { flex-direction: column; } .form-actions-mobile .btn-modern { width: 100%; } .form-card { padding: 1rem; overflow: hidden; } .form-group { padding-left: 0; padding-right: 0; } .form-row { margin-left: 0; margin-right: 0; } .fundraiser-card { padding: 1.25rem; } .fundraiser-card-actions { flex-direction: column; } .fundraiser-card-meta { flex-direction: column; gap: 0.5rem; } .fundraiser-card-title { font-size: 1.1rem; } .highlight-stat { padding: 1rem; } .highlight-value { font-size: 1.25rem; } .highlights-grid { grid-template-columns: repeat(2, 1fr); } .leaderboard-header { flex-direction: column; align-items: flex-start; } .lb-name { max-width: 120px; } .message-actions { flex-direction: column; } .btn-copy-large { width: 100%; justify-content: center; } .ppe-btn-copy { width: 100%; justify-content: center; } .ppe-link-box-input { flex-direction: column; } .ppe-link-box-input input { width: 100%; } .site-content.container-fluid.px-5 { padding-left: 1rem !important; padding-right: 1rem !important; } .sort-select { width: 100%; } .subscriber-input-row { flex-direction: column; align-items: stretch; } .subscriber-input-row .btn-modern { width: 100%; justify-content: center; } .tcsub { margin-top: 0; } }
@media (max-width: 395px) { #teamcode { width: 75%; } }
@media (max-width: 376px) { .calendar-day { max-width: 300px; margin: 0 auto; } }
@media (max-width: 1280px) { .calendar-container { max-width: 100%; } }
@media (max-width: 1200px) { .fundraiser-name { font-size: 36px; } .fund-player { font-size: 24px; } }
@media (max-width: 1199px) { .tcbox { margin-top: 20px; } .tcsub { margin-top: 43px; } }
@media (max-width: 998px) { .fundraiser-name { font-size: 32px; } .fund-player { font-size: 24px; } }
@media (max-width: 991px) { .tcsub { margin-top: 20px; } }
@media (min-width: 992px) and (max-width: 1199px) { .col-lg-4 > .row > .col-md-3, .col-lg-4 > .row > .col-md-8 { flex: 0 0 100%; max-width: 100%; } }
