.exchange-index-container{background:linear-gradient(135deg, #f0fdf4 0%, #f7fafc 100%);min-height:100vh}.exchange-header{background:linear-gradient(135deg, #188550 0%, #22c55e 100%);padding:32px;border-radius:16px;box-shadow:0 8px 24px rgba(24,133,80,0.2);margin-bottom:24px}.exchange-title{font-size:32px;font-weight:700;color:white;margin:0;text-shadow:0 2px 4px rgba(0,0,0,0.1)}.exchange-title i{color:#fef3c7}.exchange-subtitle{color:rgba(255,255,255,0.9);margin:8px 0 0 0;font-size:16px;font-weight:500}.nav-tabs{border-bottom:none;background:white;padding:8px;border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,0.08);margin-bottom:24px}.nav-tabs .nav-link{border:none;color:#64748b;font-weight:600;padding:14px 28px;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);border-radius:12px;margin:0 4px;position:relative}.nav-tabs .nav-link:hover{color:#188550;background:#f0fdf4;transform:translateY(-2px)}.nav-tabs .nav-link.active{color:white;background-color:#188550;box-shadow:0 4px 12px rgba(24,133,80,0.3);transform:translateY(-2px)}.nav-tabs .nav-link i{font-size:18px}.create-post-box{background:white;border-radius:16px;padding:20px;box-shadow:0 4px 16px rgba(0,0,0,0.08);border:2px solid #f0fdf4;transition:all 0.3s}.create-post-box:hover{box-shadow:0 8px 24px rgba(24,133,80,0.15);border-color:#bbf7d0}.create-post-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:2px solid #f0fdf4}.user-avatar-small{width:48px;height:48px;border-radius:50%;object-fit:cover;border:3px solid #188550;box-shadow:0 2px 8px rgba(24,133,80,0.2)}.create-post-input{flex:1;background:#f7fafc;border:2px solid #e2e8f0;border-radius:28px;padding:14px 24px;text-align:left;color:#94a3b8;font-size:15px;cursor:pointer;transition:all 0.3s;font-weight:500}.create-post-input:hover{background:#f0fdf4;border-color:#bbf7d0;color:#188550;transform:translateY(-1px)}.create-post-actions{display:flex;gap:12px}.action-btn{flex:1;background:white;border:2px solid #e2e8f0;padding:12px 16px;border-radius:12px;display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all 0.3s;font-weight:600;color:#475569}.action-btn:hover{background:#f0fdf4;border-color:#188550;transform:translateY(-2px);box-shadow:0 4px 12px rgba(24,133,80,0.15)}.action-btn:hover .text-primary{color:#188550 !important}.action-btn:hover .text-success{color:#188550 !important}.action-btn i{font-size:22px}.post-card{background:white;border-radius:20px;padding:0;box-shadow:0 2px 12px rgba(0,0,0,0.08);border:1px solid #e5e7eb;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);position:relative;overflow:hidden}.post-card:hover{box-shadow:0 8px 24px rgba(24,133,80,0.12);border-color:#bbf7d0;transform:translateY(-2px)}.post-type-badge{position:absolute;top:20px;right:20px;padding:8px 18px;border-radius:20px;font-weight:700;font-size:12px;display:flex;align-items:center;gap:6px;z-index:10;color:white;text-transform:uppercase;letter-spacing:0.5px}.post-type-badge i{font-size:14px}.post-type-badge.badge-borrow{background:linear-gradient(135deg, #188550 0%, #58D77A 100%)}.post-type-badge.badge-gift{background:linear-gradient(135deg, #FFB118 0%, #FFC942 100%)}.post-type-badge.badge-sell{background:linear-gradient(135deg, #FF6B6B 0%, #FF8E8E 100%)}.post-type-badge.badge-mixed{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.post-header{display:flex;align-items:center;gap:14px;padding:24px 24px 20px 24px;background:white}.user-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb;box-shadow:0 2px 6px rgba(0,0,0,0.08);transition:all 0.3s}.post-card:hover .user-avatar{border-color:#188550;box-shadow:0 2px 8px rgba(24,133,80,0.2)}.post-user-info{flex:1}.user-name{font-weight:700;color:#1e293b;margin:0 0 6px 0;font-size:15px}.post-time{color:#6b7280;font-size:13px;margin:0;display:flex;align-items:center;gap:6px}.post-time i{font-size:12px;color:#9ca3af}.post-content-section{padding:0 24px 20px 24px}.post-title{font-size:18px;font-weight:700;color:#111827;margin:0 0 10px 0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-description{color:#6b7280;font-size:14px;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-books-section{padding:20px 24px;background:#f9fafb;border-top:1px solid #e5e7eb}.books-section-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;color:#188550;font-weight:600;font-size:13px}.books-section-header i{font-size:15px}.books-preview-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:10px}.book-preview-item{aspect-ratio:2/3;border-radius:10px;overflow:hidden;position:relative;box-shadow:0 2px 8px rgba(0,0,0,0.1);transition:all 0.3s;cursor:pointer;border:2px solid transparent}.book-preview-item:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(24,133,80,0.2);border-color:#188550}.book-preview-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s}.book-preview-item:hover img{transform:scale(1.05)}.book-preview-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top, rgba(0,0,0,0.85), transparent);padding:10px 8px 6px;opacity:0;transition:opacity 0.3s}.book-preview-item:hover .book-preview-overlay{opacity:1}.book-preview-title{color:white;font-size:11px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.book-preview-more{aspect-ratio:2/3;background:linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);border:2px dashed #bbf7d0;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;color:#188550;gap:4px;transition:all 0.3s}.book-preview-more:hover{background:linear-gradient(135deg, #dcfce7 0%, #bbf7d0 100%);border-color:#188550}.book-preview-more span{font-size:22px}.book-preview-more small{font-size:10px;font-weight:600}.post-footer{display:flex;align-items:center;justify-content:end;padding:18px 24px;background:white;border-top:1px solid #f3f4f6}.post-stats{display:flex;gap:16px}.stat-item{color:#6b7280;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}.stat-item i{color:#188550;font-size:15px}.btn-view-detail{background-color:#188550;color:white;border:none;padding:10px 20px;font-weight:600;border-radius:12px;transition:all 0.3s;box-shadow:0 2px 8px rgba(24,133,80,0.25);text-decoration:none;display:inline-flex;align-items:center;gap:8px;font-size:14px}.btn-view-detail:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(24,133,80,0.35);color:white;text-decoration:none}.btn-view-detail i{font-size:12px;transition:transform 0.3s}.btn-view-detail:hover i{transform:translateX(3px)}.book-card{background:white;border-radius:16px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,0.06);transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);cursor:pointer;border:2px solid transparent;position:relative}.book-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg, rgba(24,133,80,0.1) 0%, transparent 100%);opacity:0;transition:opacity 0.3s}.book-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 40px rgba(24,133,80,0.2);border-color:#188550}.book-card:hover::after{opacity:1}.book-cover{width:100%;aspect-ratio:2/3;object-fit:cover}.book-info{padding:12px}.book-title{font-weight:600;color:#1a202c;font-size:14px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.book-author{color:#718096;font-size:12px;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-card{background:white;border-radius:16px;padding:24px;box-shadow:0 4px 16px rgba(0,0,0,0.06);border:2px solid #f0fdf4;transition:all 0.3s}.sidebar-card:hover{box-shadow:0 8px 24px rgba(24,133,80,0.1);border-color:#bbf7d0}.sidebar-title{font-weight:700;color:#188550;margin-bottom:20px;font-size:18px;display:flex;align-items:center;gap:8px}.sidebar-title i{font-size:20px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f0fdf4;border-radius:12px;margin-bottom:12px;transition:all 0.3s}.stat-item:hover{background:#dcfce7;transform:translateX(4px)}.stat-item:last-child{margin-bottom:0}.stat-item span{color:#64748b;font-size:14px;font-weight:600}.stat-item strong{color:#188550;font-size:24px;font-weight:700}.empty-state{text-align:center;padding:80px 20px;background:white;border-radius:16px;box-shadow:0 4px 16px rgba(0,0,0,0.06);border:2px dashed #d1fae5}.empty-state i{font-size:80px;color:#bbf7d0;margin-bottom:24px;animation:float 3s ease-in-out infinite}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-state h5{color:#188550;margin-bottom:12px;font-weight:700;font-size:20px}.empty-state p{color:#64748b;font-size:15px}.loading-more{text-align:center;padding:30px 20px;color:#188550;font-weight:600;display:flex;align-items:center;justify-content:center;gap:12px}.loading-more i{font-size:20px}.end-of-results{text-align:center;padding:30px 20px;color:#6b7280;font-weight:500;display:flex;align-items:center;justify-content:center;gap:10px;background:#f9fafb;border-radius:12px;margin-top:20px}.end-of-results i{color:#188550;font-size:18px}.mobile-filter-container{display:none}.mobile-filter-toggle{display:flex;justify-content:space-between;align-items:center;background:white;border:2px solid #e5e7eb;border-radius:12px;padding:14px 18px;cursor:pointer;transition:all 0.3s;font-weight:600;color:#374151}.mobile-filter-toggle:hover{background:#f0fdf4;border-color:#188550;color:#188550}.mobile-filter-dropdown{background:white;border:2px solid #e5e7eb;border-top:none;border-radius:0 0 12px 12px;margin-top:-2px;animation:slideDown 0.3s ease-out}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-filter-dropdown .filter-content{padding:16px}.mobile-filter-dropdown .filter-group{margin-bottom:16px}.mobile-filter-dropdown .filter-group:last-of-type{margin-bottom:0}.mobile-filter-dropdown .filter-label{display:block;font-weight:600;color:#374151;margin-bottom:8px;font-size:14px}.mobile-filter-dropdown .form-control,.mobile-filter-dropdown .form-select{font-size:14px;padding:10px 14px}.mobile-filter-dropdown .search-input-wrapper{position:relative}.mobile-filter-dropdown .clear-search-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:#e5e7eb;border:none;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;color:#6b7280}.mobile-filter-dropdown .clear-search-btn:hover{background:#d1d5db;color:#374151}.mobile-filter-dropdown .filter-actions{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.mobile-filter-dropdown .filter-actions .btn{flex:1;font-size:14px}.mobile-filter-dropdown .filter-actions .btn-success{background:#188550 !important;border-color:#188550 !important;color:white !important}.mobile-filter-dropdown .filter-actions .btn-success:hover{background:#166d42 !important;border-color:#166d42 !important}@media (max-width: 768px){.exchange-title{font-size:22px}.create-post-actions{flex-direction:column}.books-grid{grid-template-columns:repeat(2, 1fr)}.sidebar-card{margin-top:16px}.index-nav-tabs{display:flex;justify-content:center;padding:4px}.index-nav-tabs .nav-item{flex:1}.index-nav-tabs .nav-link{width:100%;text-align:center;padding:12px 16px;font-size:14px}.create-post-actions.desktop-only{display:none !important}.mobile-filter-container{display:block}.desktop-filter-sidebar{display:none !important}.row{margin:0}.col-lg-8,.col-lg-4{padding:0}.post-card{border-radius:16px;margin-bottom:16px}.post-type-badge{top:12px;right:12px;padding:6px 12px;font-size:11px}.post-header{padding:16px 16px 12px 16px}.post-content-section{padding:0 16px 16px 16px}.post-title{font-size:16px}.post-description{font-size:13px}.post-books-section{padding:16px}.books-preview-grid{grid-template-columns:repeat(3, 1fr);gap:8px}.post-footer{padding:14px 16px;flex-direction:column;gap:12px;align-items:stretch}.post-stats{justify-content:center}.btn-view-detail{width:100%;justify-content:center}.books-grid-mobile{margin:0 -8px}.books-grid-mobile>div{padding:0 8px}.book-card-item{border-radius:12px}.book-card-image{height:180px}.book-card-body{padding:10px}.book-card-title{font-size:13px;min-height:36px}.book-card-author{font-size:12px}.book-card-meta{flex-wrap:wrap;gap:4px}.book-card-meta .condition-badge{font-size:10px;padding:3px 8px}.book-card-price{font-size:12px}.book-card-location{font-size:11px;padding:4px 8px}.book-card-post{padding-top:8px}.post-user-avatar{width:20px;height:20px}.post-user-name{font-size:11px}.book-detail-content{flex-direction:column}.book-detail-image{width:160px;margin:0 auto 20px}.book-detail-title{font-size:20px;text-align:center}.book-detail-author{font-size:14px;justify-content:center}.book-detail-meta{display:grid;grid-template-columns:repeat(2, 1fr);gap:0}.book-detail-meta .meta-item{flex-direction:column;align-items:flex-start;gap:6px;padding:10px 12px;border-bottom:1px solid #e5e7eb}.book-detail-meta .meta-item:nth-child(odd){border-right:1px solid #e5e7eb}.book-detail-meta .meta-label{font-size:12px}.book-detail-meta .meta-value{font-size:13px}}@media (min-width: 769px){.mobile-filter-container{display:none !important}.desktop-filter-sidebar{display:block !important}.desktop-only{display:flex !important}}.badge{padding:6px 14px;border-radius:8px;font-weight:600;font-size:12px;letter-spacing:0.3px}.badge.bg-primary{background:linear-gradient(135deg, #3b82f6 0%, #60a5fa 100%) !important;box-shadow:0 2px 8px rgba(59,130,246,0.3)}.badge.bg-success{background:linear-gradient(135deg, #188550 0%, #22c55e 100%) !important;box-shadow:0 2px 8px rgba(24,133,80,0.3)}.badge.bg-warning{background:linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%) !important;box-shadow:0 2px 8px rgba(245,158,11,0.3)}.badge.bg-info{background:linear-gradient(135deg, #06b6d4 0%, #22d3ee 100%) !important;box-shadow:0 2px 8px rgba(6,182,212,0.3)}.form-control,.form-select{border:2px solid #e2e8f0;border-radius:10px;padding:10px 16px;transition:all 0.3s;font-size:14px}.form-control:focus,.form-select:focus{border-color:#188550;box-shadow:0 0 0 4px rgba(24,133,80,0.1);outline:none}.form-label{font-weight:600;color:#475569;margin-bottom:8px;font-size:14px}.search-input-wrapper{position:relative}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:14px;pointer-events:none}.search-input{padding-left:40px !important;padding-right:40px !important}.clear-search-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:#e5e7eb;border:none;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;color:#6b7280}.clear-search-btn:hover{background:#d1d5db;color:#374151}.active-filters{margin-bottom:16px;padding:12px;background:#f0fdf4;border-radius:8px;border:1px solid #bbf7d0}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#188550;color:white;border-radius:16px;font-size:13px;font-weight:600}.filter-chip i{cursor:pointer;padding:2px;border-radius:50%;transition:background 0.2s}.filter-chip i:hover{background:rgba(255,255,255,0.2)}.filter-section-label{display:flex;align-items:center;font-size:13px;font-weight:700;color:#374151;margin-bottom:12px;text-transform:uppercase;letter-spacing:0.5px}.filter-options{display:grid;grid-template-columns:repeat(2, 1fr);gap:8px;margin-bottom:12px}.filter-option-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:white;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all 0.3s;font-size:13px;font-weight:600;color:#6b7280}.filter-option-btn i{font-size:18px;color:#9ca3af;transition:all 0.3s}.filter-option-btn:hover{border-color:#188550;background:#f0fdf4;color:#188550;transform:translateY(-2px)}.filter-option-btn:hover i{color:#188550}.filter-option-btn.active{border-color:#188550;background-color:#188550;color:white;box-shadow:0 4px 12px rgba(24,133,80,0.3)}.filter-option-btn.active i{color:white}.filter-options-single{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.filter-option-btn-single{display:flex;align-items:center;gap:10px;padding:10px 14px;background:white;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all 0.2s;font-size:14px;font-weight:500;color:#374151;text-align:left}.filter-option-btn-single i{font-size:16px;color:#9ca3af;transition:all 0.2s;width:20px;text-align:center}.filter-option-btn-single span{flex:1}.filter-option-btn-single:hover{border-color:#188550;background:#f0fdf4;color:#188550}.filter-option-btn-single:hover i{color:#188550}.filter-option-btn-single.active{border-color:#188550;background-color:#188550;color:white;font-weight:600}.filter-option-btn-single.active i{color:white}.more-categories-dropdown{display:flex;flex-direction:column;gap:6px;margin-bottom:8px;animation:slideDown 0.3s ease-out}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.btn-toggle-categories{width:100%;padding:10px;background:white;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-toggle-categories:hover{border-color:#188550;color:#188550;background:#f0fdf4}.btn-toggle-categories i{font-size:12px}.btn-reset-filters{width:100%;padding:12px;background:white;border:2px solid #ef4444;border-radius:10px;color:#ef4444;font-weight:600;cursor:pointer;transition:all 0.3s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-reset-filters:hover{background:#ef4444;color:white;transform:translateY(-2px);box-shadow:0 4px 12px rgba(239,68,68,0.3)}.btn-outline-primary{border:2px solid #188550;color:#188550;font-weight:600;border-radius:10px;padding:10px 20px;transition:all 0.3s;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.btn-outline-primary:hover{background:#188550;color:white !important;border-color:#188550;transform:translateY(-2px);box-shadow:0 4px 12px rgba(24,133,80,0.3);text-decoration:none}.btn-outline-primary:focus{outline:none;box-shadow:0 0 0 3px rgba(24,133,80,0.2)}.btn-outline-secondary{border:2px solid #e2e8f0;color:#64748b;font-weight:600;border-radius:10px;transition:all 0.3s}.btn-outline-secondary:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.fa-spinner{color:#188550 !important}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}::-webkit-scrollbar-thumb{background:#188550;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#166d42}.exchange-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;backdrop-filter:blur(4px)}.exchange-modal{background:white;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,0.3);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideIn 0.3s ease-out}.exchange-modal-large{max-width:900px}@keyframes modalSlideIn{from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.exchange-modal-header{padding:24px 28px;border-bottom:2px solid #f0fdf4;display:flex;align-items:center;justify-content:space-between}.exchange-modal-title{margin:0;font-size:20px;font-weight:700;color:#188550;display:flex;align-items:center}.exchange-modal-close{background:#f3f4f6;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.3s;color:#6b7280}.exchange-modal-close:hover{background:#fee2e2;color:#dc2626;transform:rotate(90deg)}.exchange-modal-body{padding:28px;overflow-y:auto;flex:1}.exchange-modal-footer{padding:20px 28px;border-top:2px solid #f0fdf4;display:flex;gap:12px;justify-content:flex-end}.form-group{margin-bottom:20px}.form-label{display:block;font-weight:600;color:#374151;margin-bottom:8px;font-size:14px}.form-label.required::after{content:" *";color:#dc2626}.form-control,.form-select{width:100%;padding:10px 14px;border:2px solid #e5e7eb;border-radius:10px;font-size:14px;transition:all 0.3s}.form-control:focus,.form-select:focus{outline:none;border-color:#188550;box-shadow:0 0 0 3px rgba(24,133,80,0.1)}.form-control::placeholder{color:#9ca3af}textarea.form-control{resize:vertical;min-height:80px}.available-books-list{max-height:400px;overflow-y:auto;border:2px solid #e5e7eb;border-radius:12px;padding:12px}.book-select-item{padding:14px;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:12px;transition:all 0.3s;background:white}.book-select-item:last-child{margin-bottom:0}.book-select-item.selected{border-color:#188550;background:#f0fdf4}.book-select-main{display:flex;align-items:flex-start;gap:12px}.book-select-checkbox{padding-top:4px}.book-select-checkbox input[type="checkbox"]{width:20px;height:20px;cursor:pointer;accent-color:#188550}.book-select-content{flex:1;display:flex;gap:12px;cursor:pointer;margin:0}.book-select-image{width:60px;height:90px;object-fit:cover;border-radius:8px;border:2px solid #e5e7eb;flex-shrink:0}.book-select-info{flex:1}.book-select-title{font-size:15px;font-weight:700;color:#111827;margin:0 0 6px 0;line-height:1.4}.book-select-author{font-size:13px;color:#6b7280;margin:0 0 8px 0}.book-exchange-options-container{margin-top:14px;padding-top:14px;border-top:2px solid #e5e7eb;display:flex;flex-direction:column;gap:12px}.book-exchange-option{display:flex;flex-direction:column;gap:6px}.option-label{font-size:13px;font-weight:600;color:#374151;margin:0}.form-select-sm,.form-control-sm{padding:8px 12px;font-size:13px}.empty-books-message{text-align:center;padding:60px 20px;color:#6b7280}.empty-books-message i{font-size:48px;color:#d1d5db;margin-bottom:16px}.empty-books-message p{margin:0 0 16px 0;font-size:15px}.btn-cancel,.btn-submit{padding:12px 24px;border:none;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:all 0.3s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-cancel{background:#f3f4f6;color:#6b7280}.btn-cancel:hover{background:#e5e7eb;color:#374151}.btn-submit{background:linear-gradient(135deg, #188550 0%, #22c55e 100%);color:white;box-shadow:0 2px 8px rgba(24,133,80,0.3)}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(24,133,80,0.4)}.btn-submit:disabled{opacity:0.6;cursor:not-allowed}@media (max-width: 768px){.exchange-modal{max-width:100%;max-height:100vh;border-radius:0}.exchange-modal-large{max-width:100%}.available-books-list{max-height:300px}.book-select-content{flex-direction:column}}.book-card-item{background:white;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,0.08);transition:all 0.3s;cursor:pointer;display:flex;flex-direction:column;height:100%}.book-card-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(24,133,80,0.15)}.book-card-image{position:relative;width:100%;height:240px;overflow:hidden;background:#f7fafc}.book-card-image img{width:100%;height:100%;object-fit:cover}.book-card-badge{position:absolute;top:12px;right:12px;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;color:white;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px rgba(0,0,0,0.2)}.book-card-badge.badge-borrow{background:linear-gradient(135deg, #188550 0%, #58D77A 100%)}.book-card-badge.badge-gift{background:linear-gradient(135deg, #FFB118 0%, #FFC942 100%)}.book-card-badge.badge-sell{background:linear-gradient(135deg, #FF6B6B 0%, #FF8E8E 100%)}.book-card-body{padding:16px;flex:1;display:flex;flex-direction:column}.book-card-title{font-size:16px;font-weight:700;color:#1a202c;margin:0 0 8px 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:44px}.book-card-author{font-size:14px;color:#718096;margin:0 0 12px 0;display:flex;align-items:center}.book-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}.book-card-meta .condition-badge{font-size:11px;padding:4px 10px}.book-card-price{font-size:14px;font-weight:700;color:#dc2626}.book-card-duration{font-size:13px;color:#188550;font-weight:600;display:flex;align-items:center;gap:4px}.book-card-location{font-size:13px;color:#64748b;font-weight:600;display:flex;align-items:center;gap:4px;margin-top:8px;padding:6px 10px;background:#f0fdf4;border-radius:8px;border-left:3px solid #188550}.book-card-location i{color:#188550}.book-card-post{margin-top:auto;padding-top:12px;border-top:1px solid #e2e8f0;display:flex;align-items:center;gap:8px}.post-user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.post-user-name{font-size:13px;color:#4a5568;font-weight:600}.book-post-info{margin-top:24px;padding-top:24px;border-top:2px solid #e2e8f0}.book-post-title{font-size:14px;font-weight:700;color:#4a5568;margin:0 0 12px 0;text-transform:uppercase;letter-spacing:0.5px}.book-post-card{display:flex;align-items:center;gap:12px;padding:12px;background:#f7fafc;border-radius:12px;border:1px solid #e2e8f0}.book-post-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.book-post-details{flex:1}.book-post-user{font-size:13px;color:#718096;margin:0 0 4px 0}.book-post-name{font-size:15px;font-weight:700;color:#1a202c;margin:0}.formatPrice{color:#dc2626;font-weight:700}.book-detail-content{display:flex;gap:32px;align-items:flex-start}.book-detail-image{flex-shrink:0;width:200px}.book-detail-image img{width:100%;height:auto;border-radius:16px;box-shadow:0 8px 24px rgba(24,133,80,0.15)}.book-detail-info{flex:1}.book-detail-title{font-size:26px;font-weight:800;color:#1a202c;margin:0 0 12px 0;line-height:1.3}.book-detail-author{font-size:16px;color:#718096;margin:0 0 24px 0;display:flex;align-items:center;font-weight:500}.book-detail-author i{color:#58D77A}.book-detail-meta{display:flex;flex-direction:column;gap:0;margin-bottom:24px}.meta-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #e2e8f0}.meta-item:last-child{border-bottom:none}.meta-label{font-weight:700;color:#4a5568;font-size:14px;text-transform:uppercase;letter-spacing:0.5px}.meta-value{font-weight:600;color:#1a202c;font-size:15px}.price-highlight{color:#dc2626;font-weight:800;font-size:18px}.book-detail-meta .condition-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;color:white}.condition-badge.condition-poor{background:linear-gradient(135deg, #EF4444 0%, #F87171 100%)}.condition-badge.condition-fair{background:linear-gradient(135deg, #FFB118 0%, #FFC942 100%)}.condition-badge.condition-good{background:linear-gradient(135deg, #3B82F6 0%, #60A5FA 100%)}.condition-badge.condition-like-new,.condition-badge.condition-like_new{background:linear-gradient(135deg, #10b981 0%, #34d399 100%)}.condition-badge.condition-new,.condition-badge.condition-brand-new,.condition-badge.condition-brand_new{background:linear-gradient(135deg, #188550 0%, #58D77A 100%)}.book-detail-meta .condition-badge.badge-borrow{background:linear-gradient(135deg, #188550 0%, #58D77A 100%)}.book-detail-meta .condition-badge.badge-gift{background:linear-gradient(135deg, #FFB118 0%, #FFC942 100%)}.book-detail-meta .condition-badge.badge-sell{background:linear-gradient(135deg, #FF6B6B 0%, #FF8E8E 100%)}@media (max-width: 768px){.book-detail-content{flex-direction:column;text-align:center}.book-detail-image{width:160px;margin:0 auto}.book-detail-title{font-size:22px}.book-detail-author{font-size:14px;justify-content:center}.meta-item{flex-direction:column;gap:8px;text-align:center}}.scroll-to-top-btn{position:fixed;bottom:30px;left:30px;width:50px;height:50px;border-radius:50%;background-color:#188550;color:white;border:none;box-shadow:0 4px 16px rgba(24,133,80,0.4);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;z-index:9998;opacity:0;visibility:hidden;transform:translateY(20px);transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}.scroll-to-top-btn.show{opacity:1;visibility:visible;transform:translateY(0)}.scroll-to-top-btn:hover{transform:translateY(-4px);box-shadow:0 6px 20px rgba(24,133,80,0.5)}.scroll-to-top-btn:active{transform:translateY(-2px)}.scroll-to-top-btn i{animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,100%{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}@media (max-width: 768px){.scroll-to-top-btn{bottom:20px;left:20px;width:45px;height:45px;font-size:18px}}.page-header{text-align:center;padding:1rem 0;margin-bottom:1rem}.page-title{font-size:1.8rem;font-weight:700;color:#2d3748;margin-bottom:0.5rem;display:flex;align-items:center;justify-content:center;gap:0.5rem}.page-subtitle{font-size:1rem;color:#718096;margin:0}@media (max-width: 768px){.page-title{font-size:1.5rem}.page-subtitle{font-size:0.9rem}}.exchange-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);align-items:center;justify-content:center;z-index:9999;animation:fadeIn 0.2s ease-out;display:none;padding:20px;overflow-y:auto}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.exchange-modal{background:white;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.3);max-width:500px;width:100%;animation:slideUp 0.3s ease-out;max-height:90vh;display:flex;flex-direction:column}.exchange-modal-large{max-width:700px}@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.exchange-modal-header{padding:24px 28px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.exchange-modal-title{margin:0;font-size:20px;font-weight:600;color:#111827;display:flex;align-items:center;gap:10px}.exchange-modal-title i{color:#188550}.exchange-modal-close{background:none;border:none;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;transition:all 0.2s;font-size:20px}.exchange-modal-close:hover{background:#f3f4f6;color:#111827}.exchange-modal-body{padding:28px;overflow-y:auto;flex:1}.exchange-modal-footer{padding:20px 28px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;flex-shrink:0}.exchange-modal .form-group{margin-bottom:20px}.exchange-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 768px){.exchange-modal .form-row{grid-template-columns:1fr}}.exchange-modal .form-label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.exchange-modal .required{color:#ef4444}.exchange-modal .form-input,.exchange-modal .form-textarea,.exchange-modal .form-select{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:15px;transition:all 0.2s;font-family:inherit;background:white}.exchange-modal .form-input:focus,.exchange-modal .form-textarea:focus,.exchange-modal .form-select:focus{outline:none;border-color:#58D77A;box-shadow:0 0 0 3px rgba(88,215,122,0.1)}.exchange-modal .form-textarea{resize:vertical;min-height:100px}.exchange-modal .form-select{cursor:pointer}.exchange-modal .form-check{margin-bottom:12px;padding-left:0}.exchange-modal .form-check-input{width:20px;height:20px;margin-right:10px;cursor:pointer}.exchange-modal .form-check-label{cursor:pointer;font-size:15px;color:#374151}.exchange-modal-footer .btn-cancel,.exchange-modal-footer .btn-submit{padding:12px 24px;border-radius:10px;font-weight:600;font-size:15px;cursor:pointer;transition:all 0.2s;border:none;display:flex;align-items:center;gap:8px}.exchange-modal-footer .btn-cancel{background:#f3f4f6;color:#374151}.exchange-modal-footer .btn-cancel:hover{background:#e5e7eb}.exchange-modal-footer .btn-submit{background:linear-gradient(135deg, #188550 0%, #58D77A 100%);color:white;box-shadow:0 4px 12px rgba(24,133,80,0.4)}.exchange-modal-footer .btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(24,133,80,0.5)}.exchange-modal-footer .btn-submit:disabled{opacity:0.5;cursor:not-allowed;transform:none}.exchange-modal-footer .btn-submit i{font-size:16px}@media (max-width: 768px){.exchange-modal{max-width:100%;margin:0;border-radius:16px 16px 0 0;max-height:95vh}.exchange-modal-overlay{align-items:flex-end;padding:0}}.exchange-modal .file-upload-wrapper{position:relative}.exchange-modal .file-input{position:absolute;opacity:0;width:0;height:0}.exchange-modal .file-upload-label{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;border:2px dashed #cbd5e0;border-radius:10px;cursor:pointer;transition:all 0.3s;background:#f7fafc;color:#718096;font-weight:600}.exchange-modal .file-upload-label:hover{border-color:#58D77A;background:#E2FFF1;color:#188550}.exchange-modal .file-upload-label i{font-size:24px}.exchange-modal .file-name{display:block;margin-top:8px;font-size:13px;color:#188550;font-weight:500}.book-selection-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding:4px}.book-selection-item{position:relative;border:2px solid #e5e7eb;border-radius:12px;transition:all 0.3s;background:white}.book-selection-item:hover{border-color:#58D77A;box-shadow:0 4px 12px rgba(24,133,80,0.1)}.book-selection-item.selected{border-color:#188550;background:#E2FFF1;box-shadow:0 4px 16px rgba(24,133,80,0.2)}.book-checkbox{position:absolute;opacity:0;width:0;height:0}.book-selection-label{display:flex;align-items:center;gap:16px;padding:12px;cursor:pointer;margin:0}.book-selection-image{flex-shrink:0;width:60px;height:80px;border-radius:8px;overflow:hidden;background:#f7fafc}.book-selection-image img{width:100%;height:100%;object-fit:cover}.book-selection-info{flex:1;min-width:0}.book-selection-title{font-size:15px;font-weight:700;color:#1a202c;margin:0 0 4px 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-selection-author{font-size:13px;color:#718096;margin:0 0 8px 0}.book-selection-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.book-selection-meta .condition-badge{font-size:11px;padding:3px 10px}.book-selection-price{font-size:13px;font-weight:700;color:#dc2626}.book-selection-duration{font-size:12px;color:#188550;font-weight:600;display:flex;align-items:center;gap:4px}.book-selection-check{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:2px solid #cbd5e0;display:flex;align-items:center;justify-content:center;color:white;background:white;transition:all 0.3s}.book-selection-item.selected .book-selection-check{background:#188550;border-color:#188550}.book-selection-check i{font-size:16px;opacity:0;transition:opacity 0.3s}.book-selection-item.selected .book-selection-check i{opacity:1}.swal2-container{z-index:99999 !important}.swal2-popup{z-index:99999 !important}.exchange-requests-container{background:#f7fafc;min-height:100vh}.page-title{color:#1f2937}.request-type-badge{position:absolute;top:15px;right:15px;padding:6px 12px;border-radius:20px;color:white;font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px}.badge-borrow{background:linear-gradient(135deg, #3b82f6 0%, #60a5fa 100%)}.badge-gift{background:linear-gradient(135deg, #10b981 0%, #34d399 100%)}.badge-sell{background:linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%)}.badge-mixed{background:linear-gradient(135deg, #8b5cf6 0%, #a78bfa 100%)}.badge-default{background:#6b7280}.create-request-box{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,0.08)}.create-request-header{display:flex;align-items:center;gap:12px;margin-bottom:15px}.user-avatar-small{width:40px;height:40px;border-radius:50%;object-fit:cover}.create-request-input{flex:1;padding:12px 20px;border:1px solid #e5e7eb;border-radius:25px;background:#f9fafb;text-align:left;color:#9ca3af;cursor:pointer;transition:all 0.2s}.create-request-input:hover{background:#f3f4f6;border-color:#d1d5db}.create-request-actions{display:flex;gap:10px;padding-top:15px;border-top:1px solid #f3f4f6}.action-btn{flex:1;padding:10px;border:none;background:transparent;color:#6b7280;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all 0.2s}.action-btn:hover{background:#f3f4f6}.request-card{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,0.08);position:relative;transition:all 0.3s}.request-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.12);transform:translateY(-2px)}.request-header{display:flex;align-items:center;gap:12px;margin-bottom:15px}.user-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.request-user-info{flex:1}.user-name{margin:0;font-weight:600;color:#1f2937}.request-time{margin:0;font-size:13px;color:#9ca3af}.request-content-section{margin-bottom:15px}.request-title{font-size:18px;font-weight:600;color:#1f2937;margin-bottom:10px}.request-description{color:#6b7280;line-height:1.6;margin-bottom:15px}.book-info-section{background:#f0fdf4;border-left:4px solid #188550;padding:15px;border-radius:8px;margin-top:15px}.book-info-item{display:flex;align-items:center;margin-bottom:8px;color:#1f2937}.book-info-item:last-child{margin-bottom:0}.book-info-item i{color:#188550}.request-footer{display:flex;justify-content:space-between;align-items:center;padding-top:15px;border-top:1px solid #f3f4f6}.request-stats{display:flex;gap:15px}.stat-item{display:flex;align-items:center;gap:5px;color:#6b7280;font-size:14px}.stat-item i{color:#9ca3af}.btn-respond{padding:8px 16px;background:#188550;color:white;border:none;border-radius:8px;font-weight:500;transition:all 0.2s;display:inline-flex;align-items:center;cursor:pointer}.btn-respond:hover{background:#146b3e;box-shadow:0 4px 12px rgba(24,133,80,0.3)}.btn-show-more{background:none;border:none;color:#188550;font-size:14px;font-weight:500;cursor:pointer;padding:4px 0;margin-top:8px;display:inline-flex;align-items:center;gap:4px}.btn-show-more:hover{color:#146b3e;text-decoration:underline}.description-collapsed{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.response-request-info{background:#f7fafc;padding:15px;border-radius:8px;border:1px solid #e2e8f0}.modal-content{border-radius:12px;border:none}.modal-header{border-bottom:1px solid #f3f4f6;padding:20px 24px}.modal-title{font-weight:600;color:#1f2937}.modal-body{padding:24px}.modal-footer{border-top:1px solid #f3f4f6;padding:16px 24px}.empty-state{text-align:center;padding:60px 20px;background:white;border-radius:12px}.empty-state i{opacity:0.3}.empty-state h5{color:#6b7280;margin-top:20px}.sidebar-card{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,0.08)}.sidebar-title{font-weight:600;color:#1f2937;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #f3f4f6}.filter-section-label{display:block;font-weight:500;color:#4b5563;margin-bottom:10px;font-size:14px}.filter-options{display:grid;grid-template-columns:repeat(2, 1fr);gap:8px}.filter-option-btn{padding:10px;border:1px solid #e5e7eb;background:white;border-radius:8px;cursor:pointer;transition:all 0.2s;display:flex;flex-direction:column;align-items:center;gap:5px;font-size:13px}.filter-option-btn:hover{border-color:#188550;background:#f0fdf4}.filter-option-btn.active{border-color:#188550;background:#f0fdf4;color:#188550;font-weight:600}.filter-option-btn i{font-size:18px}.search-input-wrapper{position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af}.search-input{padding-left:38px}.info-content{font-size:14px;color:#6b7280;line-height:1.6}.info-content ol{padding-left:20px;margin-bottom:0}.info-content li{margin-bottom:8px}.mobile-filter-container{display:none}@media (max-width: 768px){.desktop-filter-sidebar{display:none !important}.mobile-filter-container{display:block !important}.request-card{padding:16px;border-radius:12px}.request-type-badge{top:12px;right:12px;padding:4px 10px;font-size:10px}.request-header{margin-bottom:12px}.user-avatar{width:40px;height:40px}.user-name{font-size:14px}.request-time{font-size:11px}.request-title{font-size:16px}.request-description{font-size:13px}.book-info-section{font-size:12px}.request-footer{flex-direction:column;gap:10px;align-items:stretch}.btn-respond{width:100%;justify-content:center}}@media (min-width: 769px){.mobile-filter-container{display:none !important}}
