@charset "UTF-8";.login-container{min-height:100vh;background:linear-gradient(135deg,#e8e0e2,#f5f5f5);display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:#fff;border-radius:16px;padding:40px;box-shadow:0 8px 32px #0000001a;width:100%;max-width:400px;border:1px solid rgba(255,255,255,.2)}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:2rem;font-weight:700;color:#2c3e50;margin:0 0 10px;letter-spacing:-.5px}.login-header p{color:#6c757d;margin:0;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-weight:600;color:#2c3e50;font-size:.9rem}.form-group input{padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;transition:all .3s ease;background-color:#f8f9fa}.form-group input:focus{outline:none;border-color:#844a59;background-color:#fff;box-shadow:0 0 0 3px #844a591a}.error-message{background:#f8d7da;color:#721c24;padding:12px;border-radius:8px;border:1px solid #f5c6cb;font-size:.9rem;text-align:center}.success-message{background:#d4edda;color:#155724;padding:12px;border-radius:8px;border:1px solid #c3e6cb;font-size:.9rem;text-align:center}.forgot-password-link{text-align:right;margin-top:-10px}.forgot-btn{background:none;border:none;color:#844a59;font-size:.85rem;cursor:pointer;text-decoration:underline;padding:0}.forgot-btn:hover{color:#6b3c47}.login-btn{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px;min-height:48px;display:flex;align-items:center;justify-content:center}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #844a594d}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:8px;height:20px}.spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin .8s linear infinite}.login-footer{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #e9ecef}.login-footer p{color:#6c757d;margin:0;font-size:.9rem}.toggle-btn{background:none;border:none;color:#844a59;font-weight:600;cursor:pointer;text-decoration:underline;margin-left:5px;font-size:.9rem}.toggle-btn:hover{color:#6b3c47}@media (max-width: 480px){.login-container{padding:15px 10px}.login-card{padding:25px 20px}.login-header h1{font-size:24px}.login-header p{font-size:13px}.form-group input{font-size:16px;padding:12px 14px}.login-btn{padding:12px 16px;font-size:15px}.toggle-btn{font-size:13px;padding:10px 16px}}@media (max-width: 768px){.login-container{padding:20px 15px}.login-card{padding:30px 25px;max-width:100%;margin:0}.login-header{padding:0 0 25px}.login-header h1{font-size:28px;margin-bottom:8px}.login-header p{font-size:14px}.login-form{gap:20px}.form-group{margin-bottom:5px}.form-group label{font-size:14px;margin-bottom:8px}.form-group input{font-size:16px;padding:14px 16px}.login-btn{padding:14px 20px;font-size:16px;font-weight:600}.toggle-btn{padding:12px 20px;font-size:14px}.error-message,.success-message{padding:12px 16px;font-size:14px}}.desktop-sidebar{width:280px;background:linear-gradient(135deg,#2c3e50,#34495e);height:100vh;position:fixed;left:0;top:0;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a;transition:width .3s ease;z-index:1000}.desktop-sidebar.collapsed{width:80px}.sidebar-user{padding:25px 20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:15px;position:relative;cursor:pointer;transition:background-color .2s ease;height:111px;box-sizing:border-box}.sidebar-user:hover{background-color:#ffffff0d}.sidebar-user:active{background-color:#ffffff1a}.user-avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#844a59,#6b3c47);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;flex-shrink:0;overflow:hidden}.user-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.user-info{flex:1;min-width:0}.user-name{color:#fff;font-weight:600;font-size:16px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{color:#ffffffb3;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collapse-btn{position:absolute;top:20px;right:15px;background:#ffffff1a;border:none;color:#fff;width:24px;height:24px;min-height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .3s ease}.collapse-btn:hover{background:#fff3}.collapse-btn.sticky{background:#844a59cc;color:#fff}.collapse-btn.sticky:hover{background:#844a59}.mode-switcher{padding:20px;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);height:82px;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center}.mode-buttons{display:-webkit-flex;display:flex;gap:8px}.mode-btn{-webkit-flex:1;flex:1;display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;padding:12px 8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fffc;cursor:pointer;transition:all .3s ease;min-height:60px;box-sizing:border-box}.mode-btn:hover{background:#fff3;border-color:#ffffff4d;color:#fff;transform:translateY(-2px)}.mode-btn.active{background:linear-gradient(135deg,#844a59,#6b3c47);border-color:#844a59;color:#fff;box-shadow:0 4px 12px #844a594d}.mode-icon{font-size:20px;margin-bottom:4px}.mode-name{font-size:11px;font-weight:500;text-align:center}.desktop-sidebar.collapsed .mode-switcher{padding:15px 10px;height:82px;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center}.desktop-sidebar.collapsed .mode-buttons{gap:4px}.desktop-sidebar.collapsed .mode-btn{padding:8px 4px;min-height:50px}.desktop-sidebar.collapsed .mode-icon{font-size:18px;margin-bottom:0}.desktop-sidebar.collapsed .mode-name{display:none}.sidebar-nav{flex:1;display:flex;flex-direction:column;padding:20px 0;gap:5px}.nav-tab{display:flex;align-items:center;gap:15px;padding:15px 20px;border:none;background:none;color:#fffc;cursor:pointer;transition:all .2s ease;border-radius:8px;margin:0 10px;font-size:14px;text-decoration:none}.nav-tab:hover{background:#ffffff1a;color:#fff}.nav-tab.active{background:#ffffff26;color:#fff}.tab-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.tab-label{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-tab.logout-tab{margin-top:auto;margin-bottom:20px;color:#ffffffb3;background:#dc35451a;border:1px solid rgba(220,53,69,.2)}.desktop-sidebar.collapsed .nav-tab.logout-tab{background:#dc354526;border:1px solid rgba(220,53,69,.3)}.nav-tab.logout-tab:hover{background:#dc35454d;color:#ff6b6b;border:1px solid rgba(220,53,69,.5);transform:translate(2px);box-shadow:0 4px 12px #dc35454d}.desktop-sidebar.collapsed .user-info{display:none}.desktop-sidebar.collapsed .collapse-btn{position:static;margin:10px auto}.desktop-sidebar.collapsed .nav-tab{justify-content:center;padding:15px}.desktop-sidebar.collapsed .tab-label{display:none}.desktop-sidebar.collapsed .sidebar-user{justify-content:center;padding:25px 10px;height:111px;box-sizing:border-box}.desktop-sidebar.collapsed .user-avatar{margin:0 auto}.mobile-bottom-bar{display:none}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000059;z-index:9998;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-menu-sheet{position:fixed;bottom:0;left:0;right:0;background:#f2f2f7;border-radius:14px 14px 0 0;padding:6px 0 calc(12px + env(safe-area-inset-bottom,0px));z-index:9999;box-shadow:0 -10px 40px #0000001f;animation:sheetSlideUp .35s cubic-bezier(.32,.72,0,1)}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-handle{width:36px;height:5px;background:#c7c7cc;border-radius:2.5px;margin:6px auto 14px}.mobile-menu-user{display:flex;align-items:center;gap:14px;padding:14px 20px;margin:0 10px;background:#fff;border-radius:12px;cursor:pointer;transition:background .1s ease}.mobile-menu-user:active{background:#e5e5ea}.mobile-menu-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#844a59,#6b3c47);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:17px;flex-shrink:0;overflow:hidden}.mobile-menu-avatar-img{width:100%;height:100%;object-fit:cover}.mobile-menu-user-info{flex:1;min-width:0}.mobile-menu-user-name{font-weight:600;font-size:16px;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.2px}.mobile-menu-user-email{font-size:13px;color:#8e8e93;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.mobile-menu-chevron{font-size:20px;color:#c7c7cc;font-weight:400}.mobile-menu-divider{height:8px;background:transparent}.mobile-menu-section-label{font-size:13px;font-weight:600;color:#6d6d72;text-transform:uppercase;letter-spacing:.5px;padding:4px 22px 6px}.mobile-menu-mode-switcher{display:-webkit-flex;display:flex;gap:0;margin:0 10px 4px;background:#fff;border-radius:12px;overflow:hidden}.mobile-menu-mode-btn{-webkit-flex:1;flex:1;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;gap:8px;padding:13px 16px;border:none;background:transparent;font-size:15px;font-weight:500;color:#3c3c43;cursor:pointer;transition:all .2s ease;min-height:48px;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.mobile-menu-mode-btn:first-child{border-right:1px solid #e5e5ea}.mobile-menu-mode-btn.active{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff}.mobile-menu-mode-btn:active:not(.active){background:#e5e5ea}.mobile-menu-mode-btn svg{flex-shrink:0}.mobile-menu-item{display:flex;align-items:center;gap:14px;width:calc(100% - 20px);margin:0 10px 6px;padding:14px 16px;border:none;background:#fff;border-radius:12px;cursor:pointer;font-size:16px;color:#000;transition:background .1s ease;min-height:50px}.mobile-menu-item:active{background:#e5e5ea}.mobile-menu-item.active{color:#844a59;font-weight:600}.mobile-menu-item-danger{color:#ff3b30}.mobile-menu-item-danger:active{background:#fff0ef}.mobile-menu-item svg{flex-shrink:0}.mobile-menu-item-label{font-weight:500;letter-spacing:-.2px}.logout-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.logout-confirm-modal{background:#fff;border-radius:16px;padding:0;max-width:400px;width:90%;box-shadow:0 10px 25px #0003;animation:slideUp .3s ease-out}.logout-confirm-header{padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.logout-confirm-header h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.logout-confirm-body{padding:16px 24px}.logout-confirm-body p{margin:0 0 8px;color:#374151;font-size:14px;line-height:1.5}.logout-confirm-subtext{color:#6b7280!important;font-size:13px!important}.logout-confirm-actions{padding:16px 24px 24px;display:flex;gap:12px;justify-content:flex-end}.logout-confirm-cancel{padding:10px 20px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-confirm-cancel:hover{background:#f9fafb;border-color:#9ca3af}.logout-confirm-logout{padding:10px 20px;border:none;background:#dc2626;color:#fff;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-confirm-logout:hover{background:#b91c1c;transform:translateY(-1px)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.main-with-sidebar{margin-left:280px;transition:margin-left .3s ease}.main-with-sidebar.collapsed{margin-left:80px}@media (max-width: 768px){.desktop-sidebar{display:none!important}.main-with-sidebar{margin-left:0!important}.mobile-bottom-bar{display:block;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:#f9f9f9f0;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-top:.5px solid rgba(0,0,0,.12);padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-tabs{display:flex;justify-content:space-around;align-items:flex-end;padding:6px 4px 4px;max-width:600px;margin:0 auto}.mobile-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:2px 0 1px;border:none;background:none;color:#8e8e93;cursor:pointer;transition:color .15s ease;min-height:44px;-webkit-tap-highlight-color:transparent}.mobile-tab.active{color:#844a59}.mobile-tab-svg{width:24px;height:24px;transition:color .15s ease}.mobile-tab.active .mobile-tab-svg{stroke-width:2.2}.mobile-tab-label{font-size:10px;font-weight:500;line-height:1;text-align:center;white-space:nowrap;letter-spacing:.01em;margin-top:1px}.mobile-tab.active .mobile-tab-label{font-weight:600}}.profile-container{max-width:800px;margin:0 auto;padding:20px;background:#e8e0e2;min-height:100vh;border-radius:16px}.profile-header{text-align:center;margin-bottom:40px}.section-actions{display:flex;justify-content:center;margin-top:25px;opacity:0;transform:translateY(10px);animation:slideIn .3s ease forwards}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.profile-edit-btn{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #844a5933;display:flex;align-items:center;gap:8px}.profile-edit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #844a594d;background:linear-gradient(135deg,#9a5a69,#7b4c57)}.profile-edit-btn:active{transform:translateY(0)}.avatar-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;margin-bottom:30px;text-align:center}.avatar-container{position:relative;display:inline-block}.profile-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #844a59;box-shadow:0 4px 12px #844a5933}.avatar-placeholder{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#844a59,#6b3c47);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:36px;border:4px solid #844a59;box-shadow:0 4px 12px #844a5933}.avatar-change-btn{position:absolute;bottom:5px;right:5px;background:#844a59;color:#fff;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;transition:all .3s ease;z-index:10}.avatar-change-btn:hover{background:#6b3c47;transform:scale(1.1);box-shadow:0 4px 12px #844a594d}.avatar-change-btn:active{transform:scale(.95)}.hidden{display:none}.profile-content{display:flex;flex-direction:column;gap:24px}.profile-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 8px #0000001a;border:1px solid #e9ecef}.profile-section h3{color:#2c3e50;margin-bottom:20px;font-size:1.4rem;font-weight:600;border-bottom:2px solid #e9ecef;padding-bottom:10px}.profile-info{display:flex;flex-direction:column;gap:15px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f8f9fa}.info-item:last-child{border-bottom:none}.info-item label{font-weight:600;color:#495057;font-size:.95rem}.info-item span{color:#2c3e50;font-size:1rem}.edit-btn,.change-password-btn{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-top:10px}.edit-btn:hover,.change-password-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #844a594d}.edit-form,.password-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#495057;font-size:.9rem}.form-group input,.form-group textarea,.form-group select{padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#f8f9fa}.edit-input{padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:.9rem;transition:all .3s ease;background:#f8f9fa;max-width:300px;text-align:right;opacity:0;transform:translateY(-10px);animation:slideIn .3s ease forwards}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.edit-input:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.form-group input.error,.form-group textarea.error{border-color:#dc3545;background:#fff5f5}.error-text{color:#dc3545;font-size:.85rem;margin-top:4px}.form-actions{display:flex;gap:10px;align-items:center}.form-actions .save-btn,.form-actions .cancel-btn{padding:10px 20px;font-size:.9rem;border-radius:20px}.save-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.save-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.cancel-btn:hover{background:#5a6268;transform:translateY(-2px)}.password-form{display:flex;flex-direction:column;gap:16px}.password-info p{color:#6c757d;margin-bottom:15px;font-size:.95rem}.success-message{background:#d4edda;color:#155724;padding:12px 16px;border-radius:8px;border:1px solid #c3e6cb;margin-bottom:20px;font-size:.9rem}.error-message{background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:8px;border:1px solid #f5c6cb;margin-bottom:20px;font-size:.9rem}.message{padding:12px 16px;border-radius:8px;margin-top:15px;font-size:.9rem}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;margin-top:20px}.stat-item{text-align:center;padding:20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:1px solid #e9ecef}.stat-number{font-size:2rem;font-weight:700;color:#844a59;margin-bottom:8px}.stat-label{font-size:.9rem;color:#6c757d;font-weight:500}.loading-loans,.no-loans{text-align:center;padding:40px 20px;color:#6c757d;font-style:italic}.loans-list{display:flex;flex-direction:column;gap:15px}.loan-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;transition:all .3s ease}.loan-item:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.loan-book-info h4{margin:0 0 8px;color:#2c3e50;font-size:1.1rem;font-weight:600}.loan-author{margin:0 0 15px;color:#6c757d;font-style:italic;font-size:.9rem}.loan-details{display:flex;flex-direction:column;gap:8px}.loan-date{margin:0;font-size:.9rem;color:#495057}.loan-date strong{color:#2c3e50}@media (max-width: 768px){.profile-container{padding:20px 15px;background:#e8e0e2;min-height:100vh}.profile-section{padding:25px 20px;margin-bottom:20px}.profile-header{flex-direction:column;text-align:center;gap:20px;padding:25px 20px}.avatar-section{margin:0}.profile-avatar,.avatar-placeholder{width:100px;height:100px}.profile-info{grid-template-columns:1fr;gap:15px}.info-item{flex-direction:column;align-items:flex-start;gap:8px;padding:15px}.info-item label{font-size:14px;margin-bottom:5px}.info-item span{font-size:16px}.edit-form,.password-section{padding:25px 20px}.form-row{flex-direction:column;gap:15px}.form-group{width:100%}.form-group label{font-size:14px;margin-bottom:8px}.form-group input,.form-group textarea,.form-group select{font-size:16px;padding:12px 15px}.form-actions{flex-direction:column;gap:10px}.btn{padding:12px 20px;font-size:16px;border-radius:8px}.btn-primary,.btn-secondary{width:100%}.stats-grid{grid-template-columns:repeat(2,1fr);gap:15px}.stat-item{padding:15px}.stat-number{font-size:1.5rem}.stat-label{font-size:.8rem}}@media (max-width: 480px){.profile-container{padding:15px 10px}.profile-section,.profile-header{padding:20px 15px}.profile-avatar,.avatar-placeholder{width:80px;height:80px}.profile-section h3{font-size:1.2rem}.info-item{padding:12px 15px}.edit-form,.password-section{padding:20px 15px}.form-group input,.form-group textarea,.form-group select{font-size:16px;padding:10px 12px}.btn{padding:10px 16px;font-size:14px}.stats-grid{grid-template-columns:1fr;gap:10px}}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-top:1px solid #aeaeae;border-radius:0;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-top:1px solid #aeaeae;border-radius:0 0 .3rem .3rem}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__year-select,.react-datepicker__month-year-select{background-color:transparent;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__year-select:focus-visible,.react-datepicker__month-year-select:focus-visible{outline:auto 1px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:5em;margin:2px}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:5em;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.375em;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + 1.0625em);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.625em;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__children-container{width:17.25em;margin:.5em;padding-right:.25em;padding-left:.25em;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.react-datepicker-popper-offset{margin-top:-.7em}.barcode-scanner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;z-index:20000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.barcode-scanner-container{position:relative;width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:20px}.barcode-scanner-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:0 4px}.barcode-scanner-title{color:#fff;font-size:18px;font-weight:600;margin:0}.barcode-scanner-close-btn{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:none;border-radius:50%;background:#ffffff26;color:#fff;font-size:24px;cursor:pointer;transition:background .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.barcode-scanner-close-btn:hover,.barcode-scanner-close-btn:active{background:#ffffff4d}.barcode-scanner-viewfinder{position:relative;width:100%;aspect-ratio:1 / 1;border-radius:16px;overflow:hidden;background:#000}.barcode-scanner-corners{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;height:50%;pointer-events:none;z-index:1}.barcode-scanner-corners:before,.barcode-scanner-corners:after,.barcode-scanner-corner-bl:before,.barcode-scanner-corner-br:before{content:"";position:absolute;width:30px;height:30px;border-color:#fff;border-style:solid}.barcode-scanner-corners:before{top:0;left:0;border-width:3px 0 0 3px;border-radius:4px 0 0}.barcode-scanner-corners:after{top:0;right:0;border-width:3px 3px 0 0;border-radius:0 4px 0 0}.barcode-scanner-corner-bl:before{bottom:0;left:0;border-width:0 0 3px 3px;border-radius:0 0 0 4px}.barcode-scanner-corner-br:before{bottom:0;right:0;border-width:0 3px 3px 0;border-radius:0 0 4px}.barcode-scanner-line{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:65%;height:2px;background:linear-gradient(90deg,transparent,#844a59,transparent);z-index:1;animation:scanLine 2s ease-in-out infinite;opacity:.8}@keyframes scanLine{0%,to{transform:translate(-50%,-80px)}50%{transform:translate(-50%,80px)}}.barcode-scanner-hint{color:#ffffffb3;font-size:14px;text-align:center;margin:0}.barcode-scanner-error{color:#f87171;font-size:14px;text-align:center;margin:0;padding:12px 16px;background:#f871711a;border-radius:8px;width:100%;box-sizing:border-box}.barcode-scanner-success{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#34c75926;border-radius:10px;width:100%;box-sizing:border-box;animation:successPop .3s ease-out}@keyframes successPop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.barcode-scanner-success-icon{color:#34c759;font-size:22px;font-weight:700}.barcode-scanner-success-code{color:#fff;font-size:16px;font-weight:600;font-family:SF Mono,Menlo,monospace;letter-spacing:.5px}.kassza-scan-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 20px;border:2px dashed #844a59;border-radius:12px;background:#844a590d;color:#844a59;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;margin-bottom:16px}.kassza-scan-btn:hover,.kassza-scan-btn:active{background:#844a591f;border-style:solid}.kassza-scan-btn svg{width:24px;height:24px;flex-shrink:0}.isbn-scan-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:2px solid #e9ecef;border-radius:8px;background:#f8fafc;color:#844a59;cursor:pointer;transition:all .2s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.isbn-scan-btn:hover,.isbn-scan-btn:active{background:#844a59;color:#fff;border-color:#844a59}.isbn-scan-btn svg{width:22px;height:22px}@media (max-width: 480px){.barcode-scanner-overlay{padding:16px}.barcode-scanner-container{max-width:100%}.barcode-scanner-viewfinder{border-radius:12px}.barcode-scanner-close-btn{width:52px;height:52px;font-size:26px}}.lending-panel{padding:20px;max-width:1400px;margin:0 auto}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.modal{background:#fff;border-radius:12px;padding:0;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d;z-index:10000;position:relative;border:2px solid #fff}.modal-header{padding:20px 24px;border-bottom:1px solid #e9ecef;background:#f8f9fa;border-radius:12px 12px 0 0}.modal-header h3{margin:0;color:#2c3e50;font-size:1.25rem;font-weight:600}.modal-body{padding:24px}.modal-actions{display:flex;gap:12px;padding:20px 24px;border-top:1px solid #e9ecef;background:#f8f9fa;border-radius:0 0 12px 12px}.confirm-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.confirm-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.cancel-btn{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.cancel-btn:hover{background:#5a6268;transform:translateY(-2px);box-shadow:0 4px 12px #6c757d4d}.lending-header{margin-bottom:30px}.lending-header h2{color:#2c3e50;margin-bottom:20px;font-size:28px}.lending-stats{display:flex;gap:20px;flex-wrap:wrap}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:12px;text-align:center;min-width:150px;box-shadow:0 4px 15px #667eea4d;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card.overdue{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-number{display:block;font-size:32px;font-weight:700;margin-bottom:5px}.lending-content{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px}@media (max-width: 1024px){.lending-content{grid-template-columns:1fr}}.loans-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 12px #0000001a;margin-top:20px}.loans-section h3{color:#2c3e50;margin-bottom:20px;font-size:1.3rem;border-bottom:2px solid #667eea;padding-bottom:10px}.books-section{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #0000001a;width:100%}.books-section h3{color:#2c3e50;margin-bottom:20px;font-size:20px}.search-bar{margin-bottom:20px}.search-input{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.books-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px;max-height:400px;overflow-y:auto;padding:10px;width:100%}@media (max-width: 900px){.books-grid{grid-template-columns:1fr}}@media (min-width: 1200px){.books-grid{grid-template-columns:repeat(3,1fr)}}.book-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:20px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;min-height:280px}.book-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.book-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 4px 15px #667eea4d}.book-thumbnail{width:100%;height:160px;object-fit:cover;border-radius:4px;margin-bottom:15px;max-width:100%;display:block}.book-card img,.lending-panel img{max-width:100%!important;max-height:160px!important;width:auto!important;height:auto!important;object-fit:cover!important;display:block!important;margin:0 auto 15px!important}.book-info{flex:1;display:flex;flex-direction:column}.book-title{font-size:16px;font-weight:600;color:#2c3e50;margin:0 0 8px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-author{font-size:14px;color:#6c757d;margin:0 0 15px;line-height:1.2}.loan-btn{background:#667eea;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background .3s ease;margin-top:auto}.loan-btn:hover{background:#5a6fd8}.book-card.selected .loan-btn{background:#28a745}.loan-actions{margin-top:20px;text-align:center}.search-results{margin-top:20px;border-top:1px solid #e9ecef;padding-top:20px}.search-results h4{color:#2c3e50;margin-bottom:15px;font-size:16px}.results-list{max-height:300px;overflow-y:auto}.search-result-item{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:15px;margin-bottom:10px;cursor:pointer;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center}.search-result-item:hover{border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d);transform:translateY(-1px)}.search-result-item.selected{border-color:#28a745;background:linear-gradient(135deg,#28a7451a,#228b221a)}.result-info h4{color:#2c3e50;margin:0 0 5px;font-size:16px;font-weight:600}.result-info p{color:#6c757d;margin:0 0 3px;font-size:14px}.result-info small{color:#868e96;font-size:12px}.result-action{color:#667eea;font-weight:600;font-size:14px}.search-result-item.selected .result-action{color:#28a745}.search-result-item.lent-out{background:#fff5f5;border-color:#feb2b2;opacity:.7;cursor:not-allowed}.search-result-item.lent-out:hover{background:#fff5f5;border-color:#feb2b2;transform:none;box-shadow:none}.search-result-item.lent-out .result-action{color:#dc3545;font-weight:600}.no-results{text-align:center;color:#6c757d;font-style:italic;padding:20px}.search-prompt{text-align:center;color:#6c757d;font-style:italic;padding:40px 20px;background:#f8f9fa;border-radius:8px;border:2px dashed #e9ecef}.selected-book-display{margin-top:20px;padding:20px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:8px;border:2px solid #667eea}.selected-book-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.selected-book-header h4{color:#2c3e50;margin:0;font-size:18px}.back-btn{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s ease;display:flex;align-items:center;gap:5px}.back-btn:hover{background:#5a6268;transform:translateY(-1px)}.selected-book-info p{margin:5px 0;color:#495057}.clear-btn{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s ease}.clear-btn:hover{background:#5a6268}.user-selection-section{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #0000001a;width:100%}.user-selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.user-selection-header h3{color:#2c3e50;margin:0;font-size:20px}.user-search-bar{margin-bottom:20px}.user-search-results{margin-top:20px;border-top:1px solid #e9ecef;padding-top:20px}.selected-user-display{margin-top:20px;padding:20px;background:linear-gradient(135deg,#28a7451a,#228b221a);border-radius:8px;border:2px solid #28a745}.selected-user-display h4{color:#2c3e50;margin:0 0 15px;font-size:18px}.selected-user-info p{margin:5px 0;color:#495057}.final-loan-actions{margin-top:20px;text-align:center}.final-confirm-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:15px 30px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.final-confirm-btn:hover{background:linear-gradient(135deg,#218838,#1ea085);transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.confirm-loan-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:15px 30px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.confirm-loan-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.loans-list{max-height:500px;overflow-y:auto}.no-loans{text-align:center;color:#6c757d;font-style:italic;padding:40px 20px}.loan-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.loan-card:hover{box-shadow:0 2px 8px #0000001a}.loan-card.overdue{border-color:#dc3545;background:linear-gradient(135deg,#dc35450d,#f5576c0d)}.loan-info h4{color:#2c3e50;margin:0 0 5px;font-size:16px}.loan-info p{color:#6c757d;margin:3px 0;font-size:14px}.overdue-text{color:#dc3545!important;font-weight:600}.warning-text{color:#ffc107!important;font-weight:600}.loan-actions{display:flex;gap:10px;flex-wrap:wrap}.return-btn,.renew-btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s ease}.return-btn{background:#28a745;color:#fff}.return-btn:hover{background:#218838}.renew-btn{background:#ffc107;color:#212529}.renew-btn:hover{background:#e0a800}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:99999;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-content{background:#fff;padding:40px;border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;border:1px solid #e9ecef;z-index:100000;position:relative;animation:modalAppear .3s ease-out forwards}@keyframes modalAppear{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content h3{color:#2c3e50;margin-bottom:20px;text-align:center;font-size:24px;font-weight:700}.selected-book-info{background:#f8f9fa;padding:15px;border-radius:8px;margin-bottom:20px}.selected-book-info p{margin:5px 0;color:#6c757d}.loan-form,.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#2c3e50}.form-input,.form-select{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:border-color .3s ease}.form-input:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.library-info{background:linear-gradient(135deg,#667eea1a,#764ba21a);padding:15px;border-radius:8px;border-left:4px solid #667eea;margin:20px 0;font-size:14px;color:#495057}.modal-actions{display:flex;gap:15px;justify-content:center}.confirm-btn,.cancel-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.confirm-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.confirm-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover{background:#5a6268}@media (max-width: 768px){.lending-panel{padding:12px}.lending-header{margin-bottom:16px}.lending-header h2{font-size:22px;margin-bottom:12px}.lending-stats{flex-direction:row;gap:8px}.stat-card{min-width:auto;padding:10px 12px;border-radius:10px}.stat-card .stat-number{font-size:20px}.stat-card .stat-label{font-size:11px}.lending-content{gap:12px;margin-bottom:16px}.books-section{padding:14px;border-radius:10px}.books-section h3{font-size:16px;margin-bottom:12px}.search-input{font-size:16px!important}.search-bar{margin-bottom:12px}.books-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.search-results{margin-top:12px;padding-top:12px}.search-results h4{font-size:14px;margin-bottom:10px}.search-result-item{padding:10px 12px;margin-bottom:6px;border-radius:10px}.result-info h4{font-size:14px}.result-info p{font-size:13px}.result-action{font-size:12px;white-space:nowrap}.search-prompt{padding:24px 16px;font-size:14px}.selected-book-display,.selected-user-display{padding:14px;margin-top:12px;border-radius:10px}.selected-book-header h4,.selected-user-display h4{font-size:15px}.selected-book-info p,.selected-user-info p{font-size:13px;margin:3px 0}.user-selection-section{padding:14px;border-radius:10px}.user-selection-header h3{font-size:16px;margin-bottom:12px}.final-confirm-btn{padding:12px 20px;font-size:15px;width:100%}.loans-section{padding:14px;border-radius:10px;margin-top:12px}.loans-section h3{font-size:16px;margin-bottom:12px;padding-bottom:8px}.loans-list{max-height:none}.loan-card{flex-direction:row;align-items:center;gap:10px;padding:10px 12px;margin-bottom:8px;border-radius:10px}.loan-card.overdue{border-width:1px}.loan-info{flex:1;min-width:0}.loan-info h4{font-size:14px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loan-info p{font-size:12px;margin:1px 0;line-height:1.3}.loan-info p[style]{margin-bottom:4px!important}.overdue-text,.warning-text{font-size:11px!important;margin-top:2px}.loan-actions{flex-direction:column;gap:4px;width:auto;flex-shrink:0}.return-btn,.renew-btn{padding:6px 12px;font-size:12px;text-align:center;white-space:nowrap;min-height:32px}.no-loans{padding:24px 16px;font-size:14px}.modal-content{padding:24px 16px}.modal-actions{flex-direction:column;gap:8px}.confirm-btn,.cancel-btn{width:100%;font-size:15px;padding:12px 20px}}.renewal-info{background:#f8f9fa;padding:15px;border-radius:8px;margin-bottom:20px}.renewal-info p{margin:5px 0;color:#495057}.renewal-info strong{color:#2c3e50}.form-input{width:100%;padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#f8f9fa}.form-input:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.custom-datepicker{width:100%;padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:1rem;background:#f8f9fa;color:#2c3e50;cursor:pointer;transition:all .3s ease;box-sizing:border-box}.custom-datepicker:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.react-datepicker{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;border:none;border-radius:12px;box-shadow:0 10px 30px #00000026;background:#fff;overflow:hidden}.react-datepicker__header{background:linear-gradient(135deg,#844a59,#a05d7a);color:#fff;padding:16px;border-bottom:none;border-radius:12px 12px 0 0}.react-datepicker__current-month{font-size:1.1rem;font-weight:600;color:#fff}.react-datepicker__navigation{color:#fff;top:20px;font-size:1.5rem;cursor:pointer;transition:all .3s ease}.react-datepicker__navigation:hover{background:#ffffff1a;border-radius:6px}.react-datepicker__day{color:#2c3e50;font-size:.95rem;border-radius:8px;transition:all .3s ease;margin:2px}.react-datepicker__day:hover{background:#f8f9fa;color:#844a59;transform:scale(1.1)}.react-datepicker__day--selected{background:linear-gradient(135deg,#844a59,#a05d7a);color:#fff;font-weight:600;border-radius:8px}.react-datepicker__day--today{background:#e9ecef;color:#844a59;font-weight:600;border-radius:8px}.react-datepicker__day--outside-month{color:#adb5bd}.react-datepicker__day--disabled{color:#dee2e6;cursor:not-allowed;opacity:.5}.react-datepicker__day-names{margin-top:8px;padding:0 16px}.react-datepicker__day-name{color:#844a59;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.react-datepicker__month{margin:8px}.react-datepicker__triangle{display:none}.react-datepicker__day--weekend{color:#dc3545}.react-datepicker__day--weekend.react-datepicker__day--selected{color:#fff}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.pos-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#f8f9fa;z-index:9999;opacity:0;transform-origin:top right;transform:scale(0);border-radius:50%;pointer-events:none;transition:all .6s cubic-bezier(.25,.46,.45,.94)}.pos-overlay-open{opacity:1;transform:scale(1);border-radius:0;pointer-events:all}.pos-container{height:100%;display:flex;flex-direction:column;overflow:hidden}.pos-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;padding-top:max(16px,env(safe-area-inset-top));padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));background:linear-gradient(135deg,#844a59,#a05a6d);color:#fff;box-shadow:0 2px 8px #0000001a;position:relative;z-index:10}.pos-header h2{margin:0;font-size:20px;font-weight:700;letter-spacing:.5px}.pos-close-btn{background:#fff3;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;min-width:44px;min-height:44px}.pos-close-btn:hover{background:#ffffff4d;transform:scale(1.05)}.pos-close-btn:active{transform:scale(.95)}.pos-shift-indicator{font-size:14px;font-weight:600;padding:6px 12px;background:#fff3;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pos-search-section{padding:16px 20px;background:#fff;display:flex;gap:12px;box-shadow:0 2px 4px #0000000d}.pos-search-bar{flex:1;display:flex;align-items:center;gap:12px;background:#f1f3f5;border-radius:12px;padding:12px 16px;border:2px solid transparent;transition:all .2s ease}.pos-search-bar:focus-within{background:#fff;border-color:#844a59;box-shadow:0 0 0 4px #844a591a}.pos-search-bar svg{color:#868e96;flex-shrink:0}.pos-search-bar input{flex:1;border:none;background:transparent;font-size:16px;outline:none;color:#212529}.pos-search-bar input::placeholder{color:#adb5bd}.pos-clear-search{background:none;border:none;font-size:24px;color:#868e96;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.pos-clear-search:hover{color:#495057}.pos-scan-btn{background:#844a59;border:none;width:48px;height:48px;min-width:48px;min-height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;box-shadow:0 2px 8px #844a594d}.pos-scan-btn:hover{background:#a05a6d;transform:translateY(-2px);box-shadow:0 4px 12px #844a5966}.pos-scan-btn:active{transform:translateY(0)}.pos-search-results{background:#fff;max-height:400px;overflow-y:auto;border-bottom:1px solid #e9ecef}.pos-search-result-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f1f3f5;cursor:pointer;transition:background .2s ease;min-height:60px}.pos-search-result-item:hover{background:#f8f9fa}.pos-search-result-item:active{background:#e9ecef}.pos-result-info{flex:1}.pos-result-name{font-weight:600;font-size:15px;color:#212529;margin-bottom:4px}.pos-result-meta{font-size:13px;color:#868e96}.pos-result-price{font-weight:700;font-size:16px;color:#844a59;margin-left:16px}.pos-quick-section{flex:1;overflow-y:auto;padding:20px 20px 100px}.pos-quick-section h3{margin:0 0 16px;font-size:18px;font-weight:700;color:#212529}.pos-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (max-width: 768px){.pos-quick-grid{grid-template-columns:repeat(3,1fr);gap:8px}}@media (max-width: 480px){.pos-quick-grid{grid-template-columns:repeat(3,1fr);gap:8px}}.pos-quick-btn{background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:10px 8px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:6px;min-height:95px;min-width:44px;box-shadow:0 2px 4px #0000000d}@media (max-width: 768px){.pos-quick-btn{min-height:85px;padding:8px 6px;gap:4px}}.pos-quick-btn:hover{border-color:#844a59;transform:translateY(-4px);box-shadow:0 8px 16px #844a5926}.pos-quick-btn:active{transform:translateY(-2px)}.pos-quick-thumbnail{width:100%;height:50px;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:8px;background:#f8f9fa}.pos-quick-thumbnail img{width:100%;height:100%;object-fit:cover;border-radius:8px}.pos-quick-icon-fallback{font-size:32px;display:flex;align-items:center;justify-content:center;width:100%;height:100%}@media (max-width: 768px){.pos-quick-thumbnail{height:40px}.pos-quick-icon-fallback{font-size:24px}}.pos-quick-name{font-size:13px;font-weight:600;color:#212529;text-align:center;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1}.pos-quick-price{font-size:14px;font-weight:700;color:#844a59;margin-top:auto}.pos-cart-float{position:fixed;bottom:20px;left:20px;right:20px;background:linear-gradient(135deg,#059669,#10b981);border:none;border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:16px;cursor:pointer;box-shadow:0 8px 24px #05966966;transition:box-shadow .3s ease;z-index:100;min-height:60px;color:#fff;transform:translateY(0);opacity:1;animation:slideUpCart .3s ease forwards}@keyframes slideUpCart{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.pos-cart-float:hover{transform:translateY(-4px);box-shadow:0 12px 32px #05966980;transition:transform .2s ease,box-shadow .3s ease}.pos-cart-float:active{transform:translateY(-2px);transition:transform .1s ease}.pos-cart-icon{font-size:28px;position:relative}.pos-cart-badge{position:absolute;top:-8px;right:-8px;background:#dc2626;color:#fff;font-size:12px;font-weight:700;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white}.pos-cart-total{flex:1;font-size:20px;font-weight:700;text-align:left}.pos-bottom-sheet-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:10000;opacity:0;animation:fadeIn .3s ease forwards}.pos-bottom-sheet{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:24px 24px 0 0;max-height:85vh;display:flex;flex-direction:column;transform:translateY(100%);animation:slideUpSheet .3s cubic-bezier(.34,1.56,.64,1) forwards;box-shadow:0 -4px 24px #0003}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pos-sheet-handle{width:40px;height:5px;background:#dee2e6;border-radius:3px;margin:12px auto 8px}.pos-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e9ecef}.pos-sheet-header h3{margin:0;font-size:18px;font-weight:700;color:#212529}.pos-clear-btn{background:none;border:1px solid #dc2626;color:#dc2626;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:44px}.pos-clear-btn:hover{background:#dc2626;color:#fff}.pos-cart-items{flex:1;overflow-y:auto;padding:16px 20px;max-height:300px}.pos-cart-item{display:flex;align-items:center;gap:12px;padding:16px;background:#f8f9fa;border-radius:12px;margin-bottom:12px}.pos-cart-item-info{flex:1;min-width:0}.pos-cart-item-name{font-weight:600;font-size:15px;color:#212529;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pos-cart-item-price{font-size:13px;color:#868e96}.pos-cart-item-controls{display:flex;align-items:center;gap:8px}.pos-qty-btn{background:#fff;border:1px solid #dee2e6;width:32px;height:32px;min-width:44px;min-height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;font-weight:700;color:#495057;transition:all .2s ease}.pos-qty-btn:hover{background:#f1f3f5;border-color:#844a59}.pos-qty-btn:active{transform:scale(.95)}.pos-qty-display{font-weight:700;font-size:16px;color:#212529;min-width:30px;text-align:center}.pos-remove-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.pos-remove-btn:hover{transform:scale(1.2)}.pos-remove-btn:active{transform:scale(1)}.pos-cart-item-total{font-weight:700;font-size:16px;color:#844a59;white-space:nowrap}.pos-payment-section{padding:20px;background:#fff;border-top:2px solid #e9ecef}.pos-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:16px;color:#495057}.pos-total-amount{font-size:24px;font-weight:700;color:#212529}.pos-payment-btn{width:100%;background:linear-gradient(135deg,#844a59,#a05a6d);border:none;color:#fff;padding:16px;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s ease;min-height:56px;box-shadow:0 4px 12px #844a594d}.pos-payment-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #844a5966}.pos-payment-btn:active{transform:translateY(0)}.pos-payment-form{animation:fadeIn .3s ease}.pos-payment-input-group{margin-bottom:16px}.pos-payment-input-group label{display:block;font-size:14px;font-weight:600;color:#495057;margin-bottom:8px}.pos-payment-input-group input{width:100%;padding:14px 16px;border:2px solid #dee2e6;border-radius:12px;font-size:18px;font-weight:600;color:#212529;transition:all .2s ease;box-sizing:border-box}.pos-payment-input-group input:focus{outline:none;border-color:#844a59;box-shadow:0 0 0 4px #844a591a}.pos-change-display{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8f9fa;border-radius:12px;margin-bottom:16px;font-size:16px}.pos-change-positive{font-size:20px;font-weight:700;color:#059669}.pos-change-negative{font-size:20px;font-weight:700;color:#dc2626}.pos-finalize-btn{width:100%;background:linear-gradient(135deg,#059669,#10b981);border:none;color:#fff;padding:18px;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s ease;min-height:60px;box-shadow:0 4px 12px #0596694d;letter-spacing:.5px}.pos-finalize-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #05966966}.pos-finalize-btn:active:not(:disabled){transform:translateY(0)}.pos-finalize-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.pos-header h2{font-size:18px}.pos-quick-section{padding:16px}.pos-cart-float{bottom:16px;left:16px;right:16px}}.pos-cart-items::-webkit-scrollbar,.pos-search-results::-webkit-scrollbar,.pos-quick-section::-webkit-scrollbar{width:6px}.pos-cart-items::-webkit-scrollbar-track,.pos-search-results::-webkit-scrollbar-track,.pos-quick-section::-webkit-scrollbar-track{background:transparent}.pos-cart-items::-webkit-scrollbar-thumb,.pos-search-results::-webkit-scrollbar-thumb,.pos-quick-section::-webkit-scrollbar-thumb{background:#dee2e6;border-radius:3px}.pos-cart-items::-webkit-scrollbar-thumb:hover,.pos-search-results::-webkit-scrollbar-thumb:hover,.pos-quick-section::-webkit-scrollbar-thumb:hover{background:#adb5bd}.compact-rows-mobile,.gifts-rows-mobile{display:none}.bookstore-table-desktop,.gifts-table-desktop{display:block}@media (max-width: 768px){.bookstore-table-desktop,.gifts-table-desktop{display:none!important}.compact-rows-mobile,.gifts-rows-mobile{display:flex!important;flex-direction:column;gap:1px;background:#e5e7eb;border-radius:12px;overflow:hidden}}.compact-row{background:#fff}.compact-row__summary{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:52px;transition:background-color .15s ease}.compact-row__summary:active{background:#f8f8f8}.compact-row__thumb{width:36px;height:36px;border-radius:6px;overflow:hidden;flex-shrink:0;background:#f1f5f9;display:flex;align-items:center;justify-content:center}.compact-row__thumb img{width:100%;height:100%;object-fit:cover}.compact-row__thumb-placeholder{font-size:18px;line-height:1}.compact-row__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.compact-row__title{font-size:14px;font-weight:600;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-row__subtitle{font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-row__end{display:flex;align-items:center;gap:8px;flex-shrink:0}.compact-row__badge{font-size:12px;font-weight:600;padding:3px 8px;border-radius:6px;white-space:nowrap}.compact-row__badge.in-stock{background:#ecfdf5;color:#059669}.compact-row__badge.out-of-stock{background:#fef2f2;color:#dc2626}.compact-row__chevron{color:#9ca3af;transition:transform .25s ease;flex-shrink:0}.compact-row__chevron--open{transform:rotate(180deg)}.compact-row__details{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease}.compact-row--expanded .compact-row__details{grid-template-rows:1fr}.compact-row__details-inner{overflow:hidden}.compact-row__detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 14px 12px}.compact-row__detail-item{display:flex;flex-direction:column;gap:2px}.compact-row__detail-label{font-size:10px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.compact-row__detail-item>span:last-child{font-size:13px;color:#374151}.compact-row__actions{display:flex;gap:8px;padding:8px 14px 14px}.compact-row__action-btn{flex:1;padding:10px 0;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:opacity .15s ease}.compact-row__action-btn:active{opacity:.7}.compact-row__action-btn--primary{background:#844a59;color:#fff}.compact-row__action-btn--danger{background:#fef2f2;color:#dc2626}.kassza-panel{padding:20px;max-width:1200px;margin:0 auto;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.kassza-header{text-align:center;margin-bottom:30px}.kassza-header h2{font-size:2rem;color:#2c3e50;margin:0;padding:20px 40px}.kassza-header p{margin:5px 0 0;font-size:1.2rem;color:#6c757d}.kassza-controls{display:flex;gap:20px;margin-bottom:30px;flex-wrap:wrap}.kassza-section{flex:1;min-width:250px}.kassza-section h3{margin:0 0 15px;font-size:18px;font-weight:600;color:#374151}.kassza-btn{padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.kassza-btn.primary{background:#28a745;color:#fff}.kassza-btn.primary:hover{background:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.kassza-btn.secondary{background:#6c757d;color:#fff}.kassza-btn.secondary:hover{background:#5a6268;transform:translateY(-2px)}.kassza-btn.edit{background:#ffc107;color:#856404}.kassza-btn.delete{background:#dc3545;color:#fff}.kassza-search{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:#f8fafc;transition:all .3s ease;box-sizing:border-box}.kassza-search:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.kassza-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;z-index:1000;animation:fadeIn .3s ease-out}.kassza-modal-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;padding:0;max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 30px #0000004d;animation:slideUp .3s ease-out}.kassza-modal-content h3{margin:0;padding:20px 24px;border-bottom:1px solid #e9ecef;color:#374151;font-size:1.5rem;font-weight:600}.kassza-modal-body{flex:1;overflow-y:auto;padding:24px}.kassza-modal-footer{padding:16px 24px;border-top:1px solid #e9ecef;background:#f8fafc;display:flex;gap:12px;justify-content:flex-end;border-radius:0 0 12px 12px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151;font-size:14px}.form-group input,.form-group select{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:#f8fafc;transition:all .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.product-type-buttons{display:flex;gap:12px;margin-top:8px}.product-type-btn{flex:1;padding:12px 20px;border:2px solid #e9ecef;border-radius:8px;background:#f8fafc;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;display:flex;align-items:center;justify-content:center;gap:8px}.product-type-btn:hover{border-color:#844a59;background:#fff5f5;transform:translateY(-1px);box-shadow:0 4px 12px #844a5926}.product-type-btn.active{background:linear-gradient(135deg,#844a59,#6b3a47);color:#fff;border-color:#844a59;box-shadow:0 4px 12px #844a5940}.product-type-btn.active:hover{background:linear-gradient(135deg,#6b3a47,#5a2f3a);transform:translateY(-1px)}.searchable-dropdown{position:relative;margin-top:8px}.searchable-input{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:#f8fafc;transition:all .3s ease;box-sizing:border-box}.searchable-input:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.dropdown-options{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #e9ecef;border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 12px #0000001a}.dropdown-option{padding:12px 16px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s ease}.dropdown-option:hover{background:#f8fafc}.dropdown-option:last-child{border-bottom:none}.option-title{font-weight:600;color:#374151;font-size:14px;margin-bottom:2px}.option-subtitle{color:#6c757d;font-size:12px;margin-bottom:2px}.option-stock{color:#28a745;font-size:11px;font-weight:500}.form-buttons{display:flex;gap:10px;justify-content:center;margin-top:20px}.kassza-content{display:block;width:100%;margin-top:30px}.sales-summary{display:flex;gap:20px;margin-bottom:30px}.summary-card{flex:1;background:linear-gradient(135deg,#f8fafc,#e0e7ff);padding:20px;border-radius:12px;text-align:center;box-shadow:0 4px 12px #0000001a}.summary-card h4{margin:0 0 10px;font-size:16px;font-weight:600;color:#374151}.summary-amount{font-size:24px;font-weight:700;color:#28a745;margin:0}.summary-count{font-size:20px;font-weight:700;color:#667eea;margin:0}.kassza-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 4px 12px #0000001a}.kassza-section.sales-list-section{padding-top:30px}.view-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e9ecef}.view-mode-buttons{display:flex;gap:12px}.view-mode-btn{padding:8px 16px;border:2px solid #e9ecef;border-radius:6px;background:#f8fafc;color:#6c757d;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.view-mode-btn:hover{border-color:#844a59;background:#fff5f5}.view-mode-btn.active{background:linear-gradient(135deg,#844a59,#6b3a47);color:#fff;border-color:#844a59}.month-picker{display:flex;align-items:center;gap:12px}.month-picker label{font-weight:600;color:#374151;margin:0}.month-input{padding:6px 12px;border:2px solid #e9ecef;border-radius:6px;font-size:14px;background:#fff;color:#374151}.sales-list{max-height:600px;overflow-y:auto}.no-sales{text-align:center;padding:30px;color:#6c757d}.no-sales p{font-size:16px;margin:0}.sale-item{border:1px solid #e9ecef;border-radius:6px;padding:12px;margin-bottom:8px;background:#f8fafc;transition:all .2s ease}.sale-item:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.sale-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sale-book{flex:1}.sale-book h4{margin:0 0 8px;color:#374151;font-size:14px;font-weight:600}.sale-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.sale-date{color:#6c757d;font-size:11px;background:#e9ecef;padding:3px 8px;border-radius:12px;font-weight:500}.sale-amount{color:#28a745;font-size:12px;font-weight:600;background:linear-gradient(135deg,#d4edda,#c3e6cb);padding:3px 10px;border-radius:12px}.sale-quantity{color:#374151;font-size:12px;font-weight:600;background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:3px 10px;border-radius:12px}.sale-price{color:#007bff;font-size:12px;font-weight:600;background:linear-gradient(135deg,#e3f2fd,#bbdefb);padding:3px 10px;border-radius:12px}.sale-payment{color:#6f42c1;font-size:12px;font-weight:600;background:linear-gradient(135deg,#f3e5f5,#e1bee7);padding:3px 10px;border-radius:12px}.sale-type{font-size:12px;font-weight:600;padding:3px 10px;border-radius:12px}.sale-type.book{color:#06c;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:1px solid #90caf9}.sale-type.gift{color:#2e7d32;background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border:1px solid #a5d6a7}.sale-details{flex:1;padding-left:15px;display:flex;gap:15px;align-items:center}.sale-details p{margin:0;font-size:12px;color:#4b5563;white-space:nowrap}.sale-details strong{color:#374151;font-weight:600}.sale-actions{display:flex;gap:6px;margin-top:0}.sale-actions .kassza-btn{padding:6px 10px;font-size:11px;min-width:auto}@media (max-width: 768px){.kassza-panel{padding:12px}.kassza-header{margin-bottom:16px}.kassza-header h2{font-size:22px;padding:12px 16px}.kassza-header p{font-size:14px}.kassza-controls{flex-direction:column;gap:12px;margin-bottom:16px}.kassza-section{padding:14px;border-radius:10px;margin-bottom:12px}.kassza-section h3{font-size:15px;margin-bottom:10px}.kassza-content{grid-template-columns:1fr;margin-top:16px}.sales-summary{gap:8px;margin-bottom:16px}.summary-card{padding:12px 10px;border-radius:10px}.summary-card h4{font-size:12px;margin-bottom:4px}.summary-amount{font-size:18px}.summary-count{font-size:16px}.view-controls{flex-direction:column;gap:8px;padding:10px 12px;border-radius:10px}.view-mode-buttons{width:100%;gap:6px}.view-mode-btn{flex:1;text-align:center;padding:8px 10px;font-size:13px}.month-picker{width:100%;gap:8px}.month-picker label{font-size:13px;white-space:nowrap}.month-input{flex:1;max-width:100%;min-width:0;font-size:16px!important;padding:8px 10px}.kassza-section.sales-list-section{padding-top:14px}.sales-list{max-height:none}.sale-item{padding:8px 10px;margin-bottom:6px;border-radius:8px}.sale-item:hover{transform:none}.sale-info{flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:4px}.sale-book h4{font-size:13px;margin-bottom:4px}.sale-badges{gap:4px}.sale-date,.sale-amount,.sale-quantity,.sale-price,.sale-payment,.sale-type{font-size:10px;padding:2px 6px}.sale-details{padding-left:0;margin-top:0;gap:8px;flex-wrap:wrap}.sale-details p{font-size:11px}.sale-actions{gap:4px}.sale-actions .kassza-btn{padding:5px 8px;font-size:10px;min-height:28px}.no-sales{padding:20px}.no-sales p{font-size:14px}.kassza-search{font-size:16px!important;padding:10px 14px;border-radius:10px}.kassza-modal-content{width:95%;max-height:90vh;border-radius:14px}.kassza-modal-content h3{padding:16px;font-size:18px}.kassza-modal-body{padding:16px}.kassza-modal-footer{padding:12px 16px;flex-wrap:wrap}.kassza-modal-footer .kassza-btn{flex:1;min-width:100px}.form-group input,.form-group select,.searchable-input{font-size:16px!important}.product-type-buttons{gap:8px}.product-type-btn{padding:10px 12px;font-size:13px}.delete-modal{max-width:95%}.delete-modal-header,.delete-modal-body{padding:16px}.delete-modal-footer{padding:12px 16px;flex-wrap:wrap}.delete-modal-footer .kassza-btn{flex:1;min-width:100px}}.delete-modal{max-width:500px}.delete-modal-header{text-align:center;padding:20px 24px;border-bottom:1px solid #e9ecef}.delete-modal-header h3{margin:0;color:#dc3545;font-size:1.5rem;font-weight:600}.delete-modal-body{padding:24px;text-align:center}.delete-warning-icon{font-size:3rem;margin-bottom:16px}.delete-modal-body p{margin:0 0 20px;color:#374151;font-size:16px}.sale-preview{background:#f8fafc;border:1px solid #e9ecef;border-radius:8px;padding:16px;margin:20px 0}.sale-preview h4{margin:0 0 12px;color:#374151;font-size:16px;font-weight:600}.sale-details-preview{display:flex;flex-direction:column;gap:8px}.sale-details-preview span{color:#6c757d;font-size:14px}.delete-note{color:#6c757d;font-size:14px;font-style:italic;margin:16px 0 0!important}.delete-modal-footer{padding:16px 24px;border-top:1px solid #e9ecef;background:#f8fafc;display:flex;gap:12px;justify-content:flex-end;border-radius:0 0 12px 12px}.daily-balance-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:0 2px 8px #0000000f}.daily-balance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}.balance-card{background:#f8fafc;border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:4px}.balance-card.positive{background:#ecfdf5}.balance-card.negative{background:#fef2f2}.balance-label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.balance-value{font-size:16px;font-weight:700;color:#1f2937}.balance-card.positive .balance-value{color:#059669}.balance-card.negative .balance-value{color:#dc2626}.balance-closing{display:flex;justify-content:space-between;align-items:center;background:#1f2937;border-radius:10px;padding:14px 18px;margin-bottom:14px}.balance-closing-label{font-size:14px;font-weight:600;color:#d1d5db}.balance-closing-value{font-size:20px;font-weight:700;color:#fff}.balance-closing-value.positive{color:#34d399}.balance-closing-value.negative{color:#f87171}.daily-balance-actions{display:flex;gap:10px;margin-bottom:12px}.daily-balance-actions .kassza-btn{flex:1}.kassza-btn.daily-close{background:linear-gradient(135deg,#1f2937,#374151);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.kassza-btn.daily-close:hover{background:linear-gradient(135deg,#111827,#1f2937)}.kassza-btn.daily-close:disabled{opacity:.5;cursor:not-allowed}.today-extras-list{margin-top:8px}.today-extras-list h4{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px}.extra-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:8px;margin-bottom:4px;font-size:13px}.extra-item.income{background:#ecfdf5}.extra-item.expense{background:#fef2f2}.extra-desc{color:#374151;font-weight:500}.extra-amount.income{color:#059669;font-weight:600}.extra-amount.expense{color:#dc2626;font-weight:600}.sale-seller{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;background:#f3f4f6;color:#6b7280;font-weight:500}@media (max-width: 768px){.daily-balance-grid{grid-template-columns:repeat(2,1fr);gap:6px}.balance-card{padding:10px 12px}.balance-value{font-size:14px}.balance-closing{padding:12px 14px}.balance-closing-value{font-size:18px}.daily-balance-actions{flex-direction:column;gap:8px}.extra-item{font-size:12px;padding:6px 10px}}*{margin:0;padding:0;box-sizing:border-box}button,a,[role=button]{-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;min-height:44px;touch-action:manipulation}html{scrollbar-width:thin;scrollbar-color:#844a59 #f1f5f9}.custom-scrollbar{scrollbar-width:thin;scrollbar-color:#844a59 #f8fafc}.custom-scrollbar::-webkit-scrollbar{width:8px}.custom-scrollbar::-webkit-scrollbar-track{background:#f8fafc;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#844a59;border-radius:4px;transition:background .3s ease}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#6b3a48}body{margin:0;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#e8e0e2;color:#2c3e50;line-height:1.6}.main-content-with-sidebar{margin-left:280px;min-height:100vh;background:#e8e0e2;transition:margin-left .3s ease;position:relative}.main-content-with-sidebar[style*="margin-left: 280px"] .books-container[data-density-value="4"]{--card-density: 3 !important}.main-content-with-sidebar[style*="margin-left: 280px"] .books-container[data-density-value="7"]{--card-density: 5 !important}.main-content-with-sidebar[style*="margin-left: 280px"] .books-container[data-density-value="10"]{--card-density: 8 !important}.books-container[data-density-value="4"]{--font-scale-factor: 1.1}.books-container[data-density-value="7"]{--font-scale-factor: 1}.books-container[data-density-value="10"]{--font-scale-factor: .9}.tab-content{padding:40px;background:#fff;margin:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a;font-size:calc(16px * var(--font-scale-factor, 1))}.tab-content h2{color:#2c3e50;font-size:calc(24px * var(--font-scale-factor, 1));margin-bottom:20px}.tab-content h3{color:#2c3e50;font-size:calc(20px * var(--font-scale-factor, 1));margin-bottom:15px}.tab-content p{font-size:calc(16px * var(--font-scale-factor, 1));line-height:1.6}.App{min-height:100vh;background:#e8e0e2}.App-header{padding:0;text-align:center;background:linear-gradient(135deg,#f8f9fa,#e8e0e2);box-shadow:0 2px 10px #0000000d;border-bottom:1px solid #dee2e6}.title-container{text-align:center;flex:1;padding:20px 40px}.title-container h1{margin:0;font-size:2rem;color:#2c3e50}.title-container p{margin:5px 0 0;font-size:1.2rem;color:#6c757d}.header-section{padding:20px;border-bottom:1px solid #f0f0f0}.header-section:last-child{border-bottom:none}.logo-container{display:flex;justify-content:center;align-items:center;padding:20px}.app-logo{height:60px;width:auto;max-width:280px}.header-title{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:0}.header-title h1{font-size:2.5rem;font-weight:700;color:#2c3e50;margin:0;letter-spacing:-.5px}.header-controls{display:flex;justify-content:space-between;align-items:center;padding:25px 20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #dee2e6;box-shadow:0 4px 12px #0000000d;position:relative;z-index:10}.controls-left{display:flex;align-items:center;gap:20px}.user-welcome{color:#2c3e50;font-size:.95rem}.user-welcome strong{color:#844a59}.logout-btn{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.logout-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc35454d}.controls-right{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.book-stats{display:flex;justify-content:flex-start;align-items:center;gap:10px;flex-wrap:wrap}.total-books{color:#2c3e50;font-size:18px;font-weight:600;background:linear-gradient(135deg,#e8f4f8,#d6eef5);padding:8px 16px;border-radius:20px;border:1px solid #b8d4db}.filtered-books{color:#6c757d;font-size:14px;font-weight:500;font-style:italic}.header-density{display:none}.main-content{background:#e8e0e2;margin-top:30px;position:relative}.books-container{display:flex;flex-wrap:wrap;gap:15px;padding:40px;max-width:1400px;margin:0 auto;background:#e8e0e2}.books-container:has(.bookstore-table-container){display:block}.book-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .5s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;height:100%;flex-basis:calc((100% / var(--card-density)) - 15px);max-width:calc((100% / var(--card-density)) - 15px);flex-grow:0;flex-shrink:0}.density-buttons-wrapper{display:flex;justify-content:center;align-items:center;padding:12px 20px;margin:24px auto 16px;background:#fff9;border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:fit-content}.density-buttons{display:flex;gap:8px;justify-content:center;align-items:center}.density-btn{display:flex;align-items:center;justify-content:center;padding:8px 12px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;width:44px;height:44px}.density-btn:hover{border-color:#844a59;transform:translateY(-1px);box-shadow:0 2px 8px #844a5933}.density-btn.active{background:#844a59;border-color:#844a59;color:#fff;transform:translateY(-1px);box-shadow:0 2px 12px #844a594d}.density-icon{font-size:18px;line-height:1}.density-icon-img{width:20px;height:20px;object-fit:contain;opacity:.7;transition:opacity .2s ease}.density-btn:hover .density-icon-img{opacity:1}.density-btn.active .density-icon-img{opacity:1;filter:brightness(0) invert(1)}.filter-toggle-btn{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #844a594d}.filter-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #844a5966;background:linear-gradient(135deg,#6b3c47,#5a2f3a)}.filters-wrapper{overflow:hidden;transition:height .5s ease;height:0}.filters-wrapper.show{min-height:220px;height:auto}.filters-section{margin:0;padding:25px 20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;box-shadow:inset 0 2px 4px #0000000d}.filter-row{display:flex;gap:15px;margin-bottom:20px;align-items:center;flex-wrap:wrap}.filter-row:last-child{margin-bottom:0}.filter-input{flex:1;min-width:250px;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:all .3s ease;background-color:#f8f9fa}.filter-input:focus{outline:none;border-color:#844a59;box-shadow:0 0 0 3px #844a591a;background-color:#fff}.filter-select{min-width:200px;padding:12px 40px 12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;transition:all .3s ease;background-color:#f8f9fa;cursor:pointer;color:#2c3e50;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236c757d' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px}.filter-select:focus{outline:none;border-color:#844a59;box-shadow:0 0 0 3px #844a591a;background-color:#fff}.filter-select:hover{border-color:#844a59}.clear-filters-btn{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #dc35454d;white-space:nowrap}.clear-filters-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #dc354566;background:linear-gradient(135deg,#c82333,#bd2130)}.filter-results{margin-top:15px;padding:12px 16px;background:linear-gradient(135deg,#e8f4f8,#d6eef5);border-radius:8px;color:#2c3e50;border:1px solid #b8d4db;font-size:14px;font-weight:500;text-align:center;position:relative;z-index:10}.no-books{grid-column:1 / -1;text-align:center;padding:60px 20px;color:#6c757d;font-size:18px;font-weight:500}.no-books p{margin:0;line-height:1.6}.density-control{margin-top:25px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000000d;border:1px solid #e9ecef;max-width:400px;margin-left:auto;margin-right:auto}.density-label{display:block;text-align:center;color:#2c3e50;font-weight:600;margin-bottom:10px;font-size:14px}.density-value{color:#844a59;font-weight:700;font-size:16px}.density-labels{display:flex;justify-content:space-between;color:#6c757d;font-size:12px;font-weight:500}.add-book-btn{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #844a594d}.add-book-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #844a5966;background:linear-gradient(135deg,#6b3c47,#5a2f3a)}.book-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .5s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;height:100%}.book-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026;border-color:#844a59}.book-thumbnail-container{width:100%;height:0;padding-bottom:154%;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.books-container .book-thumbnail{position:absolute;top:0;left:0;width:100%!important;height:100%!important;max-height:none!important;min-height:none!important;object-fit:contain!important;object-position:center!important;pointer-events:none}.book-card{pointer-events:auto;cursor:pointer}.book-card.lent-out{background:#fff5f5;border-color:#feb2b2;opacity:.8}.book-card.lent-out:hover{transform:translateY(-2px);box-shadow:0 6px 20px #fe2b2b26;border-color:#dc3545}.lent-out-badge{position:absolute;top:10px;right:10px;background:#dc3545;color:#fff;padding:6px 10px;border-radius:20px;font-size:11px;font-weight:600;box-shadow:0 2px 8px #dc35454d;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.book-thumbnail-placeholder{width:60px;height:60px;opacity:.3}.book-info{padding:calc(15px - (var(--card-density) - 7) * 1px);flex:1;display:flex;flex-direction:column;justify-content:space-between}.books-container[data-density-value="10"] .book-info{display:none}.books-container[data-density-value="10"] .book-card{padding:12px;display:flex;align-items:center;justify-content:center;height:144px;min-height:144px}.books-container[data-density-value="10"] .book-thumbnail-container{width:100%;height:120px;display:flex;align-items:center;justify-content:center}.books-container[data-density-value="10"] .book-thumbnail{max-width:100%;max-height:100%;object-fit:contain}.books-container[data-density-value="10"] .book-thumbnail-placeholder{font-size:32px;opacity:.6}.books-container[data-density-value="10"] .lent-out-badge{font-size:10px;padding:2px 6px}.book-title{color:#2c3e50;font-size:calc((16px - (var(--card-density) - 7) * .5px) * var(--font-scale-factor, 1));font-weight:600;margin:0;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;box-orient:vertical;text-overflow:ellipsis;min-height:calc(42px - (var(--card-density) - 7) * 2px)}.bookstore-info{display:flex;flex-direction:column;gap:4px;margin-top:8px}.book-quantity{font-size:calc((14px - (var(--card-density) - 7) * .3px) * var(--font-scale-factor, 1));color:#28a745;font-weight:500}.book-price{font-size:calc((15px - (var(--card-density) - 7) * .4px) * var(--font-scale-factor, 1));color:#844a59;font-weight:600}.book-info p{color:#6c757d;font-size:calc((14px - (var(--card-density) - 7) * .3px) * var(--font-scale-factor, 1));margin:0;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.bookstore-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a;margin:20px 0;width:100%;max-width:100%;flex-basis:100%;flex-shrink:0}.bookstore-table{width:100%;border-collapse:collapse;font-size:14px}.bookstore-table th{background:#f8fafc;padding:16px 12px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e2e8f0;position:sticky;top:0;z-index:10}.bookstore-table th.table-header-cover{width:80px;text-align:center}.bookstore-table th.table-header-title{width:350px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.bookstore-table th.table-header-title:hover{background:#e2e8f0}.bookstore-table th.table-header-author{width:220px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.bookstore-table th.table-header-author:hover{background:#e2e8f0}.bookstore-table th.table-header-price{width:130px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.bookstore-table th.table-header-price:hover{background:#e2e8f0}.bookstore-table th.table-header-quantity{width:110px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.bookstore-table th.table-header-quantity:hover{background:#e2e8f0}.bookstore-table th.table-header-status{width:130px}.bookstore-table th.table-header-actions{width:280px;text-align:center}.bookstore-table td{padding:12px;border-bottom:1px solid #e2e8f0;vertical-align:middle}.bookstore-table tr:hover{background:#f8fafc}.table-row{transition:background-color .2s ease}.table-cell-cover{text-align:center}.table-thumbnail{width:50px;height:70px;display:flex;align-items:center;justify-content:center;margin:0 auto}.table-thumbnail-img{width:100%;height:100%;object-fit:cover;border-radius:4px;box-shadow:0 2px 4px #0000001a}.table-thumbnail-placeholder{width:50px;height:70px;background:#f1f5f9;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#64748b}.table-cell-title{cursor:pointer;transition:color .2s ease}.table-cell-title:hover{color:#844a59}.table-title{font-weight:600;color:#2c3e50;margin-bottom:4px}.table-year{font-size:12px;color:#64748b}.table-cell-author{color:#475569}.table-cell-price{font-weight:600;color:#844a59;white-space:nowrap}.table-cell-quantity{text-align:center}.quantity-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.quantity-badge.high{background:#dcfce7;color:#166534}.quantity-badge.low{background:#fef3c7;color:#92400e}.quantity-badge.out{background:#fee2e2;color:#991b1b}.table-cell-status{text-align:center}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.status-badge.in-stock{background:#dcfce7;color:#166534}.status-badge.out-of-stock{background:#fee2e2;color:#991b1b}.table-cell-actions{text-align:center}.table-actions{display:flex;gap:6px;justify-content:center;align-items:stretch;flex-wrap:nowrap}.table-action-btn{padding:10px 12px;border:none;border-radius:6px;font-size:13px;font-weight:600;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex:1;min-width:70px;max-width:85px;height:100%;display:flex;align-items:center;justify-content:center;text-align:center}.table-action-btn:disabled{opacity:.5;cursor:not-allowed}.table-action-btn.sell-btn{background:#28a745;color:#fff}.table-action-btn.sell-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.table-action-btn.edit-btn{background:#844a59;color:#fff}.table-action-btn.edit-btn:hover{background:#6b3a48;transform:translateY(-1px)}.table-action-btn.delete-btn{background:#dc3545;color:#fff}.table-action-btn.delete-btn:hover{background:#c82333;transform:translateY(-1px)}@media (max-width: 1024px){.table-actions{flex-direction:column;gap:4px}.table-action-btn{width:100%;max-width:none;min-width:auto}}@media (max-width: 768px){.bookstore-table-container{overflow-x:auto}.bookstore-table{min-width:900px}.table-actions{flex-direction:column;gap:3px}.table-action-btn{font-size:12px;padding:8px 10px;width:100%;max-width:none}}:root{--card-density: 4;--font-scale-factor: 1}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0000;display:flex;justify-content:center;align-items:center;z-index:-1;opacity:0;pointer-events:none;transition:background-color .3s ease,opacity .3s ease,z-index .3s ease;-webkit-backdrop-filter:none;backdrop-filter:none}.modal.show{background-color:#00000080;opacity:1;pointer-events:auto;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:#fff;padding:40px;border-radius:16px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;border:1px solid #e9ecef;transform:scale(.9) translateY(20px);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.modal.show .modal-content{transform:scale(1) translateY(0);opacity:1}.modal-content h2{color:#2c3e50;margin-bottom:30px;text-align:center;font-size:24px;font-weight:700}.modal-content input,.modal-content textarea{width:100%;padding:14px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;margin-bottom:20px;transition:all .3s ease;background-color:#f8f9fa;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.modal-content input:focus,.modal-content textarea:focus{outline:none;border-color:#844a59;box-shadow:0 0 0 3px #844a591a;background-color:#fff}.modal-content textarea{min-height:100px;resize:vertical}.modal-buttons{display:flex;gap:15px;justify-content:flex-end;margin-top:20px}.modal-buttons button{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;min-width:120px;height:44px;display:flex;align-items:center;justify-content:center;white-space:nowrap}.modal-buttons button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.modal-buttons button:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-buttons button:not(.delete-btn):not(.confirm-delete-btn){background:#f1f5f9;color:#475569}.modal-buttons button:not(.delete-btn):not(.confirm-delete-btn):hover:not(:disabled){background:#e2e8f0}.edit-btn{background:#dbeafe;color:#1d4ed8;width:140px;margin-top:0!important}.edit-btn:hover:not(:disabled){background:#bfdbfe}.edit-btn:disabled{background:#f1f5f9;color:#94a3b8}.delete-btn{background:#fee2e2;color:#dc2626;width:120px}.delete-btn:hover:not(:disabled){background:#fecaca}.delete-btn:disabled{background:#f1f5f9;color:#94a3b8}.save-btn{background:#10b981;color:#fff;width:120px}.save-btn:hover:not(:disabled){background:#059669}.cancel-btn{background:#f1f5f9;color:#475569;width:120px}.modal-inner-content{max-height:70vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#844a59 #f8fafc;margin:-10px;padding:10px}.modal-inner-content::-webkit-scrollbar{width:8px}.modal-inner-content::-webkit-scrollbar-track{background:#f8fafc;border-radius:4px}.modal-inner-content::-webkit-scrollbar-thumb{background:#844a59;border-radius:4px;transition:background .3s ease}.modal-inner-content::-webkit-scrollbar-thumb:hover{background:#6b3a48}.user-edit-form{width:100%;max-width:400px;scrollbar-width:thin;scrollbar-color:#844a59 #f8fafc}.user-edit-form::-webkit-scrollbar{width:8px}.user-edit-form::-webkit-scrollbar-track{background:#f8fafc;border-radius:4px}.user-edit-form::-webkit-scrollbar-thumb{background:#844a59;border-radius:4px;transition:background .3s ease}.user-edit-form::-webkit-scrollbar-thumb:hover{background:#6b3a48}.user-detail-info{scrollbar-width:thin;scrollbar-color:#844a59 #f8fafc}.user-detail-info::-webkit-scrollbar{width:8px}.user-detail-info::-webkit-scrollbar-track{background:#f8fafc;border-radius:4px}.user-detail-info::-webkit-scrollbar-thumb{background:#844a59;border-radius:4px;transition:background .3s ease}.user-detail-info::-webkit-scrollbar-thumb:hover{background:#6b3a48}.user-edit-form .form-group{margin-bottom:15px}.user-edit-form label{display:block;font-weight:600;color:#374151;margin-bottom:5px;font-size:14px}.user-edit-form .edit-input{width:100%;padding:8px 12px;border:2px solid #844a59;border-radius:6px;font-size:14px;margin-top:4px;transition:border-color .3s ease}.user-edit-form .edit-input:focus{outline:none;border-color:#6b3a48}.user-edit-form textarea.edit-input{min-height:80px;resize:vertical}.delete-confirm-modal{max-width:450px;width:90%}.delete-confirm-content{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:30px}.delete-confirm-icon{font-size:48px;margin-bottom:20px}.delete-confirm-text h3{margin:0 0 15px;color:#1e293b;font-size:20px}.delete-user-info{background:#f8fafc;padding:15px;border-radius:8px;margin:15px 0;border:1px solid #e2e8f0}.delete-user-info strong{display:block;color:#1e293b;font-size:16px;margin-bottom:5px}.delete-user-info span{color:#64748b;font-size:14px}.delete-warning{color:#dc2626;font-size:14px;line-height:1.5;margin:15px 0 0}.delete-confirm-buttons{justify-content:space-between}.cancel-btn{background:#f1f5f9;color:#475569}.cancel-btn:hover:not(:disabled){background:#e2e8f0}.confirm-delete-btn{background:#dc2626;color:#fff}.confirm-delete-btn:hover:not(:disabled){background:#b91c1c}.edit-input{width:100%;padding:8px 12px;border:2px solid #844a59;border-radius:6px;font-size:14px;margin-top:4px;transition:all .3s ease}.edit-input:focus{outline:none;border-color:#6d4a5c;box-shadow:0 0 0 3px #844a591a}.edit-textarea{width:100%;padding:8px 12px;border:2px solid #844a59;border-radius:6px;font-size:14px;margin-top:4px;resize:vertical;min-height:80px;transition:all .3s ease}.edit-textarea:focus{outline:none;border-color:#6d4a5c;box-shadow:0 0 0 3px #844a591a}.book-detail-field{margin-bottom:16px}.book-detail-field strong{display:block;margin-bottom:4px;color:#2c3e50;font-weight:600}.title-section,.url-section{display:flex;gap:15px;margin-bottom:25px}.url-input{flex:1;padding:14px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:all .3s ease;background-color:#f8f9fa}.url-input:focus{outline:none;border-color:#844a59;box-shadow:0 0 0 3px #844a591a;background-color:#fff}.process-url-btn{padding:14px 20px;background:linear-gradient(135deg,#844a59,#6d4a5c);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;min-width:140px}.process-url-btn:hover:not(:disabled){background:linear-gradient(135deg,#6d4a5c,#5a3d4a);transform:translateY(-2px);box-shadow:0 4px 12px #844a594d}.process-url-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.manual-entry{display:flex;flex-direction:column;gap:15px}.divider{text-align:center;margin:25px 0;position:relative}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e9ecef}.divider:after{content:attr(data-text);position:relative;padding:0 15px;background:#fff;color:#6c757d;font-size:14px;font-weight:500}.title-input{flex:1;padding:14px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:all .3s ease;background-color:#f8f9fa}.title-input:focus{outline:none;border-color:#844a59;box-shadow:0 0 0 3px #844a591a;background-color:#fff}.search-btn{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;border:none;padding:14px 24px;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #844a594d;white-space:nowrap}.search-btn:hover{background:linear-gradient(135deg,#6b3c47,#5a2f3a);transform:translateY(-1px);box-shadow:0 6px 20px #844a5966}.search-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.results-modal{max-width:900px;max-height:85vh;overflow-y:auto}.results-count{text-align:center;color:#6c757d;margin-bottom:25px;font-size:14px;font-weight:500}.results-list{max-height:500px;overflow-y:auto;margin-bottom:25px}.result-item{display:flex;gap:20px;padding:20px;border:2px solid #e9ecef;border-radius:12px;margin-bottom:15px;cursor:pointer;transition:all .3s ease;background:#fff}.result-item:hover{background:#f8f9fa;border-color:#844a59;transform:translateY(-2px);box-shadow:0 4px 15px #844a591a}.result-thumbnail{width:100px;height:140px;object-fit:cover;border-radius:8px;border:2px solid #e9ecef;flex-shrink:0}.no-thumbnail{width:100px;height:140px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #e9ecef;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#6c757d;font-size:12px;text-align:center;flex-shrink:0}.thumbnail-upload-section{margin:15px 0}.thumbnail-upload-container{display:flex;flex-direction:column;align-items:center;gap:15px}.thumbnail-preview{width:200px;height:280px;border:2px dashed #dee2e6;border-radius:12px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#f8f9fa;transition:all .3s ease}.thumbnail-preview:hover{border-color:#844a59;background:#fff}.thumbnail-preview-image{width:100%;height:100%;object-fit:cover}.thumbnail-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:10px;color:#6c757d;text-align:center;padding:20px}.thumbnail-upload-icon{width:48px;height:48px;stroke-width:1.5}.thumbnail-upload-btn{background:#844a59;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;display:flex;align-items:center;gap:8px}.thumbnail-upload-btn:hover{background:#6d3d4a;transform:translateY(-1px);box-shadow:0 4px 12px #844a594d}.thumbnail-upload-btn:active{transform:translateY(0)}@media (max-width: 768px){.thumbnail-preview{width:150px;height:210px}.thumbnail-upload-container{flex-direction:row;flex-wrap:wrap;justify-content:center}}.modern-loader{display:flex;align-items:center;justify-content:center;padding:8px 16px}.loader-dots{display:flex;gap:4px}.loader-dots span{width:8px;height:8px;background:#fff;border-radius:50%;animation:loading-dots 1.4s infinite ease-in-out both}.loader-dots span:nth-child(1){animation-delay:-.32s}.loader-dots span:nth-child(2){animation-delay:-.16s}.loader-dots span:nth-child(3){animation-delay:0}@keyframes loading-dots{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.success-message{display:flex;align-items:center;gap:10px;padding:12px 16px;margin:10px 0;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border-radius:8px;font-size:14px;font-weight:500;animation:slideInUp .3s ease-out;box-shadow:0 4px 12px #28a7454d}.success-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#fff3;border-radius:50%;font-weight:700;font-size:12px}@keyframes slideInUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.process-url-btn:disabled{cursor:not-allowed;opacity:.8}.process-url-btn:disabled .modern-loader{pointer-events:none}.form-field{margin-bottom:16px}.field-label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:#2c3e50;text-align:left}.form-field input,.form-field textarea{width:100%;padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;transition:border-color .3s ease,box-shadow .3s ease}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:#844a59;box-shadow:0 0 0 2px #844a591a}.form-field textarea{resize:vertical;min-height:80px}.form-field .thumbnail-upload-section{margin-top:8px;margin-bottom:0}.delete-btn{background:#dc3545;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.delete-btn:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 4px 12px #dc35454d}.delete-btn:active{transform:translateY(0)}.confirm-modal{max-width:400px;text-align:center}.confirm-message{margin:20px 0;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #dc3545}.book-to-delete{margin-top:10px;font-size:16px;color:#2c3e50}.book-to-delete strong{color:#dc3545}.confirm-delete-btn{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;margin-right:10px}.confirm-delete-btn:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 4px 12px #dc35454d}.cancel-delete-btn{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.cancel-delete-btn:hover{background:#5a6268;transform:translateY(-1px);box-shadow:0 4px 12px #6c757d4d}.result-info{flex:1}.result-info h3{color:#2c3e50;margin:0 0 12px;font-size:18px;font-weight:600;line-height:1.3}.result-info p{margin:6px 0;color:#6c757d;font-size:14px;line-height:1.5}.result-info strong{color:#2c3e50;font-weight:600}.result-source{font-style:italic;color:#844a59;font-size:12px;font-weight:500}.result-description{color:#6c757d;font-size:13px;line-height:1.5;margin-top:10px}.no-cover-note{color:#844a59;font-size:12px;font-style:italic;margin-top:8px;font-weight:500}.book-detail-modal{max-width:600px;max-height:80vh;overflow-y:auto}.book-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e9ecef}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#2c3e50}.book-detail-content{display:flex;gap:20px;margin-bottom:20px}.book-detail-thumbnail{flex-shrink:0;width:150px;height:200px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:8px;overflow:hidden}.book-detail-image{max-width:100%;max-height:100%;object-fit:cover}.book-detail-placeholder{width:60px;height:60px;color:#6c757d}.book-detail-info{flex:1}.book-detail-field{margin-bottom:15px}.book-detail-field strong{color:#2c3e50;display:block;margin-bottom:5px}.book-detail-field p{margin:0;line-height:1.5;color:#495057}.loading-screen{padding:50px 20px;background:#e8e0e2}.loading-spinner{width:40px;height:40px;border:3px solid rgba(132,74,89,.3);border-top:3px solid #844a59;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.loading-screen p{font-size:16px;margin-top:15px;text-align:center;color:#2c3e50}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){body{background:#f2f2f7;-webkit-text-size-adjust:100%}input,textarea,select{font-size:16px!important}.App{background:#f2f2f7}.main-content-with-sidebar{margin-left:0!important;padding-top:env(safe-area-inset-top,0px);padding-bottom:calc(84px + env(safe-area-inset-bottom,0px));background:#f2f2f7;min-height:100vh}.App-header{padding:0;padding-top:env(safe-area-inset-top,0px);background:#fff;box-shadow:none;border-bottom:.5px solid rgba(0,0,0,.12)}.header-section{padding:0;border-bottom:none}.header-title{background:#fff;padding:0}.title-container{padding:16px 16px 8px;text-align:left}.title-container h1{font-size:28px;font-weight:700;letter-spacing:-.5px;color:#000}.title-container p{font-size:14px;color:#8e8e93;margin-top:2px}.header-controls{flex-direction:column;gap:10px;padding:8px 16px 12px;background:#fff;border-bottom:none;box-shadow:none}.controls-left{width:100%}.controls-right{display:flex;gap:8px;width:100%;flex-wrap:wrap;overflow:visible}.book-stats{gap:8px}.total-books{font-size:14px;padding:6px 12px;border-radius:16px;background:#f2f2f7;border:none;color:#3c3c43;font-weight:500}.controls-right button{flex:1;font-size:14px;padding:10px 14px;white-space:nowrap;border-radius:10px}.filter-toggle-btn,.add-book-btn{font-size:14px;padding:10px 16px;border-radius:10px;box-shadow:none;font-weight:500}.filters-wrapper.show{min-height:auto}.filters-section{padding:12px 16px;margin:0;background:#fff;border-radius:0;box-shadow:none}.filter-row{flex-direction:column;gap:8px;margin-bottom:10px}.filter-row:last-child{margin-bottom:0}.filter-input{width:100%;min-width:0;font-size:16px;padding:12px 14px;border-radius:10px;border:1px solid #d1d1d6;background:#f2f2f7}.filter-input:focus{background:#fff;border-color:#844a59}.filter-select{width:100%;min-width:0;font-size:16px;padding:12px 36px 12px 14px;border-radius:10px;border:1px solid #d1d1d6;background-color:#f2f2f7}.filter-select:focus{background-color:#fff}.clear-filters-btn{width:100%;border-radius:10px;padding:10px 16px;font-size:14px;box-shadow:none}.filter-results{border-radius:10px;font-size:13px;margin-top:10px;padding:10px 14px}.main-content{margin-top:0;background:#f2f2f7}.books-container{display:grid!important;grid-template-columns:repeat(2,1fr);gap:10px;padding:12px;max-width:100%;background:#f2f2f7}.books-container:has(.bookstore-table-container){display:block!important}.book-card{flex-basis:auto!important;max-width:none!important;border-radius:14px;padding:0;overflow:hidden;box-shadow:0 1px 3px #00000014;border:.5px solid rgba(0,0,0,.04);transition:transform .15s ease}.book-card:active{transform:scale(.97)}.book-card:hover{transform:none;box-shadow:0 1px 3px #00000014}.book-thumbnail-container{border-radius:0}.book-info{padding:10px 12px 12px}.book-title{font-size:14px!important;font-weight:600;letter-spacing:-.2px;min-height:auto!important;-webkit-line-clamp:2;line-clamp:2}.book-author{font-size:12px!important;color:#8e8e93}.bookstore-info{margin-top:6px;gap:2px}.book-quantity{font-size:12px!important}.book-price{font-size:14px!important;font-weight:700}.lent-out-badge{font-size:9px;padding:4px 8px;top:6px;right:6px;border-radius:12px}.density-buttons-wrapper{display:none}.tab-content{padding:16px;margin:0;border-radius:0;box-shadow:none;background:#f2f2f7}.modal.show{align-items:flex-end}.modal-content{width:100%;max-width:100%;max-height:92vh;border-radius:14px 14px 0 0;padding:20px 16px calc(16px + env(safe-area-inset-bottom,0px));margin:0;animation:modalSlideUp .35s cubic-bezier(.32,.72,0,1)}@keyframes modalSlideUp{0%{transform:translateY(100%);opacity:1}to{transform:translateY(0);opacity:1}}.modal-content h2{font-size:20px;margin-bottom:20px;text-align:left;letter-spacing:-.3px}.modal-content input,.modal-content textarea{font-size:16px;padding:12px 14px;border-radius:10px;border:1px solid #d1d1d6;background:#f2f2f7;margin-bottom:14px}.modal-content input:focus,.modal-content textarea:focus{background:#fff}.modal-buttons{gap:10px;flex-wrap:wrap}.modal-buttons button{min-width:auto;flex:1;border-radius:10px;font-size:15px;padding:12px 16px}.title-section,.url-section{flex-direction:column;gap:10px}.url-input,.title-input{font-size:16px;border-radius:10px;padding:12px 14px}.process-url-btn,.search-btn{width:100%;border-radius:10px;min-width:auto;font-size:15px;padding:12px 16px;box-shadow:none}.results-modal{max-height:92vh}.results-list{max-height:60vh}.result-item{flex-direction:row;gap:12px;padding:12px;border-radius:12px;margin-bottom:8px;border:.5px solid #e5e5ea}.result-thumbnail,.no-thumbnail{width:60px;height:84px;border-radius:6px;border:none}.result-info h3{font-size:15px;margin-bottom:6px}.result-info p{font-size:13px;margin:3px 0}.book-detail-modal{max-height:92vh}.book-detail-content{flex-direction:column;align-items:center;gap:16px}.book-detail-thumbnail{width:120px;height:168px;border-radius:10px}.book-detail-header{margin-bottom:16px;padding-bottom:12px}.form-field{margin-bottom:12px}.field-label{font-size:13px;color:#6d6d72;text-transform:uppercase;letter-spacing:.3px;margin-bottom:5px}.form-field input,.form-field textarea{font-size:16px;padding:12px 14px;border-radius:10px;border:1px solid #d1d1d6;background:#f2f2f7}.form-field input:focus,.form-field textarea:focus{background:#fff}.thumbnail-preview{width:120px;height:168px;border-radius:10px}.thumbnail-upload-container{flex-direction:column;align-items:center}.thumbnail-upload-btn{border-radius:10px;width:100%;justify-content:center}.bookstore-table-container{border-radius:0;box-shadow:none;margin:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.bookstore-table{min-width:480px;font-size:12px}.bookstore-table th{padding:8px 6px;font-size:11px;position:sticky;top:0;white-space:nowrap}.bookstore-table td{padding:6px}.table-header-cover,.bookstore-table td:first-child{display:none}.users-panel{padding:16px}.users-header h2{font-size:28px;letter-spacing:-.5px}.users-stats{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:16px;border-radius:14px}.stat-number{font-size:24px}.users-controls{flex-direction:column;gap:10px}.search-container{max-width:100%}.search-input{font-size:16px;border-radius:10px;padding:12px 14px}.role-filters{gap:6px}.role-filter-btn{font-size:13px;padding:6px 14px}.users-grid{grid-template-columns:1fr;gap:10px}.user-card{border-radius:14px;padding:16px;border:.5px solid rgba(0,0,0,.04);box-shadow:0 1px 3px #0000000f}.user-card:hover{transform:none;box-shadow:0 1px 3px #0000000f}.user-card:active{background:#f9f9f9}.loading-screen{background:#f2f2f7;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh}.no-books{padding:40px 16px;font-size:15px}.delete-confirm-modal{border-radius:14px 14px 0 0}.logout-confirm-modal{border-radius:14px}}.users-panel{padding:20px;max-width:1200px;margin:0 auto}.users-header{margin-bottom:30px}.users-header h2{color:#2c3e50;margin-bottom:10px;font-size:calc(28px * var(--font-scale-factor, 1))}.user-count{font-size:calc(18px * var(--font-scale-factor, 1));color:#6b3a48;font-weight:500;margin-bottom:20px}.users-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:12px;text-align:center;box-shadow:0 4px 15px #667eea4d;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #667eea66}.stat-number{font-size:32px;font-weight:700;margin-bottom:5px}.stat-label{font-size:14px;opacity:.9}.users-controls{display:flex;gap:20px;margin-bottom:20px;align-items:center}.search-container{flex:1;max-width:400px}.search-input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#844a59}.role-filters{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.role-filter-btn{padding:8px 16px;border:2px solid #e2e8f0;border-radius:20px;background:#f8fafc;color:#64748b;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.role-filter-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.role-filter-btn.active{background:#844a59;border-color:#844a59;color:#fff}.role-filter-btn.active:hover{background:#6b3a48;border-color:#6b3a48}.users-list{margin-top:20px}.no-users{text-align:center;padding:60px 20px;color:#64748b}.no-users p{font-size:16px;margin:0}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.user-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000001a;transition:transform .3s ease,box-shadow .3s ease;cursor:pointer;border:2px solid transparent}.user-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px #00000026;border-color:#667eea}.user-avatar{display:flex;justify-content:center;margin-bottom:15px}.user-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid #f1f5f9}.avatar-placeholder{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700;border:3px solid #f1f5f9}.user-info h3{margin:0 0 8px;color:#1e293b;font-size:18px;font-weight:600;text-align:center}.user-email{color:#64748b;font-size:14px;text-align:center;margin:0 0 12px;word-break:break-all}.user-meta{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.role-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-badge.admin{background:#fee2e2;color:#dc2626}.role-badge.owner{background:#fef3c7;color:#d97706}.role-badge.member{background:#dbeafe;color:#2563eb}.user-status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background:#f1f5f9;color:#64748b}.user-dates{display:flex;flex-direction:column;gap:4px}.user-dates small{color:#94a3b8;font-size:12px;text-align:center}.user-details-modal{max-width:500px;width:90%}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f1f5f9}.modal-header h2{margin:0;color:#1e293b;font-size:24px}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#64748b;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s ease}.close-btn:hover{background-color:#f1f5f9;color:#1e293b}.user-details-content{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:30px}.user-detail-avatar{margin-bottom:20px}.user-detail-avatar img{width:100px;height:100px;border-radius:50%;object-fit:cover;border:4px solid #f1f5f9;box-shadow:0 4px 12px #0000001a}.user-detail-avatar .avatar-placeholder{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:40px;font-weight:700;border:4px solid #f1f5f9;box-shadow:0 4px 12px #0000001a}.user-detail-info{width:100%;max-width:400px}.user-detail-name{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:5px}.user-detail-email{font-size:14px;color:#64748b;margin-bottom:20px;word-break:break-all}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f1f5f9}.detail-row:last-child{border-bottom:none}.detail-row label{font-weight:600;color:#374151;min-width:120px;text-align:left}.detail-row span{color:#6b7280;text-align:right;flex:1}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.inactive{background:#fee2e2;color:#dc2626}@media (max-width: 768px){.users-panel{padding:15px}.users-stats{justify-content:center}.users-controls{flex-direction:column;gap:15px}.search-container{max-width:100%}.role-filters{justify-content:center;gap:8px}.role-filter-btn{padding:6px 12px;font-size:13px}.users-grid{grid-template-columns:1fr;gap:15px}.user-details-modal{max-width:95%;width:95%}.user-detail-avatar img,.user-detail-avatar .avatar-placeholder{width:80px;height:80px;font-size:32px}.user-detail-name{font-size:18px}.detail-row{flex-direction:column;align-items:flex-start;gap:5px}.detail-row label{min-width:auto}.detail-row span{text-align:left}.delete-confirm-modal{max-width:95%;width:95%}.delete-confirm-icon{font-size:40px}.delete-confirm-buttons{flex-direction:column;gap:10px}.delete-confirm-buttons button{width:100%}}@media (max-width: 480px){.users-stats{justify-content:center}.stat-number{font-size:28px}.role-filters{gap:6px}.role-filter-btn{padding:5px 10px;font-size:12px}.user-card{padding:15px}.user-avatar img,.user-avatar .avatar-placeholder{width:60px;height:60px;font-size:24px}}.gifts-inventory{padding:20px}.inventory-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000001a;border:1px solid #e2e8f0;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.stat-icon{font-size:2rem;margin-bottom:12px;display:block}.stat-info h3{margin:0 0 8px;color:#1e293b;font-size:1.1rem;font-weight:600}.stat-info p{margin:0 0 8px;color:#64748b;font-size:1.5rem;font-weight:700}.stat-change{font-size:.85rem;color:#10b981;font-weight:500;background:#dcfce7;padding:4px 8px;border-radius:12px;display:inline-block}.inventory-table h2{margin:0 0 20px;color:#1e293b;font-size:24px;font-weight:600}.table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;border:1px solid #e2e8f0}.inventory-table{width:100%;border-collapse:collapse;font-size:.9rem}.inventory-table th{background:#f8fafc;padding:12px 16px;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0;white-space:nowrap}.inventory-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.inventory-item:hover{background:#f8fafc}.item-image{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:8px}.placeholder-icon{font-size:1.2rem}.quantity{font-weight:600;color:#1e293b;background:#f0f9ff;padding:4px 8px;border-radius:12px;font-size:.85rem}.status{padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:500;white-space:nowrap}.status.in-stock{background:#dcfce7;color:#166534}.status.low-stock,.status.warning-stock{background:#fef3c7;color:#d97706}.status.critical-stock{background:#fee2e2;color:#dc2626}.quantity.quantity-warning{color:#d97706;background:#fef3c7}.quantity.quantity-critical{color:#dc2626;background:#fee2e2}.quantity.quantity-good{color:#16a34a;background:#dcfce7}.action-buttons{display:flex;gap:8px}.action-buttons button{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.edit-btn{background:#3b82f6}.edit-btn:hover{background:#2563eb}.delete-btn{background:#ef4444}.delete-btn:hover{background:#dc2626}.App-main.gifts-padding{padding-top:40px}.gift-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:9999;animation:fadeIn .3s ease-out}.gift-modal-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:16px;padding:40px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;z-index:10000;box-shadow:0 10px 30px #0000004d;animation:slideUp .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-50%) translateY(30px) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) translateY(0) scale(1)}}.guest-register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8e0e2,#f8f9fa);padding:20px;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.guest-register-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001a;max-width:440px;width:100%;overflow:hidden}.guest-register-header{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;text-align:center;padding:32px 24px}.guest-register-header h1{margin:0;font-size:1.8rem;font-weight:700;letter-spacing:-.5px}.guest-register-header p{margin:8px 0 0;font-size:1rem;opacity:.85}.guest-register-form{padding:32px 28px;display:flex;flex-direction:column;gap:20px}.guest-form-group{display:flex;flex-direction:column;gap:6px}.guest-form-group label{font-weight:600;color:#374151;font-size:14px}.guest-form-group input{padding:14px 16px;border:2px solid #e9ecef;border-radius:10px;font-size:16px;font-family:inherit;background:#f8fafc;transition:all .2s ease;box-sizing:border-box}.guest-form-group input:focus{outline:none;border-color:#844a59;background:#fff;box-shadow:0 0 0 3px #844a591a}.guest-error{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;border:1px solid #fecaca}.guest-submit-btn{background:linear-gradient(135deg,#844a59,#6b3c47);color:#fff;border:none;padding:16px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.guest-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #844a594d}.guest-submit-btn:disabled{opacity:.6;cursor:not-allowed}.guest-info-text{text-align:center;color:#6b7280;font-size:13px;margin:0;line-height:1.5}.guest-success{padding:48px 32px;text-align:center}.success-icon{font-size:3rem;margin-bottom:16px}.guest-success h2{margin:0 0 12px;color:#059669;font-size:1.5rem}.guest-success p{color:#374151;font-size:1rem;margin:0 0 12px;line-height:1.5}.success-note{color:#6b7280!important;font-size:.9rem!important;background:#f8fafc;padding:16px;border-radius:10px;border:1px solid #e9ecef}@media (max-width: 480px){.guest-register-card{border-radius:16px}.guest-register-header{padding:24px 20px}.guest-register-header h1{font-size:1.5rem}.guest-register-form{padding:24px 20px}}
