.admin-dashboard{max-width:1200px;margin:0 auto;padding:2rem}.admin-dashboard h1{margin-bottom:2rem;color:#333;border-bottom:2px solid #4a90e2;padding-bottom:.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;transition:transform .3s,box-shadow .3s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.stat-card h3{margin:0 0 1rem;color:#666;font-size:1rem;text-transform:uppercase;letter-spacing:1px}.stat-number{font-size:2.5rem;font-weight:700;color:#4a90e2;margin:0 0 1rem}.stat-detail{display:flex;justify-content:space-between;font-size:.9rem;color:#888;border-top:1px solid #eee;padding-top:1rem}.recent-activity{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.recent-activity h2{margin:0 0 1.5rem;color:#333}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-radius:6px;background:#f9f9f9;border-left:4px solid transparent}.activity-item.donation{border-left-color:#4a90e2}.activity-item.campaign{border-left-color:#50c878}.activity-icon{font-size:1.5rem}.activity-content{flex:1}.activity-content p{margin:0 0 .25rem;color:#333}.activity-content small{color:#888;font-size:.85rem}.loading,.error{text-align:center;padding:3rem;font-size:1.2rem}.error{color:#e74c3c}.last-updated{margin-top:1rem;text-align:right;color:#888;font-size:.9rem;font-style:italic}@media(max-width:768px){.admin-dashboard{padding:1rem}.stats-grid{grid-template-columns:1fr}.stat-number{font-size:2rem}.activity-item{flex-direction:column;gap:.5rem}}@media(max-width:480px){.admin-dashboard h1{font-size:1.5rem}.stat-detail{flex-direction:column;gap:.25rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f7fa;color:#1a202c;line-height:1.6}a{color:#4c6ef5;text-decoration:none}a:hover{text-decoration:underline}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1}.page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.loading-center{display:flex;justify-content:center;padding-top:4rem;color:#718096}.loading{text-align:center;color:#718096;padding:2rem 0}.empty{text-align:center;color:#718096;padding:3rem 0}.navbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #00000012}.navbar-brand{font-size:1.2rem;font-weight:700;color:#4c6ef5}.navbar-links{display:flex;align-items:center;gap:1.25rem}.navbar-links a{color:#4a5568;font-weight:500;font-size:.9rem}.navbar-links a:hover{color:#4c6ef5;text-decoration:none}.nav-user{display:flex;align-items:center;gap:.75rem;color:#4a5568;font-size:.9rem;font-weight:500}.btn-logout{background:none;border:1px solid #fed7d7;border-radius:6px;padding:.25rem .65rem;cursor:pointer;color:#e53e3e;font-size:.8rem}.btn-logout:hover{background:#fff5f5}.footer{background:#fff;border-top:1px solid #e2e8f0;text-align:center;padding:1.25rem;color:#a0aec0;font-size:.85rem}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;padding:3.5rem 2rem;text-align:center;margin-bottom:2rem}.hero h1{font-size:2.25rem;font-weight:800;margin-bottom:.5rem}.hero p{font-size:1.1rem;opacity:.9}.search-row{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap}.search-row input,.search-row select{flex:1;min-width:180px;padding:.6rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;background:#fff}.search-row input:focus,.search-row select:focus{outline:none;border-color:#4c6ef5;box-shadow:0 0 0 3px #4c6ef51f}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #00000012;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.card:hover{box-shadow:0 6px 20px #0000001c;transform:translateY(-2px)}.card-img{width:100%;height:175px;object-fit:cover}.card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.5rem}.card-title{font-size:1rem;font-weight:700;line-height:1.4}.card-stats{font-size:.85rem;color:#4a5568}.card-stats .pct{color:#4c6ef5;font-weight:600}.card-creator{font-size:.78rem;color:#a0aec0}.card-body .btn{margin-top:auto}.badge{display:inline-block;padding:.2rem .65rem;background:#ebf4ff;color:#3b82f6;border-radius:99px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.prog-wrap{background:#e2e8f0;border-radius:99px;height:8px;overflow:hidden}.prog-fill{background:linear-gradient(90deg,#4c6ef5,#7c3aed);height:100%;border-radius:99px;transition:width .4s ease}.btn{display:inline-block;padding:.6rem 1.25rem;border-radius:8px;font-weight:600;font-size:.9rem;border:none;cursor:pointer;text-align:center;transition:opacity .15s,transform .1s;text-decoration:none}.btn:hover{opacity:.88;text-decoration:none}.btn:active{transform:scale(.98)}.btn-primary{background:#4c6ef5;color:#fff}.btn.full{width:100%;display:block}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-donate-lg{width:100%;padding:.85rem;font-size:1.05rem;margin-top:1rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:2.5rem}.pagination button{padding:.5rem 1.1rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;font-weight:600}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{color:#718096;font-size:.9rem}.alert-err{background:#fff5f5;border:1px solid #fed7d7;color:#c53030;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;margin-bottom:1rem}.auth-page{display:flex;justify-content:center;align-items:flex-start;padding:4rem 1.5rem}.auth-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 4px 20px #00000014}.auth-card h2{font-size:1.6rem;font-weight:800;margin-bottom:.25rem}.auth-sub{color:#718096;margin-bottom:1.5rem;font-size:.95rem}.auth-card form{display:flex;flex-direction:column;gap:1rem}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;font-weight:600;color:#4a5568}.auth-card input{padding:.65rem .9rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem}.auth-card input:focus{outline:none;border-color:#4c6ef5;box-shadow:0 0 0 3px #4c6ef51f}.auth-switch{margin-top:1.25rem;text-align:center;font-size:.875rem;color:#718096}.detail-page{max-width:820px}.detail-header{display:flex;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.detail-img{width:100%;max-width:380px;height:240px;object-fit:cover;border-radius:12px}.detail-info{flex:1;display:flex;flex-direction:column;gap:.6rem}.detail-info h1{font-size:1.75rem;font-weight:800;line-height:1.3}.detail-meta{color:#718096;font-size:.875rem}.status-badge{display:inline-block;padding:.2rem .75rem;border-radius:99px;font-size:.8rem;font-weight:600}.status-active{background:#c6f6d5;color:#276749}.status-completed{background:#bee3f8;color:#2a69ac}.status-inactive{background:#e2e8f0;color:#4a5568}.detail-progress-card{background:#fff;border-radius:12px;padding:1.75rem;box-shadow:0 1px 4px #00000012;margin-bottom:2rem}.detail-progress-card .prog-wrap{height:12px;margin-bottom:1rem}.progress-stats{display:flex;justify-content:space-between}.stat{display:flex;flex-direction:column}.stat strong{font-size:1.4rem;font-weight:800;color:#1a202c}.stat span{font-size:.8rem;color:#718096}.stat.center{text-align:center}.stat.right{text-align:right}.login-cta{text-align:center;color:#718096;margin-top:1rem;font-size:.9rem}.detail-body{margin-bottom:2rem}.detail-body h2{font-size:1.2rem;font-weight:700;margin-bottom:.75rem}.detail-description{color:#4a5568;line-height:1.8;white-space:pre-wrap}.donors-card{background:#fff;border-radius:12px;padding:1.75rem;box-shadow:0 1px 4px #00000012}.donors-card h2{font-size:1.2rem;font-weight:700;margin-bottom:1.25rem}.donor-count{color:#718096;font-size:.9rem;font-weight:400}.donors-list{list-style:none;display:flex;flex-direction:column}.donor-row{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 0;border-bottom:1px solid #f0f4f8}.donor-row:last-child{border-bottom:none}.donor-avatar{font-size:1.4rem}.donor-info{flex:1}.donor-name{font-weight:600;font-size:.9rem}.donor-msg{color:#718096;font-size:.85rem;font-style:italic;margin:.2rem 0}.donor-date{color:#a0aec0;font-size:.78rem}.donor-amount{font-weight:700;color:#4c6ef5;font-size:1rem;white-space:nowrap}.overlay{position:fixed;inset:0;background:#00000073;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:460px;box-shadow:0 20px 60px #0003;position:relative;max-height:90vh;overflow-y:auto}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.1rem;cursor:pointer;color:#718096}.modal-close:hover{color:#1a202c}.modal h2{font-size:1.3rem;font-weight:800;margin-bottom:.2rem}.modal-campaign-title{color:#718096;font-size:.9rem;margin-bottom:1.5rem}.modal form{display:flex;flex-direction:column;gap:1rem}.modal label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;font-weight:600;color:#4a5568;position:relative}.modal input,.modal textarea{padding:.65rem .9rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-family:inherit}.modal input:focus,.modal textarea:focus{outline:none;border-color:#4c6ef5;box-shadow:0 0 0 3px #4c6ef51f}.check-label{flex-direction:row!important;align-items:center;gap:.6rem!important;cursor:pointer;font-weight:400!important}.check-label input{width:16px;height:16px}.optional{color:#a0aec0;font-weight:400;font-size:.8rem}.field-err{color:#e53e3e;font-size:.8rem;font-weight:400}.char-count{color:#a0aec0;font-size:.78rem;text-align:right;font-weight:400}.quick-amounts{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}.quick-btn{padding:.4rem .9rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .15s}.quick-btn:hover,.quick-btn.active{border-color:#4c6ef5;background:#ebf4ff;color:#4c6ef5}.input-prefix{display:flex;align-items:center;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.input-prefix span{padding:.65rem .75rem;background:#f7fafc;color:#718096;font-weight:600;border-right:1px solid #e2e8f0}.input-prefix input{border:none;border-radius:0;flex:1}.input-prefix input:focus{box-shadow:none}.summary-row{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.summary-card{flex:1;min-width:140px;background:#fff;border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 1px 4px #00000012;display:flex;flex-direction:column;gap:.25rem}.summary-card strong{font-size:1.8rem;font-weight:800;color:#4c6ef5}.summary-card span{color:#718096;font-size:.875rem}.donations-list{display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000012;overflow:hidden}.donation-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #f0f4f8;gap:1rem}.donation-row:last-child{border-bottom:none}.donation-left{flex:1}.donation-campaign{font-weight:600;font-size:.95rem}.donation-msg{color:#718096;font-size:.85rem;font-style:italic;margin:.2rem 0}.donation-meta{display:flex;gap:.75rem;align-items:center;margin-top:.25rem}.donation-meta span{font-size:.78rem;color:#a0aec0}.badge-anon{background:#f0fff4;color:#276749;padding:.1rem .5rem;border-radius:99px;font-size:.75rem;font-weight:600}.donation-amount{font-weight:800;font-size:1.05rem;color:#4c6ef5;white-space:nowrap}.empty-state{text-align:center;padding:4rem 0;color:#718096}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.65rem;z-index:9999}.toast{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff;border-radius:10px;padding:.85rem 1.1rem;box-shadow:0 4px 20px #00000021;min-width:280px;max-width:380px;border-left:4px solid;animation:slideIn .25s ease}.toast-success{border-color:#48bb78}.toast-error{border-color:#fc8181}.toast span{font-size:.9rem;font-weight:500;flex:1}.toast button{background:none;border:none;cursor:pointer;color:#a0aec0;font-size:1rem}.toast button:hover{color:#4a5568}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.profile-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-name{font-size:1.5rem;font-weight:800;line-height:1.3}.profile-email{color:#718096;font-size:.9rem}.profile-tabs{display:flex;gap:.25rem;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem}.profile-tab{padding:.65rem 1.25rem;border:none;background:none;font-size:.9rem;font-weight:600;color:#718096;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.profile-tab:hover{color:#4a5568}.profile-tab.active{color:#4c6ef5;border-bottom-color:#4c6ef5}.profile-list{display:flex;flex-direction:column;gap:1rem}.profile-card{display:flex;gap:1.25rem;background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000012;overflow:hidden;transition:box-shadow .2s,transform .2s;text-decoration:none;color:inherit}.profile-card:hover{box-shadow:0 4px 16px #0000001c;transform:translateY(-1px);text-decoration:none}.profile-card-img{width:180px;min-height:130px;object-fit:cover;flex-shrink:0}.profile-card-body{flex:1;padding:1rem 1.25rem 1rem 0;display:flex;flex-direction:column;gap:.5rem}.profile-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.profile-card-title{font-size:1rem;font-weight:700;line-height:1.4}.profile-card-stats{display:flex;justify-content:space-between;font-size:.82rem;color:#4a5568}.profile-card-stats strong{color:#1a202c}.profile-card-meta{display:flex;gap:.75rem;font-size:.78rem;color:#a0aec0}.profile-card-msg{color:#718096;font-size:.85rem;font-style:italic}.nav-profile-link{color:#4a5568!important;font-weight:500}.nav-profile-link:hover{color:#4c6ef5!important;text-decoration:none}.account-section{max-width:480px}.account-card{background:#fff;border-radius:12px;padding:1.75rem;box-shadow:0 1px 4px #00000012}.account-card h2{font-size:1.15rem;font-weight:700;margin-bottom:1.25rem}.account-field{margin-bottom:1rem}.account-field label{font-size:.8rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.04em}.account-field p{font-size:1rem;color:#1a202c;margin-top:.2rem}.account-hint{color:#a0aec0;font-size:.85rem;margin-top:1rem;font-style:italic}@media(max-width:600px){.profile-card{flex-direction:column}.profile-card-img{width:100%;height:160px}.profile-card-body{padding:1rem}}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}
