.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgb(0 0 0 / .6);z-index:9999;align-items:center;justify-content:center;opacity:0;transition:opacity 0.3s ease;backdrop-filter:blur(4px)}.modal.active{display:flex;opacity:1}body:has(.modal.active),body.modal-open{overflow:hidden}body.modal-open-fixed{overflow:hidden;position:fixed;width:100%;height:100%;left:0;top:0}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:90%;max-width:500px;overflow:hidden;animation:modalSlideIn 0.3s ease}@keyframes modalSlideIn{from{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.modal-header h3{margin:0;font-size:20px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:12px}.modal-header h3 i{color:var(--primary-color)}.modal-close,.modal-close-btn{width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close:hover,.modal-close-btn:hover{background:var(--bg-hover);border-color:var(--danger-color);color:var(--danger-color)}.modal-body{padding:24px;overflow-y:auto;max-height:60vh}.modal-footer{padding:20px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary);display:flex;gap:12px;justify-content:flex-end}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgb(0 0 0 / .9);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;visibility:hidden;transition:opacity 0.3s ease,visibility 0.3s ease;padding:20px}.image-modal-overlay.active{opacity:1;visibility:visible}.image-modal-container{position:relative;max-width:95vw;max-height:90vh;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:20px}.image-modal-container .image-modal-nav{position:relative;top:auto;transform:none}.image-modal-container .image-modal-nav:hover{transform:scale(1.1)}.image-modal-container .image-modal-nav:active{transform:scale(.95)}.image-modal-content{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:100%;max-height:90vh}.image-modal-img{max-width:100%;max-height:85vh;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px rgb(0 0 0 / .5);transition:opacity 0.15s ease}.image-modal-caption{margin-top:16px;color:#fff;font-size:14px;text-align:center;max-width:100%;padding:0 20px;line-height:1.5}.image-modal-download,.image-modal-close{position:absolute;top:-50px;background:rgb(255 255 255 / .2);border:none;border-radius:var(--radius-md);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:20px;transition:background 0.2s ease,transform 0.2s ease;z-index:10002;pointer-events:auto}.image-modal-download{right:50px}.image-modal-close{right:0}.image-modal-download:hover,.image-modal-close:hover{background:rgb(255 255 255 / .3);transform:scale(1.1)}.image-modal-download:active,.image-modal-close:active{transform:scale(.95)}.image-modal-nav{position:relative;background:rgb(255 255 255 / .2);border:none;border-radius:var(--radius-md);width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:24px;transition:background 0.2s ease,transform 0.2s ease;z-index:10001;backdrop-filter:blur(4px);flex-shrink:0;pointer-events:auto}.image-modal-nav:hover{background:rgb(255 255 255 / .3);transform:scale(1.1)}.image-modal-nav:active{transform:scale(.95)}.image-modal-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:rgb(0 0 0 / .6);color:#fff;padding:8px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:500;z-index:10001;backdrop-filter:blur(4px);pointer-events:none}.image-modal-nav.hidden,.image-modal-counter.hidden{display:none!important}.image-modal-nav:not(.hidden){display:flex}.image-modal-counter:not(.hidden){display:block}@media (max-width:768px){.image-modal-container{gap:10px}.image-modal-nav{width:40px;height:40px;font-size:20px}.image-modal-counter{bottom:40px;font-size:12px;padding:6px 12px}}