*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#333}.navbar{background:#fff;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:1000}.nav-container{max-width:1200px;margin:0 auto;padding:15px 20px;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.5em;font-weight:700;color:#667eea;text-decoration:none;transition:opacity .3s ease;display:flex;align-items:center;gap:12px}.nav-logo:hover{opacity:.8}.logo-image{height:40px;width:auto}.nav-links{display:flex;gap:30px;align-items:center}.nav-link{color:#495057;text-decoration:none;font-weight:500;font-size:1em;transition:color .3s ease;padding:8px 12px;border-radius:5px}.nav-link:hover{color:#667eea;background:#f8f9fa}.nav-link.active{color:#667eea;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;opacity:0;transition:opacity .3s ease}.modal-overlay.active{opacity:1}.modal-content{background:#fff;padding:40px;border-radius:15px;text-align:center;max-width:450px;width:90%;box-shadow:0 10px 40px #0003;transform:scale(.9);transition:transform .3s ease}.modal-overlay.active .modal-content{transform:scale(1)}.modal-icon{font-size:4em;margin-bottom:20px}.modal-title{color:#28a745;margin-bottom:15px;font-size:1.5em}.modal-message{color:#6c757d;margin-bottom:30px;line-height:1.6;font-size:1.1em}.modal-btn{min-width:120px}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:80px 20px;text-align:center}.hero h1{font-size:3em;margin-bottom:20px;font-weight:700}.hero p{font-size:1.3em;margin-bottom:30px;opacity:.95}.hero-buttons{display:flex;gap:15px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:30px}.cta-button{background:#fff;color:#667eea;padding:15px 40px;border:none;border-radius:50px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-block;text-decoration:none;position:relative;overflow:hidden;min-width:160px}.cta-primary{background:#fff;color:#667eea;border:2px solid white}.cta-secondary{background:transparent;color:#fff;border:2px solid white}.cta-button:hover{transform:translateY(-3px);box-shadow:0 10px 25px #0000004d}.cta-primary:hover{background:#f8f9fa}.cta-secondary:hover{background:#ffffff26}.cta-button:active{transform:translateY(-1px);box-shadow:0 5px 15px #0003}.cta-button:focus{outline:none;box-shadow:0 0 0 3px #fff6}.container{max-width:1200px;margin:0 auto;padding:60px 20px}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-bottom:60px}.feature-card{background:#f8f9fa;padding:30px;border-radius:15px;text-align:center;transition:transform .3s}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:3em;margin-bottom:15px}.feature-card h3{margin-bottom:10px;color:#667eea}.section-title{text-align:center;font-size:2.5em;margin-bottom:50px;color:#333}.inventory-samples{margin-top:40px}.sample-tabs{display:flex;justify-content:center;gap:20px;margin-bottom:30px}.tab-button{background:#e9ecef;border:none;padding:12px 30px;border-radius:25px;cursor:pointer;font-size:1em;font-weight:600;transition:all .3s}.tab-button.active{background:#667eea;color:#fff}.inventory-view{display:none;animation:fadeIn .5s}.inventory-view.active{display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.inventory-list{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px #0000001a}.list-header{background:#667eea;color:#fff;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr;padding:15px 20px;font-weight:600}.list-item{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr;padding:20px;border-bottom:1px solid #e9ecef;align-items:center;transition:background .2s}.list-item:hover{background:#f8f9fa}.status-badge{display:inline-block;padding:5px 15px;border-radius:20px;font-size:.85em;font-weight:600}.status-donate{background:#d4edda;color:#155724}.status-exchange{background:#fff3cd;color:#856404}.expiry-warning{color:#dc3545;font-weight:600}.expiry-caution{color:#fd7e14;font-weight:600}.expiry-safe{color:#28a745;font-weight:600}.action-btn{background:#667eea;color:#fff;border:none;padding:8px 20px;border-radius:20px;cursor:pointer;font-size:.9em;transition:background .3s}.action-btn:hover{background:#5568d3}.inventory-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px}.inventory-card{background:#fff;border-radius:15px;padding:25px;box-shadow:0 5px 20px #0000001a;transition:transform .3s,box-shadow .3s}.inventory-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026}.card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:15px}.card-title{font-size:1.2em;font-weight:600;color:#333}.card-details{margin:15px 0}.card-detail-row{display:flex;justify-content:space-between;margin:8px 0;font-size:.95em}.card-detail-label{color:#6c757d}.card-footer{margin-top:20px;padding-top:20px;border-top:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.department-tag{background:#e9ecef;padding:5px 12px;border-radius:15px;font-size:.85em;color:#495057}.inventory-compact{background:#fff;border-radius:15px;padding:30px;box-shadow:0 5px 20px #0000001a}.compact-item{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid #e9ecef}.compact-item:last-child{border-bottom:none}.compact-left{flex:1}.compact-name{font-weight:600;margin-bottom:5px}.compact-meta{font-size:.85em;color:#6c757d}.compact-right{display:flex;align-items:center;gap:20px}.quantity-display{font-size:1.2em;font-weight:600;color:#667eea}@media(max-width:768px){.nav-container{padding:12px 15px}.nav-logo{font-size:1.2em;gap:8px}.logo-image{height:32px}.nav-links{gap:15px}.nav-link{font-size:.9em;padding:6px 10px}.hero{padding:60px 20px}.hero h1{font-size:2em}.hero p{font-size:1.1em}.hero-buttons{flex-direction:column;gap:12px;width:100%;padding:0 20px}.cta-button{width:100%;max-width:300px;padding:14px 30px;font-size:1em}.list-header,.list-item{grid-template-columns:1fr;gap:10px}.list-header{display:none}.compact-right{flex-direction:column;gap:10px}.modal-content{padding:30px 20px;width:95%}.modal-title{font-size:1.3em}.modal-message{font-size:1em}}.hero-small{padding:60px 20px}.hero-small h1{font-size:2.5em;margin-bottom:10px}.hero-small p{font-size:1.2em;margin-bottom:0}.access-request-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:40px}.info-section{display:flex;flex-direction:column;gap:20px}.info-section h2{font-size:2em;color:#333;margin-bottom:10px}.info-card{background:#f8f9fa;padding:25px;border-radius:15px;box-shadow:0 2px 10px #0000000d}.info-card h3{color:#667eea;margin-bottom:15px;font-size:1.2em}.info-card p{margin-bottom:10px;color:#495057}.info-card ul{margin-left:20px;color:#495057}.info-card ul li{margin:8px 0;line-height:1.6}.warning-card{background:#fff3cd;border-left:4px solid #ffc107}.warning-card h3{color:#856404}.form-section{position:sticky;top:20px;height:-moz-fit-content;height:fit-content}.form-card{background:#fff;padding:35px;border-radius:15px;box-shadow:0 5px 20px #0000001a}.form-card h2{color:#333;margin-bottom:10px;font-size:1.8em}.form-subtitle{color:#6c757d;margin-bottom:30px;font-size:.95em}.access-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:8px;color:#333;font-size:.95em}.required{color:#dc3545;margin-left:2px}.form-group input[type=text],.form-group input[type=email],.form-group input[type=tel],.form-group select{padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:1em;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-hint{color:#6c757d;font-size:.85em;margin-top:5px}.checkbox-group{flex-direction:row;align-items:flex-start}.checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{margin-top:3px;width:18px;height:18px;cursor:pointer;accent-color:#667eea}.checkbox-label span{flex:1;font-size:.9em;color:#495057;line-height:1.5}.form-actions{display:flex;gap:15px;margin-top:10px}.btn-primary,.btn-secondary{padding:14px 30px;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;flex:1}.btn-primary{background:#667eea;color:#fff;border:2px solid #667eea}.btn-primary:hover{background:#5568d3;border-color:#5568d3;transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea}.btn-secondary:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.btn-secondary:active{transform:translateY(0)}@media(max-width:992px){.access-request-wrapper{grid-template-columns:1fr;gap:30px}.form-section{position:static}.info-section{order:2}.form-section{order:1}}@media(max-width:768px){.hero-small h1{font-size:2em}.hero-small p{font-size:1em}.form-card{padding:25px 20px}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.login-container{min-height:calc(100vh - 60px);display:flex;justify-content:center;align-items:center;padding:40px 20px;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;padding:50px;border-radius:20px;box-shadow:0 10px 40px #0003;max-width:480px;width:100%}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:2.2em;color:#333;margin-bottom:10px}.login-header p{color:#6c757d;font-size:1em}.login-info{margin-bottom:30px}.info-badge{background:#e7f3ff;border-left:4px solid #667eea;padding:15px;border-radius:8px;display:flex;align-items:center;gap:10px}.info-icon{font-size:1.2em}.info-badge span{color:#495057;font-size:.9em;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:20px}.passwordless-info{background:#f8f9fa;padding:15px;border-radius:8px;text-align:center}.passwordless-info p{margin:5px 0;color:#495057;font-size:.9em}.passwordless-info p:first-child{font-weight:600;color:#667eea}.btn-full{width:100%}.login-footer{margin-top:25px;text-align:center;padding-top:20px;border-top:1px solid #e9ecef}.login-footer p{color:#6c757d;font-size:.9em}.login-footer a{color:#667eea;text-decoration:none;font-weight:600}.login-footer a:hover{text-decoration:underline}.verify-card{max-width:550px}.code-inputs{display:flex;gap:12px;justify-content:center;margin:30px 0}.code-input{width:60px;height:70px;font-size:2em;text-align:center;border:2px solid #e9ecef;border-radius:10px;font-weight:600;color:#333;transition:all .3s ease}.code-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;transform:scale(1.05)}.code-input:not(:-moz-placeholder){border-color:#667eea;background:#f8f9ff}.code-input:not(:placeholder-shown){border-color:#667eea;background:#f8f9ff}.verify-footer{margin-top:25px;text-align:center;padding-top:20px;border-top:1px solid #e9ecef}.verify-footer p{color:#6c757d;font-size:.9em;margin:10px 0}.verify-footer a{color:#667eea;text-decoration:none;font-weight:600}.verify-footer a:hover{text-decoration:underline}.message-toast{position:fixed;top:80px;right:20px;background:#fff;padding:15px 25px;border-radius:10px;box-shadow:0 5px 20px #0003;z-index:3000;transform:translate(400px);transition:transform .3s ease;font-weight:500}.message-toast.show{transform:translate(0)}.message-toast.success{border-left:4px solid #28a745;color:#28a745}.message-toast.error{border-left:4px solid #dc3545;color:#dc3545}@media(max-width:768px){.login-card{padding:35px 25px}.login-header h1{font-size:1.8em}.code-inputs{gap:8px}.code-input{width:45px;height:55px;font-size:1.5em}.message-toast{right:10px;left:10px;top:70px}}.dashboard-container{max-width:1400px;margin:0 auto;padding:40px 20px}.dashboard-header{margin-bottom:40px}.dashboard-header h1{font-size:2.5em;color:#333;margin-bottom:10px}.dashboard-header p{color:#6c757d;font-size:1.1em}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:25px;margin-bottom:50px}.stat-card{background:#fff;padding:30px;border-radius:15px;box-shadow:0 3px 15px #00000014;display:flex;align-items:center;gap:20px;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.stat-icon{font-size:3em;width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:15px}.stat-donations .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-requests .stat-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-pending .stat-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-content h3{color:#6c757d;font-size:.95em;font-weight:600;margin-bottom:10px}.stat-number{font-size:2.5em;font-weight:700;color:#333;margin-bottom:5px}.stat-label{color:#6c757d;font-size:.9em}.dashboard-section{margin-bottom:50px}.section-header{margin-bottom:30px}.section-header h2{font-size:2em;color:#333;margin-bottom:10px}.section-header p{color:#6c757d;font-size:1em}.requests-list{display:flex;flex-direction:column;gap:20px}.request-card{background:#fff;padding:25px;border-radius:15px;box-shadow:0 3px 15px #00000014;transition:all .3s ease}.request-card:hover{box-shadow:0 8px 25px #0000001f}.request-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #e9ecef}.request-header h3{color:#333;font-size:1.3em;margin-bottom:8px}.request-meta{color:#6c757d;font-size:.9em}.status-pending{background:#fff3cd;color:#856404}.request-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-label{color:#6c757d;font-size:.85em;font-weight:500}.detail-value{color:#333;font-size:1em;font-weight:600}.request-actions{display:flex;gap:12px}.btn-approve,.btn-decline{padding:10px 25px;border-radius:8px;font-size:.95em;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-approve{background:#28a745;color:#fff}.btn-approve:hover:not(:disabled){background:#218838;transform:translateY(-2px);box-shadow:0 5px 15px #28a7454d}.btn-decline{background:#dc3545;color:#fff}.btn-decline:hover:not(:disabled){background:#c82333;transform:translateY(-2px);box-shadow:0 5px 15px #dc35454d}.btn-approve:disabled,.btn-decline:disabled{opacity:.5;cursor:not-allowed}.upload-section{display:grid;grid-template-columns:1fr 1fr;gap:30px}.upload-info{display:flex;flex-direction:column;gap:20px}.future-feature{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.future-feature h3{color:#fff}.future-feature p,.future-feature ul li{color:#fffffff2}.upload-area{background:#fff;padding:30px;border-radius:15px;box-shadow:0 3px 15px #00000014}.upload-box{border:3px dashed #cbd5e0;border-radius:15px;padding:60px 30px;text-align:center;transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:15px}.upload-box:hover{border-color:#667eea;background:#f8f9ff}.upload-box.drag-over{border-color:#667eea;background:#f8f9ff;transform:scale(1.02)}.upload-icon{font-size:4em}.upload-box h3{color:#333;margin-bottom:5px}.upload-box p{color:#6c757d;margin-bottom:15px}.btn-upload{background:#667eea;color:#fff;padding:12px 30px;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-upload:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.upload-preview{display:flex;flex-direction:column;gap:20px}.preview-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:15px;border-bottom:1px solid #e9ecef}.preview-header h3{color:#333}.btn-remove{background:#dc3545;color:#fff;padding:8px 20px;border:none;border-radius:8px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-remove:hover{background:#c82333}#previewImage{width:100%;max-height:400px;-o-object-fit:contain;object-fit:contain;border-radius:10px;border:1px solid #e9ecef}.preview-info p{color:#6c757d;font-size:.9em;margin:5px 0}.upload-note{text-align:center;color:#6c757d;font-size:.85em;margin-top:10px}@media(max-width:992px){.upload-section{grid-template-columns:1fr}.upload-info{order:2}.upload-area{order:1}}@media(max-width:768px){.dashboard-header h1{font-size:2em}.stats-grid{grid-template-columns:1fr}.stat-card{padding:20px}.stat-icon{width:60px;height:60px;font-size:2em}.stat-number{font-size:2em}.request-header{flex-direction:column;gap:15px}.request-details{grid-template-columns:1fr}.request-actions{flex-direction:column}.btn-approve,.btn-decline{width:100%}.upload-box{padding:40px 20px}.upload-icon{font-size:3em}}
