:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Roboto,sans-serif!important}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}nav{font-weight:600}#root{margin:0 auto;min-height:100vh}.app{min-height:100vh}th,td{padding-left:1rem;padding-right:1rem}.form-section{background-color:#f8f9fa;border-radius:10px;padding:25px;margin-bottom:30px;box-shadow:0 2px 10px #0000001a}.form-header{margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #dc3545}.required-field:after{content:" *";color:#dc3545}.donation-options .form-check-label{cursor:pointer}.donation-options .form-check-input:checked+.form-check-label{font-weight:700;color:#dc3545}.table-responsive{overflow:hidden}.table thead{background-color:#dc3545;color:#fff}.input-sm input[type=number]{max-width:3rem}.stepper-wrapper{margin-top:auto;justify-content:space-between;margin-bottom:20px}.stepper-item{position:relative;display:flex;flex-direction:column;align-items:center;flex:1}.stepper-item:before{position:absolute;content:"";border-bottom:2px solid #ccc;width:100%;top:20px;left:-50%;z-index:2}.stepper-item:after{position:absolute;content:"";border-bottom:2px solid #ccc;width:100%;top:20px;left:50%;z-index:2}.stepper-item .step-counter{position:relative;z-index:5;display:flex;justify-content:center;align-items:center;width:40px;height:40px;border-radius:50%;background:#fff;border:2px solid #ccc;margin-bottom:6px;color:#6c757d;font-weight:600}.stepper-item.active .step-counter{background-color:#0d6efd;color:#fff;border-color:#0d6efd}.stepper-item.completed .step-counter{background-color:#198754;color:#fff;border-color:#198754}.stepper-item.completed:after{position:absolute;content:"";border-bottom:2px solid #198754;width:100%;top:20px;left:50%;z-index:3}.stepper-item:first-child:before{content:none}.stepper-item:last-child:after{content:none}.step-name{font-size:.875rem;color:#6c757d;text-align:center;font-weight:600}.stepper-item.active .step-name{color:#0d6efd;font-weight:600}.stepper-item.completed .step-name{color:#198754}.btn-wrapper{display:flex;justify-content:space-between}.btn-wrapper button,.btn-wrapper a.btn{flex:1;margin:0 5px}.header{background-color:#2c3e50;color:#fff;padding:.5rem 0;box-shadow:0 2px 4px #0000001a}.header-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 1rem}.logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.nav{display:flex;gap:1rem;align-items:center}.nav a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .3s}.nav a:hover{background-color:#ffffff1a}.logout-btn{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background-color .3s}.logout-btn:hover{background-color:#c0392b}:root{--primary: #e74c3c;--secondary: #3498db;--accent: #2c3e50;--light: #f8f9fa;--dark: #212529}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#333;background-color:#f8f9fa}.navbar{box-shadow:0 2px 10px #0000001a;background:linear-gradient(to right,#e74c3c,#c0392b);padding:1rem 0}.navbar-brand{font-weight:700;font-size:1.8rem;color:#fff!important}.nav-link{color:#ffffffe6;font-weight:500;margin:0 10px;transition:all .3s}.nav-link:hover{transform:translateY(-3px)}.hero-section{background:linear-gradient(#e74c3ce6,#c0392be6),url(https://images.unsplash.com/photo-1576091160399-112ba8d25d1d?ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D&auto=format&fit=crop&w=1920&q=80);background-size:cover;background-position:center;color:#fff;padding:100px 0;margin-bottom:50px}.hero-title{font-weight:800;font-size:3.5rem;margin-bottom:20px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.hero-subtitle{font-size:1.5rem;margin-bottom:30px;max-width:800px}.button-primary{background:#3498db;color:#fff;border:none;padding:14px 30px;font-weight:600;border-radius:50px;transition:all .3s;box-shadow:0 4px 15px #3498db4d}.button-primary:hover{background:#2980b9;transform:translateY(-3px);box-shadow:0 6px 20px #3498db66}.button-outline-white{border:2px solid white;color:#fff;padding:12px 30px;font-weight:600;border-radius:50px;transition:all .3s}.button-outline-white:hover{background:#fff;color:#e74c3c;transform:translateY(-3px)}.feature-card{background:#fff;border-radius:15px;padding:30px;margin:20px 0;box-shadow:0 5px 15px #0000000d;transition:all .3s;text-align:center;height:100%}.feature-card:hover{transform:translateY(-10px);box-shadow:0 15px 30px #0000001a}.feature-icon{font-size:3rem;color:#e74c3c;margin-bottom:20px}.feature-title{font-weight:700;margin-bottom:15px;color:#2c3e50}.stats-section{background:linear-gradient(to right,#2c3e50,#34495e);color:#fff;padding:60px 0;margin:50px 0}.stat-number{font-size:3rem;font-weight:800;margin-bottom:10px}.stat-text{font-size:1.2rem;opacity:.9}.testimonial-card{background:#fff;border-radius:15px;padding:30px;margin:20px;box-shadow:0 5px 15px #0000000d;border-left:5px solid #e74c3c}.testimonial-text{font-style:italic;margin-bottom:20px;position:relative}.testimonial-text:before{content:"";font-size:4rem;position:absolute;left:-20px;top:-30px;color:#e74c3c;opacity:.3;font-family:Georgia,serif}.testimonial-author{display:flex;align-items:center}.author-avatar{width:50px;height:50px;border-radius:50%;overflow:hidden;margin-right:15px;background:#ecf0f1;display:flex;align-items:center;justify-content:center;font-weight:700;color:#e74c3c}.author-name{font-weight:700}.author-position{font-size:.9rem;opacity:.8}.cta-section{background:linear-gradient(to right,#e74c3c,#c0392b);color:#fff;padding:80px 0;margin:50px 0;border-radius:15px}.cta-title{font-weight:800;margin-bottom:20px}.footer{background:#2c3e50;color:#fff;padding:50px 0 20px}.footer-title{font-weight:700;margin-bottom:20px;position:relative;padding-bottom:10px}.footer-title:after{content:"";position:absolute;bottom:0;left:0;width:50px;height:3px;background:#e74c3c}.footer-link{color:#bdc3c7;text-decoration:none;margin-bottom:10px;display:block;transition:all .3s}.footer-link:hover{color:#e74c3c;padding-left:5px}.social-icon{width:40px;height:40px;border-radius:50%;background:#ffffff1a;display:inline-flex;align-items:center;justify-content:center;margin-right:10px;transition:all .3s}.social-icon:hover{background:#e74c3c;transform:translateY(-3px)}.copyright{text-align:center;padding-top:20px;margin-top:30px;border-top:1px solid rgba(255,255,255,.1);opacity:.7}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.2rem}.btn{margin:10px 0}}.login-container{display:flex;justify-content:center;align-items:center;padding:1rem}.login-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.login-form h2{text-align:center;margin-bottom:1.5rem;color:#2c3e50}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#3498db}.error-message{background-color:#e74c3c;color:#fff;padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center}.login-info{margin-top:1rem;padding:1rem;background-color:#ecf0f1;border-radius:4px;font-size:.875rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;transition:transform .3s ease}.card:hover{transform:translateY(-5px)}.card-icon{font-size:2rem;margin-right:15px;color:#3498db}.card-content h3{font-size:1.8rem;margin-bottom:5px;color:#2c3e50}.card-content p{color:#7f8c8d;font-size:.9rem}@media (max-width: 768px){.summary-cards{grid-template-columns:1fr 1fr}}.blood-stock-chart{height:400px;margin-bottom:30px}@media (max-width: 768px){.blood-stock-chart{height:300px}}.blood-requests-chart{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.chart-container{background:#fff;padding:20px;border-radius:10px;box-shadow:0 4px 6px #0000001a}.chart-container h4{margin-bottom:15px;color:#2c3e50}@media (max-width: 768px){.blood-requests-chart{grid-template-columns:1fr}}.recent-requests-table{background:#fff;border-radius:10px;padding:20px;box-shadow:0 4px 6px #0000001a;overflow-x:auto}.recent-requests-table table{width:100%;border-collapse:collapse}.recent-requests-table th,.recent-requests-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.recent-requests-table th{background-color:#f8f9fa;font-weight:600;color:#2c3e50}.recent-requests-table tr:hover{background-color:#f8f9fa}.recent-requests-table .status{padding:5px 10px;border-radius:20px;font-size:.8rem;font-weight:500}.status.pending{background-color:#fff8e1;color:#ff8f00}.recent-requests-table .status.processing{background-color:#e3f2fd;color:#1976d2}.status.completed{background-color:#e8f5e9;color:#2e7d32}.recent-requests-table .status.cancelled{background-color:#ffebee;color:#c62828}.blood-types-table{background:#fff;border-radius:10px;padding:20px;box-shadow:0 4px 6px #0000001a;overflow-x:auto}.blood-types-table table{width:100%;border-collapse:collapse}.blood-types-table th,.blood-types-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.blood-types-table th{background-color:#f8f9fa;font-weight:600;color:#2c3e50}.blood-types-table tr:hover{background-color:#f8f9fa}.status{padding:5px 10px;border-radius:20px;font-size:.8rem;font-weight:500}.status.low{background-color:#ffebee;color:#c62828}.status.normal{background-color:#e8f5e9;color:#2e7d32}.blood-types-table tfoot td{font-weight:600;background-color:#f8f9fa}.setting-card{border:1px solid #dee2e6;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s;height:100%}.setting-card:hover{transform:translateY(-3px);box-shadow:0 4px 8px #00000026}.setting-card .card-title{margin-bottom:.5rem;color:#333}.setting-card .card-text{margin-bottom:0}.custom-control-label:before{background-color:#007bff;border-color:#007bff}.custom-control-input:checked+.custom-control-label:before{background-color:#28a745;border-color:#28a745}.custom-control-input:checked+.custom-control-label:after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23fff' d='M6.564.75l-3.54 3.54 1.5 1.5 2.01-2.01L7.5 4.5l-1.5-1.5L6.564.75z'/%3e%3c/svg%3e")}@media (max-width: 768px){.setting-card{margin-bottom:1rem}}
