body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--sidebar-width-desktop:220px;--sidebar-width-tablet:200px;--sidebar-width-mobile:100%;--sidebar-collapsed-width:64px;--sidebar-bg-color:#7d203a;--header-height:80px!important;--nav-tabs-height:40px}.app-header{border-bottom:1px solid #ebebeb;height:80px!important;height:var(--header-height,60px)!important;left:220px!important;left:var(--sidebar-width-desktop)!important;position:fixed!important;right:0!important;top:0!important;transition:left .3s ease;z-index:20}body.sidebar-collapsed .app-header{left:64px!important;left:var(--sidebar-collapsed-width)!important}.header-content{height:100%!important;justify-content:space-between!important;padding:5px 20px 0 40px!important;width:100%!important}.header-content,.page-title-wrapper{align-items:flex-start!important;display:flex!important;position:relative!important}.page-title{color:#374151;font-size:1.5rem!important;font-weight:400!important;margin:0!important;max-width:calc(100vw - 300px)!important;overflow:hidden!important;text-align:left!important;text-overflow:ellipsis!important;white-space:nowrap!important}.header-actions{align-items:center!important;display:flex!important;gap:12px!important}.nav-tabs{display:flex;left:224px;margin-left:20px;padding-bottom:10px;padding-top:5px;position:fixed;right:0;top:44px;transition:left .3s ease;z-index:19}body.sidebar-collapsed .nav-tabs{left:64px;left:var(--sidebar-collapsed-width)}.nav-tab{align-items:center;border-bottom:0 solid #0000;color:#64748b;display:flex;font-size:.875rem;font-weight:500;height:100%;padding:0 16px;text-decoration:none}.nav-tab:hover{color:#7d203a}.nav-tab.active{color:#7d203a;font-weight:600}.content-area.with-tabs{margin-top:120px;margin-top:calc(var(--header-height) + var(--nav-tabs-height))}.content-area{margin-left:var(--sidebar-width-desktop);margin-top:40px}body.sidebar-collapsed .content-area{margin-left:64px;margin-left:var(--sidebar-collapsed-width)}@media (max-width:992px){.app-header{left:200px!important;left:var(--sidebar-width-tablet)!important}body.sidebar-collapsed .app-header{left:64px!important;left:var(--sidebar-collapsed-width)!important}.nav-tabs{left:200px;left:var(--sidebar-width-tablet)}body.sidebar-collapsed .nav-tabs{left:64px;left:var(--sidebar-collapsed-width)}.content-area{margin-left:200px;margin-left:var(--sidebar-width-tablet)}body.sidebar-collapsed .content-area{margin-left:64px;margin-left:var(--sidebar-collapsed-width)}}@media (max-width:768px){.app-header,body.sidebar-collapsed .app-header,body.sidebar-expanded .app-header{left:0!important}.nav-tabs{left:0;overflow-x:auto;padding-left:10px}body.sidebar-collapsed .nav-tabs,body.sidebar-expanded .nav-tabs{left:0}.content-area,body.sidebar-collapsed .content-area,body.sidebar-expanded .content-area{margin-left:0}.page-title{font-size:1.125rem!important;max-width:calc(100vw - 150px)!important}.nav-tab{font-size:.75rem;padding:0 12px;white-space:nowrap}.header-content{padding:0 15px!important}}.sidebar{background-color:#7d203a!important;box-shadow:2px 0 5px #0000001a;color:#fff;height:100%;overflow:visible!important;transition:width .3s ease;width:60px;z-index:1000}.sidebar.open{width:220px}.sidebar.mini{width:60px}.sidebar>*{overflow-x:hidden}.sidebar-edge-toggle{align-items:center;background-color:#fff;border:2px solid #7d203a;border-radius:50%;bottom:40px;box-shadow:0 2px 6px #0003;color:#7d203a!important;cursor:pointer;display:flex;height:32px;justify-content:center;left:100%;position:fixed;transform:translateX(-50%);transition:background-color .2s ease,color .2s ease;width:32px;z-index:1001}.sidebar-edge-toggle:hover{background-color:#8f3049;color:#fff!important}.sidebar-edge-toggle svg{fill:currentColor!important;display:block;height:20px;width:20px}.user-meta,.user-name{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.sidebar.mini .user-meta,.sidebar.mini .user-name{opacity:0;pointer-events:none;transform:translateY(-10px)}.user-profile{will-change:transform,opacity}.content-area{flex-grow:1;margin-left:0;padding-left:24px;transition:margin-left .3s ease}.main-content{flex-direction:row;gap:0;height:100%;padding-left:0;padding-right:0;width:100%}.user-profile{align-items:center;background-color:var(--primary-light);border-bottom:1px solid #ffffff1a;color:#fff!important;cursor:pointer;display:flex;flex-direction:column;height:79.5px!important;min-height:64px;overflow:visible;padding:16px;position:relative;text-align:center}.user-profile.mini{justify-content:center;padding:12px}.user-avatar{border:2px solid #ffffff4d;box-shadow:0 2px 4px #0000001a;color:#fff;font-size:16px;font-weight:600;height:48px;margin-bottom:10px;position:relative;width:48px}.user-profile.mini .user-avatar{font-size:14px;height:36px;margin:0;width:36px}.avatar-arrow{align-items:center;background-color:#ffffff1a;border-radius:50%;bottom:-16px;display:flex;height:16px;justify-content:center;left:50%;position:absolute;transform:translateX(-50%);transition:transform .2s ease;width:16px}.avatar-arrow.open{transform:translateX(-50%) rotate(180deg)}.user-name{color:#fff!important;font-size:14px;margin-top:4px}.user-meta{background-color:#ffffff1a;border-radius:4px;color:#fff!important;display:inline-block;font-size:12px;margin-top:2px;opacity:.8;padding:2px 6px}.user-dropdown{background-color:#fff;border-radius:4px;box-shadow:0 2px 10px #00000026;color:#333;display:none;left:8px;max-width:calc(100% - 16px);overflow:hidden;position:absolute;right:8px;top:calc(100% + 4px);z-index:10001!important}.user-dropdown.open{display:block}.dropdown-header{border-bottom:1px solid #eee;font-size:14px;font-weight:600;padding:10px 12px}.user-dropdown-item{align-items:center;cursor:pointer;display:flex;font-size:14px;padding:10px 12px;transition:background-color .2s}.user-dropdown-item:hover{background-color:#f5f5f5}.dropdown-icon{color:#7d203a;height:20px;justify-content:center;margin-right:10px;width:20px}.profile-settings-btn{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;font-family:inherit;text-align:left;width:100%}.logout-item{border-top:1px solid #eee}.branch-selector{border:1px solid #ddd;border-radius:3px;margin-left:auto;padding:4px}.sidebar-item.unavailable .material-icons{color:#adb5bd}.animate-fade-in{animation:fade-in .2s ease-in-out}.sidebar-nav{background-color:#7d203a!important;display:flex;flex:1 1;flex-direction:column;justify-content:space-between;overflow-y:auto}.sidebar-nav ul{list-style:none;margin:0;padding:0}.main-menu{flex:1 1}.bottom-menu{border-top:1px solid #ffffff1a;margin-top:auto}.sidebar-nav li{margin:0;padding:0}.sidebar-nav a{align-items:center;color:#fff;display:flex;font-size:14px;padding:12px 16px;text-decoration:none;transition:background-color .2s;white-space:nowrap}.sidebar-nav a svg{fill:#ffffffb3;transition:all .2s ease}.sidebar-nav a:hover svg{fill:#fff;transform:scale(1.1)}.sidebar-nav a svg{transition:all .3s ease}.sidebar-nav a.active svg{fill:#7d203a;background-color:#fff;border-radius:50px}.sidebar-nav a.icon-only svg{height:24px;width:24px}.sidebar-nav a.icon-only.active svg{transform:scale(1.15)}.menu-icon{align-items:center;color:#fff;display:flex;flex-shrink:0;height:24px;justify-content:center;margin-right:12px;opacity:.9;width:24px}.sidebar.mini .unavailable-tooltip{left:60px;right:auto;transform:translateY(-50%)}.sidebar.mini .menu-icon{margin-right:0}.menu-text{font-size:14px}.help-menu-item{background-color:#00000026}.help-link{font-weight:500}.sidebar-edge-toggle{animation:pulse 1.5s ease-in-out 3}.sidebar-toggle{align-items:center;background-color:#7d203a;border:none;border-radius:4px;box-shadow:0 2px 5px #0003;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;left:12px;position:fixed;top:12px;width:40px;z-index:1010}.sidebar-toggle:hover{background-color:#8f3049}.modal-overlay{z-index:2000!important}.modal{border-radius:6px;box-shadow:0 3px 15px #0003;max-width:500px;width:90%}.modal-header{border-bottom:1px solid #eee;padding:16px 20px}.modal-header h2{font-size:18px}.close-button{color:#999;padding:4px}.close-button:hover{color:#333}.modal-content{padding:20px}.profile-info{align-items:center;display:flex;margin-bottom:24px}.profile-avatar{margin-right:16px}.large-avatar{align-items:center;background-color:#7d203a;border-radius:50%;color:#fff;display:flex;font-size:24px;font-weight:600;height:64px;justify-content:center;width:64px}.profile-details h3{font-size:18px;margin:0 0 4px}.profile-branch,.profile-organization,.profile-role{color:#666;font-size:14px;margin:0 0 4px}.profile-settings-section{margin-bottom:24px}.profile-settings-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 16px}.form-group{margin-bottom:16px}.form-group label{color:#555;display:block;font-size:14px;margin-bottom:6px}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 12px;width:100%}.form-note{color:#888;font-size:12px;font-style:italic;margin-top:4px}.modal-actions{gap:12px;margin-top:20px}.modal-button{border:none;border-radius:4px;font-size:14px;padding:8px 16px}.modal-button.primary:hover:not(:disabled){background-color:#8f3049}.modal-button.secondary{background-color:#f0f0f0;color:#333}.modal-button.secondary:hover{background-color:#e4e4e4}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:240px}.sidebar.open{transform:translateX(0)}.sidebar.mini{transform:translateX(-100%)}.sidebar-edge-toggle{display:none}.sidebar-toggle{background-color:#7d203a!important;z-index:1010}body{padding-left:0!important}}@media (max-width:576px){.sidebar{width:100%}.sidebar.open{transform:translateX(0)}}@media (min-width:769px){.sidebar-edge-toggle{display:flex!important;visibility:visible!important}.sidebar{overflow:visible!important}.content-area{margin-left:220px!important;transition:margin-left .3s ease}body.sidebar-collapsed .content-area{margin-left:60px!important}}@media (max-width:1200px){.sidebar.mini{width:60px}}@media (max-width:992px){.sidebar.open{width:220px}.sidebar.mini{width:50px}}@media (min-width:1281px){.sidebar.open{width:220px}}.sidebar.mini .menu-icon{align-items:center;display:flex;height:24px;justify-content:center;margin:0;width:24px}.sidebar.mini .menu-icon svg{height:24px;width:24px}.sidebar.mini .user-avatar{height:36px;width:36px}.sidebar.mini .sidebar-nav a{justify-content:center;padding:12px}.menu-icon svg{fill:currentColor;height:24px;width:24px}.tooltip-overlay{height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:1001}.tooltip-container{animation:fade-in .2s ease-out;background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:200px;padding:16px;pointer-events:auto;position:absolute;transform:translate(-50%,-50%);z-index:1001}.tooltip-message{color:#000;font-size:.95rem;font-weight:semi-bold;margin-bottom:16px;text-align:center}.tooltip-close{background-color:#7d203a;border:none;border-radius:4px;color:#fff;cursor:pointer;display:block;font-weight:500;margin:0 auto;padding:8px 0;text-align:center;transition:background-color .2s ease;width:50%}.tooltip-close:hover{background-color:#9e3450}@keyframes fade-in{0%{opacity:0;transform:translate(-50%,-60%)}to{opacity:1;transform:translate(-50%,-50%)}}.home-page{--primary-color:#7d203a;--primary-light:#9a3941;--primary-dark:#5c1829;--secondary-color:#f8f9fa;--accent-color:#3a7d20;--text-color:#333;--light-text:#6c757d;--border-color:#dee2e6;--hover-color:#6a1b31;background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:var(--text-color);flex-direction:column;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.home-content,.home-page{display:flex;min-height:100vh}.home-content{align-items:center;flex:1 1;flex-direction:column;justify-content:center;margin:0 auto;max-width:1200px}.welcome-container{align-items:center;display:flex;gap:2rem;width:100%}.welcome-section{background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #00000014;max-width:750px;overflow:hidden;padding:2rem;position:relative;width:100%}.welcome-header{margin-bottom:1.5rem;position:relative;text-align:center}.project-badge{background-color:#7d203a1a;border-radius:30px;color:var(--primary-color);display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.5px;margin-bottom:.8rem;padding:.3rem .8rem}.welcome-section h1{color:var(--text-color);font-size:2.2rem;font-weight:700;margin-bottom:.4rem}.highlight{color:var(--primary-color);display:inline-block;position:relative}.subtitle{color:var(--light-text);font-size:1rem;margin-bottom:1.5rem}.project-description{line-height:1.5;margin-bottom:1.8rem}.description-with-icon{align-items:flex-start;background-color:#f8f9fa;border-left:4px solid var(--primary-color);border-radius:8px;display:flex;gap:1rem;padding:1.2rem}.icon-container{align-items:center;color:var(--primary-color);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.icon-container svg{height:100%;width:100%}.project-description p{font-size:1rem;margin:0}.key-features{margin-bottom:2.5rem;width:100%}.key-features h2{color:var(--text-color);display:inline-block;font-size:1.4rem;left:50%;margin-bottom:1.5rem;padding-bottom:.6rem;position:relative;text-align:center;transform:translateX(-50%)}.key-features h2:after{background-color:var(--primary-color);border-radius:3px;bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.features-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.feature-item{background-color:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 10px #00000008;display:flex;flex-direction:column;height:100%;padding:1.5rem;transition:transform .3s ease,box-shadow .3s ease}.feature-item:hover{box-shadow:0 12px 20px #0000000d;transform:translateY(-5px)}.feature-icon{align-items:center;background-color:#7d203a14;border-radius:10px;color:var(--primary-color);display:flex;height:40px;justify-content:center;margin-bottom:1rem;padding:.6rem;width:40px}.feature-icon svg{height:100%;width:100%}.feature-item h3{color:var(--text-color);font-size:1.15rem;font-weight:600;margin-bottom:.5rem}.feature-item p{color:var(--light-text);font-size:.95rem;line-height:1.5;margin:0}.login-section{text-align:center}.login-button{align-items:center;background-color:var(--primary-color);border:none;border-radius:8px;box-shadow:0 4px 6px #7d203a33;color:#fff;cursor:pointer;display:inline-flex;font-size:1.05rem;font-weight:600;gap:.75rem;padding:.8rem 1.8rem;transition:all .3s ease}.login-button svg{height:18px;transition:transform .3s ease;width:18px}.login-button:hover{background-color:var(--hover-color);box-shadow:0 6px 12px #7d203a40;transform:translateY(-2px)}.login-button:hover svg{transform:translateX(4px)}.login-button:focus{box-shadow:0 0 0 3px #7d203a4d,0 6px 12px #7d203a40;outline:none}.login-note{color:var(--light-text);font-size:.85rem;margin-top:.8rem}.decoration-element{display:none}@media (min-width:992px){.decoration-element{display:block;flex:0 0 250px}.book-stack{height:350px;margin:0 auto;position:relative;width:180px}.book{border-radius:3px 10px 10px 3px;box-shadow:0 10px 20px #0000001a;height:180px;position:absolute;transform:rotate(0deg);transform-origin:bottom left;transition:transform .3s ease}.book-1{background-color:var(--primary-color);bottom:0;height:200px;left:70px;width:35px;z-index:5}.book-2{background-color:#3a7d20;bottom:0;height:180px;left:105px;width:30px;z-index:4}.book-3{background-color:#207d7d;bottom:0;height:220px;left:135px;width:40px;z-index:3}.book-4{background-color:#7d5520;bottom:0;height:160px;left:45px;width:25px;z-index:2}.book-5{background-color:#20347d;bottom:0;height:190px;left:0;width:45px;z-index:1}.book-stack:hover .book-1{transform:rotate(-5deg)}.book-stack:hover .book-2{transform:rotate(3deg)}.book-stack:hover .book-3{transform:rotate(-2deg)}.book-stack:hover .book-4{transform:rotate(4deg)}.book-stack:hover .book-5{transform:rotate(-3deg)}}@media (max-width:991px){.welcome-container{flex-direction:column}}@media (max-width:768px){.home-content,.welcome-section{padding:1.2rem}.welcome-section h1{font-size:1.8rem}.subtitle{font-size:.95rem}.features-grid{gap:1rem;grid-template-columns:1fr}.description-with-icon{align-items:center;flex-direction:column;text-align:center}}@media (max-width:480px){.home-content,.welcome-section{padding:1rem}.welcome-section h1{font-size:1.6rem}.project-badge{font-size:.7rem}.login-button{width:100%}}.welcome-section{animation:fadeIn .6s ease-out forwards}.feature-item:first-child{animation:fadeIn .6s ease-out .1s forwards}.feature-item:nth-child(2){animation:fadeIn .6s ease-out .2s forwards}.feature-item:nth-child(3){animation:fadeIn .6s ease-out .3s forwards}.feature-item:nth-child(4){animation:fadeIn .6s ease-out .4s forwards}.feature-item{opacity:0}:root{--branch-primary:#7d203a;--branch-primary-light:#9e3450;--branch-primary-dark:#5c1829;--branch-primary-transparent:#7d203a1a}.home-dashboard-loading{align-items:center;color:#7d203a;color:var(--branch-primary);display:flex;flex-direction:column;gap:1.5rem;height:100vh;justify-content:center}.loading-spinner{border:4px solid #7d203a1a;border-top-color:#7d203a;border:4px solid var(--branch-primary-transparent);border-top-color:var(--branch-primary);height:3rem;width:3rem}.dashboard-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.branch-switcher{position:relative;z-index:30}.branch-button{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px #0000000d;cursor:pointer;display:flex;gap:.75rem;min-width:280px;padding:.75rem 1rem;transition:all .2s ease}.branch-button:hover{box-shadow:0 4px 6px -1px #0000001a}.branch-button:focus,.branch-button:hover{border-color:#7d203a;border-color:var(--branch-primary)}.branch-button:focus{box-shadow:0 0 0 3px #7d203a1a;box-shadow:0 0 0 3px var(--branch-primary-transparent);outline:none}.branch-icon{align-items:center;background-color:#7d203a1a;background-color:var(--branch-primary-transparent);border-radius:.5rem;color:#7d203a;color:var(--branch-primary);display:flex;flex-shrink:0;font-size:1.5rem;height:2.75rem;justify-content:center;overflow:hidden;width:2.75rem}.branch-logo{font-size:1.5rem;line-height:1}.branch-info{display:flex;flex-direction:column;flex-grow:1;text-align:left}.branch-name{color:#1f2937;font-size:1rem;font-weight:600}.branch-address{color:#6b7280;font-size:.875rem;margin-top:.125rem}.dropdown-icon{color:#6b7280;font-size:1.25rem;margin-left:.25rem}.dropdown-icon.open{color:#7d203a;color:var(--branch-primary)}.branch-menu{animation:fadeIn .2s ease-out;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;left:0;overflow:hidden;position:absolute;top:calc(100% + .5rem);width:100%;z-index:40}.branch-menu-item{align-items:center;background-color:initial;border:none;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:all .2s ease;width:100%}.branch-menu-item:focus,.branch-menu-item:hover{background-color:#f3f4f6}.branch-menu-item:focus{outline:none}.branch-menu-item.active{background-color:#7d203a1a;background-color:var(--branch-primary-transparent)}.branch-menu-icon{align-items:center;background-color:#7d203a1a;background-color:var(--item-bg,var(--branch-primary-transparent));border-radius:.375rem;color:#7d203a;color:var(--item-color,var(--branch-primary));display:flex;flex-shrink:0;font-size:1.25rem;height:2.25rem;justify-content:center;overflow:hidden;width:2.25rem}.branch-menu-logo{font-size:1.25rem;line-height:1}.branch-menu-info{display:flex;flex-direction:column;flex-grow:1}.branch-menu-info span:first-child{color:#1f2937;font-weight:500}.branch-menu-info span:last-child{color:#6b7280;font-size:.75rem;margin-top:.125rem}.active-check{color:#7d203a;color:var(--item-color,var(--branch-primary));font-size:1.25rem}@media (min-width:640px){.search-button-text{display:inline}}.dashboard-content{display:flex;flex-direction:column}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:1024px){.dashboard-grid{grid-template-columns:1fr 1fr}}.dashboard-section,.dashboard-section.popular-section.loaded{box-shadow:0 1px 3px #0000001a}.dashboard-section{background-color:#fff;border-radius:.75rem;opacity:0;padding:1.5rem;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.dashboard-section.loaded{opacity:1;transform:translateY(0)}.section-header{margin-bottom:1.5rem}.section-header h2{align-items:center;color:#1f2937;display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin:0}.section-actions{display:flex;gap:.75rem}.popular-books{display:flex;flex-direction:column;gap:1rem}.popular-book-card{animation:fadeInUp .5s forwards;animation-delay:calc(var(--index)*.1s);background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;gap:1rem;opacity:0;padding:1rem;transform:translateY(20px);transition:all .2s ease}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.popular-book-card:hover{border-color:#9e3450;border-color:var(--branch-primary-light);box-shadow:0 4px 6px -1px #0000001a}.book-rank{align-items:center;background-color:#7d203a;border-radius:.5rem;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:2.5rem;justify-content:center;width:2.5rem}.book-details{flex-grow:1}.book-title{color:#1f2937;font-size:1rem;margin:0 0 .25rem}.book-author{color:#4b5563;font-size:.875rem;margin:0 0 .5rem}.book-loan-count{color:#4b5563;margin-bottom:.5rem}.book-availability,.book-loan-count{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.book-availability{margin-bottom:.75rem}.book-availability.available{color:#10b981}.book-availability.unavailable{color:#6b7280}.availability-icon{font-size:1rem}.book-info{margin-bottom:.75rem}.book-category{align-items:center;background-color:#f3f4f6;border-radius:9999px;color:#4b5563;display:inline-flex;font-size:.75rem;gap:.375rem;padding:.25rem .5rem}.category-icon{font-size:.875rem}.book-admin-actions{display:none}.admin-button{align-items:center;background-color:#f3f4f6;border:none;border-radius:.375rem;color:#4b5563;cursor:pointer;display:flex;font-size:.75rem;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .2s ease}.admin-button:hover{background-color:#e5e7eb;color:#1f2937}.admin-button:focus{box-shadow:0 0 0 2px #7d203a1a;box-shadow:0 0 0 2px var(--branch-primary-transparent);outline:none}.admin-button span{display:none}@media (min-width:640px){.admin-button span{display:inline}}.period-filter{align-items:center;background-color:#f3f4f6;border-radius:.375rem;display:flex;gap:.5rem;padding:.375rem .75rem}.filter-icon{color:#6b7280}.period-select{background:#0000;border:none;color:#4b5563;cursor:pointer;font-size:.875rem;outline:none;padding:.25rem}.period-select:focus{outline:none}.add-event-button{align-items:center;background-color:#7d203a;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;padding:.5rem 1rem;transition:background-color .2s ease}.add-event-button:hover{background-color:#5c1829}.add-event-button:focus{box-shadow:0 0 0 3px #7d203a1a;box-shadow:0 0 0 3px var(--branch-primary-transparent);outline:none}.add-event-button-empty{background-color:#f3f4f6;border:1px solid #7d203a1a;border:1px solid var(--branch-primary-transparent);border-radius:.375rem;color:#7d203a;color:var(--branch-primary);cursor:pointer;font-size:.875rem;font-weight:500;margin-top:1rem;padding:.5rem 1rem;transition:all .2s ease}.add-event-button-empty:hover{background-color:#7d203a1a;background-color:var(--branch-primary-transparent)}.event-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.event-actions{display:flex;flex-shrink:0;gap:.375rem;margin-left:.5rem}.event-action-button{align-items:center;background-color:#f3f4f6;border:none;border-radius:.375rem;color:#4b5563;cursor:pointer;display:flex;font-size:1rem;height:2rem;justify-content:center;transition:all .2s ease;width:2rem}.event-action-button:hover{background-color:#e5e7eb;color:#7d203a;color:var(--branch-primary)}.event-action-button:focus{box-shadow:0 0 0 2px #7d203a1a;box-shadow:0 0 0 2px var(--branch-primary-transparent);outline:none}.events-timeline{padding-top:1rem;position:relative}.timeline-today-marker{background-color:#7d203a;border-radius:.25rem;color:#fff;font-size:.75rem;font-weight:500;left:0;padding:.25rem .5rem;position:absolute;top:0;z-index:1}.events-list{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.event-card{animation:fadeInUp .5s forwards;animation-delay:calc(var(--index)*.1s);background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;gap:1rem;opacity:0;padding:1rem;transform:translateY(20px);transition:all .2s ease}.event-card:hover{border-color:#9e3450;border-color:var(--branch-primary-light);box-shadow:0 4px 6px -1px #0000001a}.event-card.featured{border-left:4px solid #7d203a;border-left:4px solid var(--branch-primary)}.event-date-time{display:flex;flex-direction:column;flex-shrink:0;gap:.5rem;min-width:140px}.event-date,.event-time{align-items:center;color:#4b5563;display:flex;font-size:.875rem;gap:.5rem}.event-details{flex-grow:1}.event-title{align-items:center;color:#1f2937;display:flex;flex:1 1;flex-wrap:wrap;font-size:1rem;font-weight:600;gap:.5rem;margin-right:.5rem}.event-tag{border-radius:.25rem;font-size:.625rem;font-weight:500;padding:.125rem .375rem;text-transform:uppercase}.event-tag.new{background-color:#7d203a1a;background-color:var(--branch-primary-transparent);color:#7d203a;color:var(--branch-primary)}.event-tag.featured{background-color:#4f46e51a;color:#4f46e5}.event-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#4b5563;display:-webkit-box;font-size:.875rem;margin:0 0 .75rem;overflow:hidden;text-overflow:ellipsis}.event-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.75rem}.event-location{color:#4b5563;font-size:.875rem}.event-attendance,.event-location{align-items:center;display:flex;gap:.5rem}.attendance-text{align-items:center;color:#4b5563;display:flex;gap:.375rem}.attendance-text,.mini-icon{font-size:.875rem}.empty-events{background-color:#f9fafb;border:1px dashed #d1d5db;border-radius:.5rem;padding:2rem;text-align:center}.empty-events p{color:#6b7280;margin-bottom:1rem}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;overflow-y:auto;padding:1rem;z-index:50}.modal{animation:modalFadeIn .3s ease-out;background-color:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.modal-header h2{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.close-button{background-color:#f3f4f6;border-radius:9999px;color:#4b5563;height:2rem;width:2rem}.close-button:hover{background-color:#e5e7eb;color:#1f2937}.modal-content{padding:1.5rem}.event-detail-header{margin-bottom:1.5rem}.event-detail-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.event-tags{display:flex;gap:.5rem}.event-detail-info{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:1.5rem}@media (min-width:640px){.event-detail-info{grid-template-columns:1fr 1fr}}.detail-item{display:flex;gap:.75rem}.detail-icon{color:#7d203a;color:var(--branch-primary);font-size:1.25rem;margin-top:.25rem}.detail-item strong{color:#4b5563;display:block;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.detail-item p{color:#1f2937;font-size:1rem;margin:0}.attendance-bar{background-color:#e5e7eb;border-radius:9999px;height:.5rem;margin-top:.5rem;overflow:hidden;width:100%}.attendance-fill{background-color:#7d203a;background-color:var(--branch-primary);border-radius:9999px;height:100%}.event-description-full{margin-bottom:1.5rem}.event-description-full h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 .5rem}.event-description-full p{color:#4b5563;font-size:.9375rem;line-height:1.5;margin:0}.modal-actions{gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.modal-button{align-items:center;border-radius:.375rem;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:all .2s ease}.modal-button.primary{background-color:#7d203a;background-color:var(--branch-primary);border:none;color:#fff}.modal-button.primary:hover{background-color:#5c1829;background-color:var(--branch-primary-dark)}.modal-button.secondary{background-color:#f3f4f6;border:1px solid #e5e7eb;color:#4b5563}.modal-button.secondary:hover{background-color:#e5e7eb;color:#1f2937}.modal-button.danger{background-color:#fee2e2;border:1px solid #fecaca;color:#dc2626}.modal-button.danger:hover{background-color:#fecaca}.event-edit-form{gap:1.25rem}.event-edit-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.375rem}.form-group label{color:#4b5563;font-size:.875rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#1f2937;font-size:.9375rem;padding:.625rem .75rem;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#7d203a;border-color:var(--branch-primary);box-shadow:0 0 0 3px #7d203a1a;box-shadow:0 0 0 3px var(--branch-primary-transparent);outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}@media (min-width:640px){.form-row{grid-template-columns:1fr 1fr}}.checkbox-row{margin-top:.5rem}.checkbox-group{align-items:center;flex-direction:row;gap:.5rem}.checkbox-group input{height:1rem;margin:0;width:1rem}.checkbox-group label{margin:0}.form-hint{color:#6b7280;display:block;font-size:.75rem;margin-top:.25rem}.form-feedback{margin-top:1rem}.error-message{align-items:center;color:#dc2626;display:flex;font-size:.875rem;gap:.375rem;margin:0}.modal-button:disabled{cursor:not-allowed;opacity:.6}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal{animation:modalFadeIn .25s cubic-bezier(.4,0,.2,1);max-height:calc(100vh - 2rem);overflow-y:auto}.add-event-button-empty:focus,.add-event-button:focus,.admin-button:focus,.close-button:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.modal-button:focus{box-shadow:0 0 0 2px #7d203a1a,0 0 0 4px #fffc;box-shadow:0 0 0 2px var(--branch-primary-transparent),0 0 0 4px #fffc;outline:none}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-track{background:#f3f4f6}.modal::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:9999px}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.high-contrast-focus:focus-visible{outline:2px solid #000;outline-offset:2px}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.form-group input.error,.form-group select.error,.form-group textarea.error{background-color:#fef2f2;border-color:#ef4444}.form-group input.success,.form-group select.success,.form-group textarea.success{background-color:#ecfdf5;border-color:#10b981}.tooltip{display:inline-block;position:relative}.tooltip .tooltip-text{background-color:#1f2937;border-radius:6px;bottom:125%;box-shadow:0 10px 15px -3px #0000001a;color:#fff;font-size:.75rem;left:50%;opacity:0;padding:.5rem;position:absolute;text-align:center;transform:translateX(-50%);transition:opacity .3s;visibility:hidden;width:200px;z-index:100}.tooltip .tooltip-text:after{border:5px solid #0000;border-top-color:#1f2937;content:"";left:50%;margin-left:-5px;position:absolute;top:100%}.tooltip:hover .tooltip-text{opacity:1;visibility:visible}.badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:500;justify-content:center;line-height:1.25;padding:.125rem .5rem}.badge-primary{background-color:#7d203a1a;background-color:var(--branch-primary-transparent);color:#7d203a;color:var(--branch-primary)}.badge-success{background-color:#d1fae5;color:#10b981}.badge-warning{background-color:#fef3c7;color:#d97706}.badge-danger{background-color:#fee2e2;color:#ef4444}.progress-bar{background-color:#e5e7eb;border-radius:9999px;height:.5rem;overflow:hidden;width:100%}.progress-bar-fill{border-radius:9999px;height:100%;transition:width .3s ease}.progress-bar-primary .progress-bar-fill{background-color:#7d203a;background-color:var(--branch-primary)}.progress-bar-success .progress-bar-fill{background-color:#10b981}.progress-bar-warning .progress-bar-fill{background-color:#f59e0b}.progress-bar-danger .progress-bar-fill{background-color:#ef4444}.toast{align-items:center;animation:toastSlideIn .3s ease-out forwards;background-color:#fff;border-radius:.5rem;bottom:1.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:flex;gap:.75rem;max-width:350px;padding:1rem;right:1.5rem;z-index:50}@keyframes toastSlideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-success{border-left:4px solid #10b981}.toast-warning{border-left:4px solid #f59e0b}.toast-error{border-left:4px solid #ef4444}.toast-info{border-left:4px solid #3b82f6}.toast-icon{font-size:1.25rem}.toast-content{flex-grow:1}.toast-title{color:#1f2937;font-size:.875rem;font-weight:600;margin:0 0 .25rem}.toast-message{color:#4b5563;font-size:.75rem;margin:0}.toast-close{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:color .2s ease}.toast-close:hover{color:#1f2937}@media (max-width:768px){.modal{margin:1rem;max-height:calc(100vh - 2rem);max-width:none;width:100%}.modal-content,.modal-header{padding:1rem}.form-row{grid-template-columns:1fr}.modal-actions{flex-wrap:wrap}.modal-button{flex:1 0 auto;justify-content:center}.modal-button.danger{flex:0 0 100%;margin-bottom:.5rem}.event-card{flex-direction:column}.event-date-time{flex-direction:row;justify-content:space-between;margin-bottom:.5rem;min-width:auto}.branch-button{min-width:auto;width:100%}.search-container{max-width:none;width:100%}.welcome-banner{padding:1.5rem}.welcome-content h1{font-size:1.25rem}.welcome-content p{font-size:1rem}.section-header{align-items:flex-start;flex-direction:column}.event-header{flex-wrap:wrap}.event-actions{margin-left:0;margin-top:.5rem}}@media print{.home-dashboard-container{height:auto;overflow:visible}.add-event-button,.admin-button,.dashboard-controls,.period-filter{display:none!important}.dashboard-section{border:1px solid #e5e7eb;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.dashboard-grid{grid-template-columns:1fr}.event-card,.popular-book-card{border:1px solid #e5e7eb;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.welcome-banner{background-image:none;border-left:4px solid #000}body{background-color:#fff;color:#000}}@media (prefers-color-scheme:dark){.dark-mode-enabled{--color-bg-primary:#111827;--color-bg-secondary:#1f2937;--color-text-primary:#f9fafb;--color-text-secondary:#e5e7eb;--color-border:#374151;background-color:var(--color-bg-primary);color:var(--color-text-primary)}.dark-mode-enabled .branch-button,.dark-mode-enabled .branch-menu,.dark-mode-enabled .dashboard-section,.dark-mode-enabled .event-card,.dark-mode-enabled .modal,.dark-mode-enabled .popular-book-card,.dark-mode-enabled .search-container,.dark-mode-enabled .welcome-banner{background-color:var(--color-bg-secondary);border-color:var(--color-border)}.dark-mode-enabled .book-title,.dark-mode-enabled .branch-name,.dark-mode-enabled .event-title,.dark-mode-enabled .modal-header h2,.dark-mode-enabled .section-header h2,.dark-mode-enabled .welcome-content h1{color:var(--color-text-primary)}.dark-mode-enabled .book-author,.dark-mode-enabled .branch-address,.dark-mode-enabled .event-description,.dark-mode-enabled .welcome-content p{color:var(--color-text-secondary)}.dark-mode-enabled .form-group input,.dark-mode-enabled .form-group select,.dark-mode-enabled .form-group textarea{background-color:var(--color-bg-primary);border-color:var(--color-border);color:var(--color-text-primary)}}.modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-container{background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #0006;max-height:85vh;max-width:900px;overflow-y:auto;position:relative;width:90%}.modal-content{padding:0}.modal-content .page-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin:0;padding:20px 30px 15px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.modal-content .page-header h1{color:#1f2937;font-size:1.5rem;margin:0}.modal-actions{gap:10px}.expand-button,.modal-actions{align-items:center;display:flex}.expand-button{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;height:32px;justify-content:center;transition:all .2s ease;width:32px}.expand-button:hover{background:#e5e7eb;color:#374151}.close-button{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.close-button:hover{background:#f3f4f6;color:#374151}.modal-content .borrower-info-card,.modal-content .message-container,.modal-content .tab-navigation,.modal-content .table-responsive{margin:0 30px 25px;margin-top:10px!important;max-width:100%!important}.modal-content .borrower-info-card:first-of-type{margin-top:20px}.borrowers-list-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.borrower-list-item{align-items:center;border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;padding:16px 20px;transition:background-color .2s ease}.borrower-list-item:hover{background-color:#f9fafb}.borrower-list-item:last-child{border-bottom:none}.borrower-list-id{color:#374151;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;font-weight:600;min-width:120px}.borrower-list-name{color:#1f2937;font-weight:500;margin-right:16px;min-width:200px}.borrower-list-email{color:#6b7280;font-size:.9rem}@media (max-width:768px){.modal-container{margin:10px;max-height:90vh;width:95%}.modal-content .page-header{padding:15px 20px 10px}.modal-content .page-header h1{font-size:1.25rem}.modal-content .borrower-info-card,.modal-content .message-container,.modal-content .tab-navigation,.modal-content .table-responsive{margin:0 20px 20px}.borrower-list-item{align-items:flex-start;flex-direction:column;gap:4px}.borrower-list-id,.borrower-list-name{min-width:auto}}.modal-overlay{animation:fadeIn .2s ease-out}.modal-container{animation:slideIn .3s ease-out}.modal-container::-webkit-scrollbar{width:6px}.modal-container::-webkit-scrollbar-track{background:#f1f5f9}.modal-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.modal-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.modal-content .loading-indicator{padding:60px 20px;text-align:center}.modal-content .table-responsive{max-height:400px;overflow-y:auto}.modal-content .tab-navigation{border-bottom:1px solid #e5e7eb;margin-bottom:20px;padding-bottom:0}.modal-content .borrower-info-card{box-shadow:0 1px 3px 0 #0000001a}.modal-content .message-container{max-height:400px;overflow-y:auto}.modal-container:focus{outline:none}.borrower-list-item:hover .borrower-list-id{color:#1f2937}.borrower-list-item:hover .borrower-list-name{color:#111827}.borrower-list-item:active{transform:translateY(1px)}.borrowers-list h2{color:#374151;font-size:1.125rem;font-weight:600;margin-bottom:16px}.no-results,.search-help{color:#6b7280;padding:60px 20px;text-align:center}.no-results p,.search-help p{font-size:1rem;margin:0}.loading-indicator{color:#6b7280;padding:40px}.spinner{border:3px solid #f3f4f6;border-top-color:#3b82f6;height:32px;margin-bottom:12px;width:32px}.search-container-borrower{margin-bottom:32px}.search-input-borrowers{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;max-width:500px;padding:12px 16px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.search-input-borrowers:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.borrowers-search{margin:0 auto;padding:20px}.page-header{margin-bottom:32px}.page-header h1{color:#374151!important;font-weight:700;margin:0}.borrowers-results{min-height:200px}.borrower-dashboard-wrapper{margin:0 auto;max-width:75rem}.loading-indicator{align-items:center;display:flex;flex-direction:column;gap:1.5rem;justify-content:center;min-height:20rem}.spinner{animation:spin 1s linear infinite;border:2px solid #e5e5e5;border-radius:50%;border-top-color:#5a1728;height:2rem;width:2rem}.loading-indicator p{color:#666;font-size:.875rem}.page-header{margin-bottom:3rem}.page-header h1{color:#1a1a1a;font-size:2rem;font-weight:600;letter-spacing:-.025em}.borrower-info-card,.email-message,.favorite-author-card,.favorite-genres-card,.table-responsive{background:#fff;border:1px solid #e5e5e5;border-radius:.75rem;margin-bottom:2rem;max-width:90%!important}.borrower-info-card:hover,.email-message:hover,.favorite-author-card:hover,.favorite-genres-card:hover{border-color:#d1d5db;transition:border-color .2s ease}.borrower-info-header,.favorite-author-header,.favorite-genres-header{border-bottom:1px solid #f3f4f6;padding:1.5rem 2rem 1rem}.borrower-info-header h2,.favorite-author-header h2,.favorite-genres-header h2{align-items:center;color:#1a1a1a;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem}.borrower-info-header h2:before{content:"👤"}.favorite-author-header h2:before{content:"✍️"}.favorite-genres-header h2:before{content:"📚"}.borrower-info-content,.favorite-author-content,.favorite-genres-content{padding:1rem 2rem 2rem}.borrower-info-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(20rem,1fr))}.info-item{background:#fafafa;border-radius:.5rem;display:flex;flex-direction:column;gap:.25rem;padding:1rem;transition:background-color .2s ease}.info-item:hover{background:#f3f4f6}.info-label{color:#666;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.info-value{color:#1a1a1a;font-weight:500}.library-badge,.membership-badge{align-items:center;border-radius:9999px;color:#fff;display:inline-flex;font-size:.75rem;font-weight:600}.library-badge,.membership-badge{color:green;font-size:16px;font-weight:600}.authors-list,.genres-list{display:flex;flex-wrap:wrap;gap:.75rem}.author-info,.genre-info{background:#f3f4f6;border:1px solid #e5e5e5;border-radius:9999px;color:#374151;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.author-info:hover,.genre-info:hover{background:#5a1728;border-color:#5a1728;color:#fff}.search-container-borrowers{margin-bottom:3rem;margin-left:0;margin-right:auto;max-width:72rem}.search-form-borrowers{background:#fff;border:1px solid #e5e5e5;border-radius:1rem;box-shadow:0 2px 8px #0000000a;margin-bottom:2rem;padding:2rem}.search-grid-borrower{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.search-field-borrower{display:flex;flex-direction:column;gap:.5rem}.search-field label{color:#374151;font-size:.875rem;font-weight:500}.search-input-borrower,.search-select{background:#fff;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;min-width:500px;padding:.875rem 1rem;transition:all .2s ease}.search-input-borrower:focus,.search-select:focus{border-color:#5a1728;box-shadow:0 0 0 3px #2563eb1a;outline:none}.search-input::placeholder{color:#9ca3af}.search-actions{align-items:center;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;padding-top:1.5rem}.search-buttons{display:flex;gap:1rem}.clear-button,.search-button{border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.search-button{background:#5a1728;color:#fff}.search-button:hover{background:#5a1728;transform:translateY(-1px)}.clear-button{background:#f3f4f6;border:1px solid #d1d5db;color:#6b7280}.clear-button:hover{background:#e5e7eb;color:#374151}.create-borrower-button{align-items:center;background:#10b981;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.create-borrower-button:hover{background:#059669;transform:translateY(-1px)}.create-borrower-button:before{content:"+";font-size:1.125rem}.borrowers-results h2{color:#1a1a1a;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.borrowers-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr))}.borrower-card{background:#fff;border:1px solid #e5e5e5;border-radius:.75rem;color:inherit;padding:1.5rem;position:relative;text-decoration:none;transition:all .2s ease}.borrower-card:before{background:#5a1728;border-radius:.75rem 0 0 .75rem;content:"";height:100%;left:0;position:absolute;top:0;transform:scaleY(0);transform-origin:top;transition:transform .2s ease;width:3px}.borrower-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0000000d;transform:translateY(-2px)}.borrower-card:hover:before{transform:scaleY(1)}.borrower-id{color:#5a1728;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.borrower-name{color:#4b5563;font-weight:500}.tab-navigation{background:#f8f9fa;border-radius:.75rem;display:flex;gap:.25rem;margin-bottom:2rem;max-width:200px;padding:.25rem}.tab-navigation button{background:#0000;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;flex:1 1;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.tab-navigation button:hover{background:#e5e7eb;color:#374151}.tab-navigation button.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#5a1728;font-weight:600}.reservations-table{border-collapse:collapse;width:100%}.reservations-table thead{background:#f8f9fa}.reservations-table th{border-bottom:1px solid #e5e5e5;color:#374151;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:1rem 1.5rem;text-align:left;text-transform:uppercase}.reservations-table td{border-bottom:1px solid #f3f4f6;color:#4b5563;padding:1rem 1.5rem}.reservations-table tbody tr:last-child td{border-bottom:none}.reservations-table tbody tr:hover{background:#fafafa}.status-hentet,.status-utløpt,.status-venter{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.025em;padding:.25rem .75rem;text-transform:uppercase}.status-venter{background:#fef3c7;color:#92400e}.status-hentet{background:#d1fae5;color:#065f46}.status-utløpt{background:#fee2e2;color:#991b1b}.message-container{grid-gap:1.25rem;display:grid;gap:1.25rem}.email-header{align-items:flex-start;background:#f8f9fa;border-bottom:1px solid #e5e5e5;display:flex;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.email-meta{display:flex;flex-direction:column;gap:.25rem}.email-date{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.025em;text-transform:uppercase}.email-subject{color:#1a1a1a;font-size:1.125rem;font-weight:600}.message-delivery-info{align-items:center;background:#dbeafe;border-radius:9999px;color:#1e40af;display:inline-flex;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.email-body{color:#374151;line-height:1.6;padding:2rem}.no-data-message,.no-results,.search-help{color:#6b7280;padding:4rem 2rem;text-align:center}.no-data-message p,.no-results p,.search-help p{font-size:1.125rem}.navigation-link{margin-top:3rem;text-align:center}.navigation-link a{align-items:center;background:#f3f4f6;border:1px solid #e5e5e5;border-radius:.5rem;color:#374151;display:inline-flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.navigation-link a:hover{background:#5a1728;border-color:#5a1728;color:#fff;transform:translateY(-1px)}@media (max-width:768px){.borrower-info-content{gap:1rem}.borrower-info-content,.borrowers-grid{grid-template-columns:1fr}.email-header,.tab-navigation{flex-direction:column}.email-header{align-items:flex-start}.reservations-table td,.reservations-table th{padding:.75rem 1rem}.page-header h1{font-size:1.5rem}.borrower-info-header,.favorite-author-header,.favorite-genres-header{padding:1rem 1.5rem .75rem}.borrower-info-content,.favorite-author-content,.favorite-genres-content{padding:.75rem 1.5rem 1.5rem}.email-body,.email-header{padding:1rem 1.5rem}}@media (max-width:480px){.page-header,.search-container-borrower{margin-bottom:2rem}.search-form{padding:1.5rem}.search-grid{gap:1rem;grid-template-columns:1fr}.search-actions{align-items:stretch;flex-direction:column;gap:1rem}.search-buttons{flex-wrap:wrap}.create-borrower-button,.search-buttons{justify-content:center}.reservations-table{font-size:.875rem}}:root{--primary-light:#9e3651;--primary-dark:#5c1728;--primary-transparent:#7d203a1a;--primary-very-light:#7d203a0d;--secondary:#3a5a78;--secondary-light:#4e7190;--secondary-dark:#2a4258;--success:#2e7d32;--success-light:#4caf50;--warning:#ed6c02;--warning-light:#ff9800;--error:#d32f2f;--error-light:#ef5350;--info:#0288d1;--info-light:#03a9f4;--text-dark:#1a2027;--text-medium:#424750;--text-light:#6e7276;--text-very-light:#9ea1a6;--background:#fff;--background-light:#f8f9fa;--background-medium:#f0f2f5;--background-dark:#e3e5e8;--border-light:#e0e0e0;--border-medium:#d0d0d0;--border-dark:#b0b0b0;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 4px 6px #00000012,0 1px 3px #00000014;--shadow-lg:0 10px 15px #0000000f,0 4px 6px #0000000d;--border-radius-sm:4px;--border-radius-md:8px;--border-radius-lg:12px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--transition-standard:all 0.2s ease-in-out;--status-waiting:#ff9800;--status-expired:#d32f2f;--status-picked-up:#2e7d32}h1,h2,h3,h4,h5,h6{color:#1a2027;color:var(--text-dark);font-weight:600;margin-top:0}button{border:none;cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-family);font-size:14px;transition:all .2s ease-in-out;transition:var(--transition-standard)}.btn-primary{align-items:center;background-color:#7d203a;background-color:var(--primary);border-radius:8px;border-radius:var(--border-radius-md);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);color:#fff;display:inline-flex;font-weight:500;gap:8px;justify-content:center;padding:10px 16px}.content-area{margin-top:var(--header-height)!important!}.btn-primary:focus,.btn-primary:hover{background-color:#9e3651;background-color:var(--primary-light);box-shadow:0 4px 6px #00000012,0 1px 3px #00000014;box-shadow:var(--shadow-md)}.btn-primary:active{background-color:#5c1728;background-color:var(--primary-dark)}.btn-primary:disabled{background-color:#d0d0d0;background-color:var(--border-medium);box-shadow:none;color:#6e7276;color:var(--text-light);cursor:not-allowed}.btn-secondary{align-items:center;background-color:#fff;border:1px solid #d0d0d0;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--border-radius-md);color:#1a2027;color:var(--text-dark);display:inline-flex;font-weight:500;gap:8px;justify-content:center;padding:9px 16px}.btn-secondary:focus,.btn-secondary:hover{background-color:#f0f2f5;background-color:var(--background-medium);border-color:#b0b0b0;border-color:var(--border-dark)}.btn-secondary:active{background-color:#e3e5e8;background-color:var(--background-dark)}.btn-secondary:disabled{background-color:#f8f9fa;background-color:var(--background-light);border-color:#e0e0e0;border-color:var(--border-light);color:#9ea1a6;color:var(--text-very-light);cursor:not-allowed}.btn-text{background:#0000;border-radius:4px;border-radius:var(--border-radius-sm);color:#7d203a;color:var(--primary);font-weight:500;padding:8px 12px}.btn-text:focus,.btn-text:hover{background-color:#7d203a0d;background-color:var(--primary-very-light)}.btn-text:active{background-color:#7d203a1a;background-color:var(--primary-transparent)}.btn-export{background-color:#fff;border:1px solid #d0d0d0;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--border-radius-md);color:#424750;color:var(--text-medium);display:inline-flex;font-size:13px;gap:6px;padding:8px 14px}.btn-export:hover{color:#1a2027;color:var(--text-dark)}.btn-export:hover,.btn-reset-filters{background-color:#f0f2f5;background-color:var(--background-medium)}.btn-reset-filters{border-radius:8px;border-radius:var(--border-radius-md);color:#424750;color:var(--text-medium);font-size:14px;margin-top:16px;padding:8px 16px}.btn-reset-filters:hover{background-color:#e3e5e8;background-color:var(--background-dark);color:#1a2027;color:var(--text-dark)}button .icon{font-size:18px}.loading-container{align-items:center;display:flex;flex-direction:column;height:400px;justify-content:center;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f0f2f5;border-top:3px solid #7d203a;border:3px solid var(--background-medium);border-radius:50%;border-top-color:var(--primary);height:40px;margin-bottom:16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.toast{animation:slideIn .3s forwards;border-radius:8px;border-radius:var(--border-radius-md);box-shadow:0 10px 15px #0000000f,0 4px 6px #0000000d;box-shadow:var(--shadow-lg);max-width:450px;min-width:300px;position:fixed;right:20px;top:20px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-content{align-items:center;display:flex;gap:12px;padding:14px 16px}.toast-icon{flex-shrink:0;font-size:20px}.toast-content p{font-size:14px;line-height:1.5;margin:0}.toast-success{background-color:#e8f5e9;border-left:4px solid #2e7d32;border-left:4px solid var(--success)}.toast-success .toast-icon{color:#2e7d32;color:var(--success)}.toast-error{background-color:#fdecea;border-left:4px solid #d32f2f;border-left:4px solid var(--error)}.toast-error .toast-icon{color:#d32f2f;color:var(--error)}.toast-info{background-color:#e3f2fd;border-left:4px solid #0288d1;border-left:4px solid var(--info)}.toast-info .toast-icon{color:#0288d1;color:var(--info)}.stats-section{margin-bottom:24px}.stats-dashboard{background-color:#fff;border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:24px}.stats-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.stats-header h2{font-size:20px;margin:0}.stats-period{align-items:center;display:flex;gap:8px}.period-label{color:#6e7276;color:var(--text-light);font-size:14px}.period-selector{background-color:#f8f9fa;background-color:var(--background-light);border-radius:8px;border-radius:var(--border-radius-md);font-size:14px;gap:6px;padding:6px 12px}.period-selector:hover{background-color:#f0f2f5;background-color:var(--background-medium)}.selected-period{font-weight:500}.period-icon{color:#6e7276;color:var(--text-light)}.stats-metrics{display:flex;gap:24px}.metric-card{background-color:#f8f9fa;background-color:var(--background-light);border-radius:8px;border-radius:var(--border-radius-md);flex:1 1;padding:20px;position:relative}.metric-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.metric-header h3{color:#424750;color:var(--text-medium);font-size:15px;font-weight:500;margin:0}.info-button{background:#0000;border-radius:50%;color:#6e7276;color:var(--text-light);font-size:16px;padding:4px}.info-button:hover{background-color:#f0f2f5;background-color:var(--background-medium);color:#1a2027;color:var(--text-dark)}.metric-value-container{align-items:center;display:flex;gap:14px;margin-bottom:14px}.metric-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;height:42px;justify-content:center;width:42px}.time-icon{background-color:#3a5a781a;color:#3a5a78;color:var(--secondary)}.pickup-icon{background-color:#d32f2f1a;color:#d32f2f;color:var(--error)}.active-icon{background-color:#2e7d321a;color:#2e7d32;color:var(--success)}.metric-details{align-items:baseline;display:flex;gap:4px}.metric-value{font-size:28px;font-weight:600;margin:0}.metric-unit{color:#6e7276;color:var(--text-light);font-size:14px;margin:0}.metric-trend{align-items:center;display:flex;font-size:13px;gap:6px}.trend-icon{font-size:14px}.trend-value{font-weight:500}.trend-period{color:#6e7276;color:var(--text-light)}.metric-trend.positive{color:#2e7d32;color:var(--success)}.metric-trend.negative{color:#d32f2f;color:var(--error)}.metric-trend.neutral{color:#0288d1;color:var(--info)}.metric-explanation{background-color:#fff;border-radius:8px;border-radius:var(--border-radius-md);box-shadow:0 10px 15px #0000000f,0 4px 6px #0000000d;box-shadow:var(--shadow-lg);font-size:14px;left:0;margin-top:8px;max-width:100%;padding:16px;position:absolute;right:0;top:100%;z-index:10}.explanation-header{margin-bottom:10px}.explanation-header h4{font-size:14px}.close-explanation{background:#0000;color:#6e7276;color:var(--text-light);font-size:16px;padding:4px}.close-explanation:hover{color:#1a2027;color:var(--text-dark)}.metric-explanation p{line-height:1.5;margin:0 0 8px}.metric-explanation ul{margin:0;padding-left:20px}.metric-explanation li{line-height:1.5;margin-bottom:4px}.reservations-section{margin-bottom:24px}.view-controls{display:flex;gap:4px}.view-btn{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--border-radius-md);color:#6e7276;color:var(--text-light);display:flex;font-size:18px;justify-content:center;padding:8px}.view-btn:hover{background-color:#f0f2f5;background-color:var(--background-medium);color:#424750;color:var(--text-medium)}.view-btn.active{background-color:#7d203a0d;background-color:var(--primary-very-light);color:#7d203a;color:var(--primary)}.filter-bar{display:flex;gap:16px;margin-bottom:16px}.search-wrapper{flex:1 1;position:relative}.search-icon{color:#6e7276;color:var(--text-light);font-size:16px;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background-color:#fff;border:1px solid #d0d0d0;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--border-radius-md);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-family);font-size:14px;padding:9px 36px;width:100%}.search-input:focus{border-color:#9e3651;border-color:var(--primary-light);box-shadow:0 0 0 2px #7d203a1a;box-shadow:0 0 0 2px var(--primary-transparent);outline:none}.clear-search{align-items:center;background:#0000;border:none;color:#6e7276;color:var(--text-light);cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:4px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.clear-search:hover{color:#1a2027;color:var(--text-dark)}.filter-dropdown{position:relative}.filter-select{-webkit-appearance:none;appearance:none;background-color:#fff;border:1px solid #d0d0d0;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--border-radius-md);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-family);font-size:14px;padding:9px 36px 9px 12px}.filter-select:focus{border-color:#9e3651;border-color:var(--primary-light);box-shadow:0 0 0 2px #7d203a1a;box-shadow:0 0 0 2px var(--primary-transparent);outline:none}.filter-icon{color:#6e7276;color:var(--text-light);pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.column-manager-dropdown{position:relative}.column-manager-toggle{align-items:center;background-color:#fff;border:1px solid #d0d0d0;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--border-radius-md);color:#424750;color:var(--text-medium);display:flex;font-size:14px;gap:6px;padding:9px 12px}.column-manager-toggle:hover{background-color:#f8f9fa;background-color:var(--background-light)}.dropdown-icon{align-items:center;display:flex;margin-left:4px}.column-options{background-color:#fff;border-radius:8px;border-radius:var(--border-radius-md);box-shadow:0 10px 15px #0000000f,0 4px 6px #0000000d;box-shadow:var(--shadow-lg);margin-top:4px;min-width:180px;padding:8px;position:absolute;right:0;top:100%;z-index:10}.column-option{align-items:center;border-radius:4px;border-radius:var(--border-radius-sm);cursor:pointer;display:flex;font-size:14px;gap:8px;padding:6px 8px}.column-option:hover{background-color:#f8f9fa;background-color:var(--background-light)}.column-option input{margin:0}.data-table-container{background-color:#fff;border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);overflow:auto}.data-table{border-collapse:collapse;font-size:14px;width:100%}.data-table th{background-color:#f8f9fa;background-color:var(--background-light);border-bottom:1px solid #d0d0d0;border-bottom:1px solid var(--border-medium);color:#424750;color:var(--text-medium);font-weight:600;padding:14px 16px;text-align:left;white-space:nowrap}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background-color:#f0f2f5;background-color:var(--background-medium)}.sort-indicator{color:#7d203a;color:var(--primary);display:inline-flex;margin-left:4px}.data-table td{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-light);padding:12px 16px;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background-color:#f8f9fa;background-color:var(--background-light)}.title-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.borrower-link{align-items:center;background:#0000;border:none;border-radius:4px;border-radius:var(--border-radius-sm);color:#7d203a;color:var(--primary);cursor:pointer;display:inline-flex;font-size:14px;gap:6px;padding:4px 8px}.borrower-link:hover{background-color:#7d203a0d;background-color:var(--primary-very-light);text-decoration:underline}.borrower-icon{color:#6e7276;color:var(--text-light)}.date-cell{align-items:center;display:flex;gap:6px}.date-icon{color:#6e7276;color:var(--text-light)}.date-icon.success{color:#2e7d32;color:var(--success)}.expired-date{color:#d32f2f;color:var(--error)}.empty-cell{color:#9ea1a6;color:var(--text-very-light)}.status-badge{border-radius:4px;border-radius:var(--border-radius-sm);display:inline-block;font-size:12px;font-weight:500;padding:4px 8px;text-transform:uppercase}.status-venter{background-color:#ff98001a;color:#ed6c02;color:var(--warning)}.status-hentet{background-color:#2e7d321a;color:#2e7d32;color:var(--success)}.status-utløpt{background-color:#d32f2f1a;color:#d32f2f;color:var(--error)}.days-cell,.days-value{text-align:center}.days-value{background-color:#f8f9fa;background-color:var(--background-light);border-radius:4px;border-radius:var(--border-radius-sm);display:inline-block;font-weight:500;min-width:24px;padding:2px 6px}.pickup-number{font-family:Courier New,monospace;font-weight:600;letter-spacing:.5px}.card-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.reservation-card{background-color:#fff;border-radius:12px;border-radius:var(--border-radius-lg);border-top:4px solid #0000;box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;transition:all .2s ease-in-out;transition:var(--transition-standard)}.reservation-card:hover{box-shadow:0 4px 6px #00000012,0 1px 3px #00000014;box-shadow:var(--shadow-md);transform:translateY(-2px)}.status-venter-card{border-top-color:#ff9800;border-top-color:var(--status-waiting)}.status-hentet-card{border-top-color:#2e7d32;border-top-color:var(--status-picked-up)}.status-utløpt-card{border-top-color:#d32f2f;border-top-color:var(--status-expired)}.card-header{background-color:#f8f9fa;background-color:var(--background-light);display:flex;justify-content:space-between;padding:12px 16px}.card-pickup-number{align-items:flex-end;display:flex;flex-direction:column}.pickup-label{color:#6e7276;color:var(--text-light);font-size:12px;margin-bottom:2px}.card-content{flex:1 1;padding:16px}.book-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:16px;font-weight:600;line-height:1.3;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis}.book-author{color:#424750;color:var(--text-medium);font-size:14px;margin:0 0 16px}.card-details{display:flex;flex-direction:column;gap:10px}.detail-row{font-size:14px;justify-content:space-between}.detail-label,.detail-row{align-items:center;display:flex}.detail-label{gap:6px}.detail-icon,.detail-label{color:#6e7276;color:var(--text-light)}.card-footer{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-light);padding:12px 16px}.card-metadata{display:flex;flex-wrap:wrap;gap:12px}.metadata-item{color:#6e7276;color:var(--text-light);font-size:12px}.no-results{background-color:#fff;border-radius:12px;border-radius:var(--border-radius-lg);padding:40px;text-align:center}.no-results-icon{color:#6e7276;color:var(--text-light);font-size:48px;margin-bottom:16px}.no-results h3{font-size:18px;margin:0 0 8px}.no-results p{color:#6e7276;color:var(--text-light);margin:0 0 16px}.settings-page{background-color:#fff;border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);padding:24px}.settings-container{margin:0 auto;max-width:800px}.settings-section{margin-bottom:40px}.settings-header{margin-bottom:24px}.settings-header h2{font-size:20px;margin:0 0 8px}.settings-description{color:#6e7276;color:var(--text-light);font-size:14px;margin:0}.settings-content{display:flex;gap:24px;margin-bottom:24px}.setting-card{background-color:#f8f9fa;background-color:var(--background-light);border-radius:8px;border-radius:var(--border-radius-md);flex:1 1;padding:20px}.setting-card-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.setting-icon{align-items:center;background-color:#7d203a0d;background-color:var(--primary-very-light);border-radius:50%;color:#7d203a;color:var(--primary);display:flex;font-size:20px;height:40px;justify-content:center;width:40px}.setting-card-header h3{font-size:16px;font-weight:600;margin:0}.setting-card-content{margin-bottom:16px}.setting-card-content p{color:#424750;color:var(--text-medium);font-size:14px;line-height:1.5;margin:0 0 16px}.setting-input-group{margin-bottom:12px}.number-input-group{align-items:center;display:flex;gap:8px}.setting-value input[type=number]{border:1px solid #d0d0d0;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--border-radius-md);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-family);font-size:14px;padding:8px 12px;text-align:center;width:80px}.setting-value input[type=number]:focus{border-color:#7d203a;border-color:var(--primary);box-shadow:0 0 0 2px #7d203a1a;box-shadow:0 0 0 2px var(--primary-transparent);outline:none}.input-suffix{color:#424750;color:var(--text-medium);font-size:14px}.setting-card-footer{color:#6e7276;color:var(--text-light);font-size:13px}.setting-info{line-height:1.5;margin:0}.settings-actions{display:flex;gap:12px;justify-content:flex-end}.auto-reminder-info{background-color:#f8f9fa;background-color:var(--background-light);border-radius:8px;border-radius:var(--border-radius-md);padding:20px}.info-card{display:flex;gap:16px}.info-icon{align-items:center;background-color:#7d203a0d;background-color:var(--primary-very-light);border-radius:50%;color:#7d203a;color:var(--primary);display:flex;flex-shrink:0;font-size:24px;height:48px;justify-content:center;width:48px}.info-content h3{font-size:16px;font-weight:600;margin:0 0 12px}.info-content p{color:#424750;color:var(--text-medium);font-size:14px;line-height:1.5;margin:0 0 12px}.info-content p:last-child{margin-bottom:0}.status-venter-row{background-color:#ff980008}.status-hentet-row{background-color:#2e7d3208}.status-utløpt-row{background-color:#d32f2f08}@media (max-width:1200px){.stats-metrics{flex-direction:column;gap:16px}.filter-bar{flex-wrap:wrap}.search-wrapper{flex:1 1 100%;order:1}.column-manager-dropdown,.filter-dropdown{flex:1 1;order:2}.title-cell{max-width:200px}}@media (max-width:992px){.settings-content{flex-direction:column;gap:16px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width:768px){.chart-header,.section-header{align-items:flex-start;flex-direction:column;gap:12px}.card-grid{grid-template-columns:1fr}.stats-header{align-items:flex-start;gap:12px}.settings-actions,.stats-header{flex-direction:column}.settings-actions button{width:100%}.chart-container{padding:16px}}@media print{.btn-export,.chart-tabs,.filter-bar,.section-header,.toggle-container,.view-controls{display:none}.data-table{font-size:12px}.data-table td,.data-table th{padding:8px}.status-badge{font-size:10px;padding:2px 4px}.borrower-link{color:#1a2027;color:var(--text-dark);text-decoration:none}.chart-container,.metric-card{border:1px solid #e0e0e0;border:1px solid var(--border-light);box-shadow:none}.card-grid{display:block}.reservation-card{border:1px solid #e0e0e0;border:1px solid var(--border-light);box-shadow:none;margin-bottom:16px;page-break-inside:avoid}.borrower-icon,.date-icon,.detail-icon,.metric-trend{display:none}}.card-grid,.chart-container,.data-table-container,.stats-dashboard{animation:fadeIn .3s ease-in-out}button:focus,input:focus,select:focus{box-shadow:0 0 0 2px #7d203a1a;box-shadow:0 0 0 2px var(--primary-transparent);outline:none}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid #7d203a;outline:2px solid var(--primary);outline-offset:2px}.print-export-menu{position:relative}.print-options{border-radius:8px;border-radius:var(--border-radius-md);box-shadow:0 10px 15px #0000000f,0 4px 6px #0000000d;box-shadow:var(--shadow-lg);flex-direction:column;gap:4px;margin-top:8px;min-width:220px;padding:8px;position:absolute;right:0;top:100%;z-index:10}.btn-print,.print-options{background-color:#fff;display:flex}.btn-print{align-items:center;border:1px solid #e0e0e0;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--border-radius-md);color:#424750;color:var(--text-medium);font-size:13px;gap:8px;padding:8px 14px;text-align:left;transition:all .2s ease-in-out;transition:var(--transition-standard)}.btn-print:hover{background-color:#f0f2f5;background-color:var(--background-medium);border-color:#d0d0d0;border-color:var(--border-medium);color:#1a2027;color:var(--text-dark)}.btn-export{align-items:center;display:flex;gap:8px}.dropdown-icon{transition:transform .2s ease}.dropdown-icon.open{transform:rotate(180deg)}.print-only{display:none}@media print{body{background-color:#fff!important;color:#000!important;font-size:12pt!important;line-height:1.3!important}.printable-content,body{margin:0!important;padding:0!important}.printable-content{max-width:none!important;width:100%!important}.printable-content,body[data-print-report=reminders] .reminder-report,body[data-print-report=reservations] .reservation-report,body[data-print-report=statistics] .statistics-report{display:block!important}.print-report{margin:0;padding:0;page-break-after:always}.print-header{border-bottom:1pt solid #000;margin-bottom:20pt;padding-bottom:10pt;text-align:center}.print-header h1{font-size:18pt;margin:0 0 5pt}.print-date{color:#666;font-size:10pt;margin:0}.print-summary{border:1pt solid #ccc;display:flex;justify-content:space-between;margin-bottom:20pt;padding:10pt}.print-summary-item{text-align:center}.print-summary-item h3{color:#666;font-size:10pt;font-weight:400;margin:0 0 5pt}.print-summary-item p{font-size:14pt;font-weight:700;margin:0}.print-table{border-collapse:collapse;font-size:9pt;margin-bottom:20pt;width:100%}.print-table th{background-color:#f0f0f0!important;font-weight:700;text-align:left}.print-table td,.print-table th{border:1pt solid #ccc;padding:5pt}.print-table td{vertical-align:top}.print-table .status-venter-row{background-color:#fff9e6!important}.print-table .status-hentet-row{background-color:#f0f7f0!important}.print-table .status-utløpt-row{background-color:#fdf0f0!important}.print-chart-data h2{font-size:14pt;margin:20pt 0 10pt}.print-no-data{border:1pt dashed #ccc;color:#666;padding:20pt;text-align:center}.print-table{page-break-inside:auto}.print-table tr{page-break-after:auto;page-break-inside:avoid}.print-table thead{display:table-header-group}.print-table tfoot{display:table-footer-group}@page{margin:2cm;@bottom-center{content:"Side " counter(page) " av " counter(pages);font-size:9pt}}}.statistics-section{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin:0 auto 2rem;max-width:95%;padding:1.75rem}.statistics-section,.visualization-section{margin-left:0!important}.statistics-container{display:flex;flex-direction:column;gap:1.5rem}.statistics-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:.5rem}@media (min-width:768px){.statistics-header{align-items:center;flex-direction:row;justify-content:space-between}}.statistics-title{color:#555;font-size:1.25rem;font-weight:600;margin:0}.period-selector-container{align-items:center;display:flex;gap:.5rem}.period-label{color:#4b5563;font-size:.875rem}.period-selector{border:none;transition:background-color .15s ease}.statistics-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}@media (min-width:768px){.statistics-cards{grid-template-columns:repeat(3,1fr)}}.stat-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.25rem;position:relative;transition:transform .2s ease,box-shadow .2s ease;z-index:10}.stat-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.stat-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.stat-title{color:#374151;font-size:.875rem;font-weight:500;margin:0}.info-button{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;font-size:1.125rem;justify-content:center;padding:.25rem;transition:color .15s ease}.info-button:hover{color:#7d203a}.stat-content{gap:1rem;margin-bottom:.75rem}.stat-content,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:9999px;font-size:1.25rem;height:3rem;justify-content:center;width:3rem}.stat-icon-blue{background-color:#7d203a26;color:#7d203a}.stat-icon-red{background-color:#fee2e2;color:#ef4444}.stat-icon-green{background-color:#d1fae5;color:#10b981}.stat-value-container{display:flex;flex-direction:column;gap:.25rem}.stat-value{color:#1f2937;font-size:1.75rem;font-weight:700;line-height:1;margin:0}.stat-unit{color:#6b7280;font-size:.875rem;margin:0}.stat-additional-info{color:#4b5563;font-size:.875rem;margin-top:.5rem}.stat-explanation{animation:fadeIn .2s ease-out;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;font-size:.875rem;left:0;padding:1rem;position:absolute;right:0;top:calc(100% + .5rem);z-index:10}.explanation-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.explanation-header h4{color:#1f2937;font-size:.9375rem;font-weight:600;margin:0}.close-explanation{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:.25rem;transition:color .15s ease}.close-explanation:hover{color:#4b5563}.stat-explanation p{color:#4b5563;line-height:1.5;margin:0 0 .75rem;z-index:10}.explanation-list{color:#4b5563;line-height:1.5;list-style-type:disc;margin:0;padding-left:1.25rem}.explanation-list li{margin-bottom:.375rem}.explanation-list li:last-child{margin-bottom:0}.dropdown-container{position:relative}.period-selector{align-items:center;background-color:#f3f4f6;border:1px solid #0000;border-radius:.375rem;color:#1f2937;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem .75rem;transition:all .15s ease}.period-selector.active,.period-selector:hover{background-color:#e5e7eb}.period-selector.active{border-color:#d1d5db;box-shadow:0 1px 2px #0000000d}.period-icon{color:#6b7280;transition:transform .15s ease}.period-dropdown{animation:fadeIn .15s ease-out;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;left:0;list-style:none;margin:0;max-height:15rem;overflow-y:auto;padding:.25rem 0;position:absolute;right:0;top:calc(100% + .25rem);z-index:20}.period-option{background:none;border:none;color:#1f2937;cursor:pointer;font-size:.875rem;padding:.5rem .75rem;text-align:left;transition:background-color .15s ease;width:100%}.period-option:hover{background-color:#f3f4f6}.period-option.selected{background-color:#7d203a0d;color:#7d203a;font-weight:500}.bar-chart{height:100%;position:relative;width:100%}.bar-chart-tooltip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#fffffff2;border:1px solid #d0d6e699;border-radius:10px;box-shadow:0 8px 16px #0000000f,0 2px 4px #0000000a;font-size:13px;line-height:1.5;max-width:250px;padding:12px 16px;z-index:10}.bar-chart-tooltip h4{border-bottom:1px solid #f0f2f9;color:#9d3353;font-size:14px;font-weight:600;margin:0 0 8px;padding-bottom:6px}.tooltip-item{margin-bottom:6px}.tooltip-label{margin-right:8px}.tooltip-value{color:#121826}.recharts-bar-rectangle:hover{filter:brightness(1.1);transition:filter .2s ease}.chart-title{color:#333;margin-bottom:.75rem}.chart-helper-text{color:#666;font-size:12px;font-style:italic;margin-top:.75rem}.custom-tooltip{border:1px solid #e1e6f0b3;box-shadow:0 4px 12px #00000014;max-width:270px}.tooltip-title{font-size:14px;margin-bottom:8px}.recharts-xAxis .recharts-cartesian-axis-tick text tspan{font-weight:inherit}.weekday-highlight{font-weight:600!important}.recharts-bar-rectangle{transition:opacity .2s ease}.recharts-bar-rectangle:hover{opacity:.85}.recharts-legend-item{margin-right:16px!important}.recharts-legend-item-text{margin-left:6px!important}@media (max-width:768px){.bar-chart-tooltip{font-size:12px;max-width:220px;padding:10px 14px}.bar-chart-tooltip h4{font-size:13px}.chart-title{font-size:14px}.chart-helper-text{font-size:11px}}.recharts-bar-rectangle:focus,.recharts-dot:focus{outline:2px solid #7d203a;outline-offset:2px}.scatter-legend>div{cursor:help}.scatter-legend>div:hover{background-color:#f0f0f080;border-radius:4px}.pickup-distribution-chart{background-color:#fff;border-radius:8px;display:flex;flex-direction:column;height:100%;padding:16px}.distribution-chart-header{margin-bottom:16px;text-align:center}.chart-title{color:#384255;font-size:1rem;font-weight:600;margin:0 0 4px}.chart-description{color:#606b85;font-size:.875rem;margin:0 0 4px}.chart-highlight{background-color:#9d33531a;border-radius:4px;color:#9d3353;display:inline-block;font-size:.875rem;margin:8px 0 0;padding:4px 8px}.chart-container{flex-grow:1}.chart-legend{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-bottom:12px}.legend-item{align-items:center;color:#606b85;display:flex;font-size:.75rem}.legend-color-box{border-radius:2px;height:12px;margin-right:6px;width:12px}.legend-text{font-size:.75rem}.distribution-insights{border-top:1px solid #f0f2f9;display:flex;gap:16px;justify-content:space-around;margin-top:16px;padding-top:16px}.insight-metric{flex:1 1;text-align:center}.insight-value{color:#9d3353;display:block;font-size:1.25rem;font-weight:700}.insight-value.pickup-days{color:#3f8ca8}.insight-value.not-picked{color:#e65a5a}.insight-label{color:#606b85;display:block;font-size:.75rem;margin-top:4px}.custom-tooltip{background-color:#fff;border:1px solid #f0f2f9;box-shadow:0 4px 12px #0000001a;max-width:250px;padding:12px 16px}.tooltip-title{border-bottom:1px solid #f0f2f9;color:#384255;font-size:.875rem;margin:0 0 8px;padding-bottom:6px}.tooltip-item{display:flex;font-size:.8125rem;justify-content:space-between;margin-bottom:4px}.tooltip-label{color:#606b85;margin-right:16px}.tooltip-value{color:#384255;font-weight:500}@media (max-width:768px){.distribution-insights{align-items:center;flex-direction:column;gap:12px}.insight-metric{max-width:180px;width:100%}.chart-legend{align-items:center;flex-direction:column;gap:8px}}@media (max-width:480px){.pickup-distribution-chart{padding:12px}.chart-title{font-size:.875rem}.chart-description,.chart-highlight{font-size:.75rem}.insight-value{font-size:1.125rem}.insight-label{font-size:.6875rem}}.export-menu-container{position:relative}.export-menu-button{align-items:center;background-color:#7d203a;border-radius:8px;color:#fff;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:background-color .3s ease}.export-menu-button:hover{background-color:#9a3941}.button-icon{font-size:18px}.export-menu-dropdown{animation:fadeIn .3s ease-in-out;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;padding:16px;position:absolute;right:0;top:100%;width:320px;z-index:10}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.export-menu-header{align-items:center;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.export-options-button{align-items:center;background-color:#9a3941;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;gap:6px;padding:6px 10px;transition:background-color .2s ease}.export-options-button:hover{background-color:#ad4b53}.export-options-panel{background-color:#f3f4f7;border-radius:8px;box-shadow:0 4px 6px #0000001a;padding:20px}.export-option-group{margin-bottom:16px}.export-option-checkbox,.export-option-radio{align-items:center;display:flex;margin-bottom:8px}.checkbox-label,.radio-label{margin-left:8px}.export-options-actions{display:flex;justify-content:space-between;margin-top:20px}.apply-options-button,.cancel-options-button{align-items:center;background-color:#9a3941;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;gap:6px;padding:6px 10px;transition:background-color .2s ease}.apply-options-button:hover,.cancel-options-button:hover{background-color:#6a0000}.export-menu-options{display:flex;flex-direction:column;gap:8px}.export-menu-item{align-items:center;background-color:initial;border:1px solid #e0e0e0;border-radius:6px;color:#7d203a;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:8px 12px;transition:background-color .2s ease,color .2s ease}.export-menu-item:hover{background-color:#661a2f;color:#fff}.menu-icon{font-size:18px}.custom-date-range{display:flex;flex-direction:column;gap:10px}.date-range-field{align-items:center;display:flex;gap:10px}.date-input-wrapper{align-items:center;display:flex;gap:6px}.date-icon{font-size:18px}.visualization-section{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:95%;padding:1.75rem;transition:all .3s ease}.button-group{gap:12px;justify-content:flex-end}.button-group,.section-header{align-items:center;display:flex}.section-header{flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.75rem}.title-group{gap:.75rem}.section-title,.title-group{align-items:center;display:flex}.section-title{color:#333;font-size:1.35rem;font-weight:600;margin:0}.section-icon{color:#b53b62;font-size:1.2em;margin-right:.5rem}.chart-navigation{display:flex;flex-wrap:wrap;gap:1.25rem;justify-content:space-between;margin-bottom:1.75rem}.chart-types{display:flex;flex-wrap:wrap;gap:.625rem}.action-button,.chart-types button,.explore-btn,.glossary-toggle-btn,.intro-toggle-btn,.time-periods button{align-items:center;background-color:#f8f9fa;border:1px solid #e4e7eb;border-radius:8px;color:#4a5568;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;padding:.625rem .875rem;position:relative;transition:all .2s ease}.action-button:hover,.chart-types button:hover,.explore-btn:hover,.glossary-toggle-btn:hover,.intro-toggle-btn:hover,.time-periods button:hover{background-color:#f1f3f5;box-shadow:0 2px 5px #0000000d;transform:translateY(-1px)}.action-button:active,.chart-types button:active,.explore-btn:active,.glossary-toggle-btn:active,.intro-toggle-btn:active,.time-periods button:active{box-shadow:none;transform:translateY(0)}.chart-types button.active,.time-periods button.active{background-color:#f0f5ff;border-color:#bfdeff;color:#1950a0;font-weight:600}.time-periods button.active{background-color:#fdf2f6;border-color:#fed7e2;color:#b53b62}.chart-type-icon,.description-icon,.explore-icon,.glossary-icon,.help-icon,.period-icon{font-size:1.1em;margin-right:.5rem}.time-periods{display:flex;flex-wrap:wrap;gap:.625rem}.chart-description{background-color:initial;font-size:.85rem;margin-bottom:.75rem;padding:.5rem 0}.chart-description-text{color:#666;font-size:.85rem;margin:0}.description-icon{color:#b53b62;flex-shrink:0;font-size:.85rem;margin-right:.4rem}.chart-visualization{margin-top:.5rem;position:relative}.bar-chart-container{position:relative}.chart-summary{background-color:initial;border:none;margin-bottom:.5rem;padding:.25rem 0;text-align:center}.chart-summary-text{color:#666;font-size:.8rem}.chart-summary-text strong{animation:none;color:#b53b62;display:inline;font-weight:600}.custom-tooltip{background-color:#fffffff7;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 6px 16px #0000001f;max-width:275px;padding:.875rem;z-index:10}.tooltip-title{border-bottom:1px solid #edf2f7;color:#2d3748;font-size:.925rem;font-weight:600;margin:0 0 .625rem;padding-bottom:.625rem}.tooltip-label{color:#718096;font-size:.8rem;margin-right:.5rem}.tooltip-value{font-size:.875rem;font-weight:600}.intro-panel{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 2px 8px #0000000d;margin-bottom:1.5rem;padding:1.5rem}.intro-header{justify-content:space-between;margin-bottom:1rem}.intro-header,.intro-title{align-items:center;display:flex}.intro-title{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0}.intro-icon{color:#3182ce;margin-right:.5rem}.intro-close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#718096;cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:all .2s ease}.intro-close-btn:hover{background-color:#edf2f7;color:#4a5568}.intro-content{color:#4a5568;font-size:.925rem}.intro-content ul{margin:.75rem 0;padding-left:1.5rem}.intro-content li{margin-bottom:.5rem}.intro-terms{border-top:1px solid #e2e8f0;margin-top:1.25rem;padding-top:1rem}.glossary-toggle-btn{align-items:center;background:none;background-color:#ebf8ff;border:1px solid #bee3f8;border-radius:6px;color:#1950a0;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;padding:.5rem .75rem;transition:all .2s ease}.glossary-toggle-btn:hover{background-color:#e6f6ff}.glossary-section{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:1rem;padding:1rem}.glossary-title{color:#2d3748;font-size:.95rem;font-weight:600;margin:0 0 .75rem}.glossary-list{margin:0}.glossary-list dt{color:#4a5568;font-weight:600;margin-bottom:.25rem}.glossary-list dd{color:#718096;font-size:.875rem;margin-bottom:.75rem;margin-left:0}.explore-btn{align-items:center;background-color:#b53b62;border:none;border-radius:8px;color:#fff;display:flex;font-size:.95rem;font-weight:600;justify-content:center;margin-top:1.25rem;padding:.75rem 1.25rem;transition:all .2s ease;width:50%%}.explore-btn:hover{background-color:#a03057;box-shadow:0 4px 8px #b53b6240;transform:translateY(-2px)}.explore-btn:active{box-shadow:none;transform:translateY(0)}.explore-icon{margin-left:.5rem;transition:transform .2s ease}.explore-btn:hover .explore-icon{transform:translateX(3px)}.intro-toggle-btn{align-items:center;background-color:#f0f5ff;border:1px solid #bfdeff;color:#1950a0;display:flex;padding:.5rem .75rem}.help-icon{color:#3182ce}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.weekly-highlight{position:relative}.weekly-highlight:after{color:#e85692;content:"↑";font-size:16px;font-weight:700;left:50%;position:absolute;top:-20px;transform:translateX(-50%)}.custom-tooltip.weekly-tooltip .tooltip-title{color:#b53b62;font-size:1rem}.weekly-indicator{background-color:#e85692b3;border-radius:8px;color:#fff;font-size:10px;font-weight:700;left:50%;padding:1px 6px;position:absolute;top:-15px;transform:translateX(-50%);white-space:nowrap;z-index:1}.visualization-section button:focus{box-shadow:0 0 0 3px #4299e180;outline:none}.visualization-section button:focus:not(:focus-visible){box-shadow:none}.time-periods button.active[aria-pressed=true]{box-shadow:0 0 0 3px #b53b6233}[aria-labelledby=most-active-day]{font-weight:700!important;text-decoration:underline}@media (max-width:992px){.visualization-section{padding:1.5rem}.chart-navigation{gap:1rem}}@media (max-width:768px){.section-header{align-items:flex-start;flex-direction:column}.chart-navigation{flex-direction:column;gap:1rem}.chart-types,.time-periods{width:100%}.intro-toggle-btn{align-self:flex-start;margin-top:.5rem}}@media (max-width:576px){.visualization-section{padding:1.25rem}.action-button,.chart-types button,.intro-toggle-btn,.time-periods button{font-size:.8rem;padding:.5rem .75rem}.section-title{font-size:1.15rem}.chart-description{padding:.5rem 0}.chart-description-text{font-size:.75rem}.intro-panel{padding:1.25rem}.custom-tooltip{max-width:240px;padding:.75rem}}@media (max-width:480px){.chart-types,.time-periods{justify-content:space-between}.chart-types button span:not(.chart-type-icon),.time-periods button span{display:none}.chart-type-icon,.period-icon{margin-right:0}.chart-types button.active:after,.time-periods button.active:after{background-color:#b53b62;border-radius:50%;bottom:-3px;content:"";display:block;height:6px;left:50%;position:absolute;transform:translateX(-50%);width:6px}.intro-title{font-size:1rem}.glossary-toggle-btn{justify-content:center;width:100%}}.modern-toast{align-items:flex-start;animation:slideUpFade .4s ease-out;background-color:#fff;border-left:6px solid;border-radius:12px;bottom:32px;box-shadow:0 8px 24px #0000001a;display:flex;font-family:Segoe UI,sans-serif;font-size:15px;gap:12px;left:50%;max-width:90%;min-width:320px;padding:16px 20px;position:fixed;transform:translateX(-50%);z-index:9999}.toast-icon{font-size:24px;margin-top:2px}.toast-text{color:#333;line-height:1.4}.toast-success{border-color:#2e7d32;color:#2e7d32}.toast-error{border-color:#c62828;color:#c62828}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.printable-content{display:none}@media print{body{background:#fff;color:#121826;font-family:Arial,Helvetica Neue,sans-serif;font-size:12pt;line-height:1.5}.printable-content{display:block;margin:0;max-width:100%;padding:0}.dashboard-wrapper>:not(.printable-content){display:none!important}.print-report{margin-bottom:2cm;page-break-after:always}.print-report:last-child{margin-bottom:0;page-break-after:auto}.print-header{border-bottom:1pt solid #d0d6e6;margin-bottom:1cm;padding-bottom:.5cm}.print-header h1{color:#9d3353;font-size:24pt;margin:0 0 .25cm}.print-date{color:#606b85;font-size:10pt;margin:0}.print-summary{display:flex;justify-content:space-between;margin-bottom:1cm}.print-summary-item{background-color:#f9fafc;border-radius:8pt;flex:1 1;margin:0 .25cm;padding:.5cm;text-align:center}.print-summary-item:first-child{margin-left:0}.print-summary-item:last-child{margin-right:0}.print-summary-item h3{color:#606b85;font-size:10pt;font-weight:600;margin:0 0 .25cm}.print-summary-item p{color:#9d3353;font-size:18pt;font-weight:700;margin:0}.print-table{border-collapse:collapse;font-size:9pt;margin-bottom:1cm;width:100%}.print-table th{background-color:#f0f2f9;border-bottom:1pt solid #d0d6e6;color:#384255;font-weight:600;padding:.25cm;text-align:left}.print-table td{border-bottom:1pt solid #f0f2f9;color:#384255;padding:.2cm .25cm}.print-table tr:last-child td{border-bottom:none}.status-venter-row{background-color:#fff8e1}.status-hentet-row{background-color:#e8f5e9}.status-utløpt-row{background-color:#ffebee}.print-no-data{border:1pt dashed #d0d6e6;color:#606b85}.print-chart-data,.print-no-data{background-color:#f9fafc;border-radius:8pt;padding:1cm;text-align:center}.print-chart-data{margin-top:1cm}.print-chart-data h2{color:#384255;font-size:14pt;margin:0 0 .5cm}.print-chart-data p{color:#606b85;margin:0}@page{counter-increment:page;margin:2cm}@page :first{margin-top:3cm}.print-report:after{bottom:.5cm;color:#a4adc1;content:"Side " counter(page);font-size:8pt;position:absolute;right:.5cm}}.help-section{display:flex;height:calc(100vh - var(--header-height));overflow:hidden}.help-sidebar{background-color:#f5f5f7;border-right:1px solid #e2e2e7;flex-shrink:0;overflow-y:auto;padding:20px;width:280px}.help-content-container{flex:1 1;overflow-y:auto;padding:30px}.help-categories{list-style:none;margin:20px 0;padding:0}.help-categories li{border-radius:6px;cursor:pointer;margin-bottom:5px;padding:12px 15px;transition:background-color .2s ease}.help-categories li:hover{background-color:#e8e8ef}.help-categories li.active{background-color:#7d203a;color:#fff;font-weight:500}.help-content h2{color:#222;font-size:28px;margin-bottom:20px}.help-content h3{color:#333;font-size:18px;margin:30px 0 15px}.help-content p{color:#444;line-height:1.6;margin-bottom:16px}.help-content ol,.help-content ul{margin-bottom:20px;padding-left:20px}.help-content li{line-height:1.5;margin-bottom:8px}.help-content strong{font-weight:600}.help-contact{background-color:#eef2f5;border-radius:8px;margin-top:30px;padding:15px}.help-contact h3{font-size:16px;margin-top:0}.help-contact p{font-size:14px;margin:8px 0}.shortcuts-table{border-collapse:collapse;margin-bottom:20px;width:100%}.shortcuts-table td{border-bottom:1px solid #e2e2e7;padding:10px}.shortcuts-table td:first-child{white-space:nowrap;width:30%}kbd{background-color:#f7f7f7;border:1px solid #ccc;border-radius:3px;box-shadow:0 1px 0 #0003;color:#333;display:inline-block;font-family:monospace;font-size:13px;line-height:1.4;margin:0 .1em;padding:.1em .6em;text-shadow:0 1px 0 #fff}@media (max-width:768px){.help-section{flex-direction:column}.help-sidebar{border-bottom:1px solid #e2e2e7;border-right:none;max-height:200px;width:100%}.help-categories{display:flex;flex-wrap:wrap;margin:10px 0}.help-categories li{font-size:14px;margin-bottom:5px;margin-right:5px;padding:8px 12px}.help-content-container{padding:15px}.help-content h2{font-size:24px}.help-content h3{font-size:16px}}:root{--primary:#7d203a;--primary-light:#9a3941;--primary-dark:#5a1728;--primary-contrast:#fff;--gray-50:#f5f7fa;--gray-100:#edf2f7;--gray-200:#e2e8f0;--gray-300:#cbd5e0;--gray-400:#a0aec0;--gray-500:#718096;--gray-600:#4a5568;--gray-700:#2d3748;--gray-800:#1a202c;--gray-900:#171923;--header-height:60px;--sidebar-width:220px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1);--transition-bounce:300ms cubic-bezier(0.34,1.56,0.64,1);--z-header:1000;--z-sidebar:900;--z-dropdown:950;--z-modal:1100}*{box-sizing:border-box;margin:0;padding:0}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1a202c;color:var(--gray-800);font-size:16px;line-height:1.5;overflow-x:hidden;width:100%}.app-container{display:flex;flex-direction:column;min-height:100vh;position:relative}.app-header{align-items:center;background-color:#fff;border-bottom:1.5px solid #9a3941;border-bottom:1.5px solid var(--primary-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);left:0;position:fixed;right:0;top:0;z-index:1000;z-index:var(--z-header)}.app-header,.left-panel{display:flex;height:60px;height:var(--header-height)}.left-panel{color:#fff;color:var(--primary-contrast);flex-direction:column;justify-content:center;position:relative;transition:width .2s cubic-bezier(.4,0,.2,1);transition:width var(--transition);width:220px;width:var(--sidebar-width)}.left-panel,.left-panel:after{background-color:#9a3941;background-color:var(--primary-light)}.left-panel:after{bottom:-1.5px;content:"";height:1.5px;position:absolute;right:0;width:30px}.user-info{align-items:center;cursor:pointer;display:flex;padding:0 16px;transition:background-color .2s cubic-bezier(.4,0,.2,1);transition:background-color var(--transition)}.user-info:hover{background-color:#ffffff1a}.user-avatar{align-items:center;background-color:#fff3;border-radius:50%;flex-shrink:0;font-weight:700;height:40px;justify-content:center;margin-right:12px;width:40px}.user-avatar,.user-details{display:flex;font-size:14px}.user-details{flex-direction:column;line-height:1.2}.user-name{font-weight:600}.user-id,.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-id{font-size:12px;opacity:.9}.header-title{flex:1 1;padding-left:24px}.header-title h1{color:#2d3748;color:var(--gray-700);font-size:20px;font-weight:500;letter-spacing:-.01em;margin:0;position:relative}.header-title h1:after{background-color:#9a3941;background-color:var(--primary-light);border-radius:2px;bottom:-4px;content:"";height:2px;left:0;opacity:.7;position:absolute;width:40px}.main-content{display:flex;margin-top:60px;margin-top:var(--header-height);min-height:calc(100vh - 60px);min-height:calc(100vh - var(--header-height));position:relative}.sidebar{background-color:#7d203a;background-color:var(--primary);bottom:0;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;scroll-behavior:smooth;scrollbar-color:#ffffff4d #0000;scrollbar-width:thin;top:0;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1);transition:transform var(--transition),box-shadow var(--transition);width:220px;width:var(--sidebar-width);z-index:900;z-index:var(--z-sidebar)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:#0000}.sidebar::-webkit-scrollbar-thumb{background-color:#ffffff4d;border-radius:4px}.content-area{flex:1 1;margin-left:220px;margin-left:var(--sidebar-width);min-height:calc(100vh - 60px);min-height:calc(100vh - var(--header-height));padding-left:40px;transition:margin-left .2s cubic-bezier(.4,0,.2,1),width .2s cubic-bezier(.4,0,.2,1),padding .2s cubic-bezier(.4,0,.2,1);transition:margin-left var(--transition),width var(--transition),padding var(--transition);width:calc(100% - 220px);width:calc(100% - var(--sidebar-width));will-change:margin-left,width,padding}.mobile-menu-button{background:none;border:none;border-radius:4px;cursor:pointer;display:none;margin-right:8px;padding:8px;transition:background-color .2s cubic-bezier(.4,0,.2,1);transition:background-color var(--transition)}.mobile-menu-button:hover{background-color:#fff3}.mobile-menu-button:focus{box-shadow:0 0 0 2px #ffffff80;outline:none}.menu-icon-bar{background-color:#fff;border-radius:2px;display:block;height:2px;margin:4px 0;transition:transform .2s cubic-bezier(.4,0,.2,1),opacity .2s cubic-bezier(.4,0,.2,1);transition:transform var(--transition),opacity var(--transition);width:22px}.mobile-menu-button.open .menu-icon-bar:first-child{transform:translateY(6px) rotate(45deg)}.mobile-menu-button.open .menu-icon-bar:nth-child(2){opacity:0}.mobile-menu-button.open .menu-icon-bar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}@media (max-width:1200px){.content-area{padding:20px}}@media (max-width:992px){.content-area{padding:16px}.header-title h1{font-size:18px}}@media (max-width:768px){.mobile-menu-button{align-items:center;display:flex;flex-direction:column;justify-content:center}.sidebar{box-shadow:none;transform:translateX(-100%)}.sidebar.open{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateX(0)}.content-area{margin-left:0;padding:16px;width:100%}.left-panel{align-items:center;flex-direction:row;width:auto}.user-details{display:none}.header-title{padding-left:16px}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:none;left:0;opacity:0;position:fixed;right:0;top:60px;top:var(--header-height);transition:opacity .2s cubic-bezier(.4,0,.2,1);transition:opacity var(--transition);z-index:899;z-index:calc(var(--z-sidebar) - 1)}.sidebar-overlay.active{display:block;opacity:1}}@media (max-width:480px){.content-area{padding:12px}.header-title h1{font-size:16px}.header-title h1:after{width:30px}}@media print{.app-header,.mobile-menu-button,.sidebar{display:none!important}.content-area{margin-left:0!important;padding:0!important;width:100%!important}.main-content{margin-top:0!important}body{background-color:#fff!important;color:#000!important}@page{margin:1.5cm}h1,h2,h3,h4,h5,h6{page-break-after:avoid}h1,h2,h3,h4,h5,h6,img{page-break-inside:avoid}img{max-width:100%!important}figure,table{page-break-inside:avoid}}:focus{outline:2px solid #9a3941;outline:2px solid var(--primary-light);outline-offset:2px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid #9a3941;outline:2px solid var(--primary-light);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@media (prefers-color-scheme:dark){body{--gray-50:#171923;--gray-100:#1a202c;--gray-700:#e2e8f0;--gray-800:#edf2f7}.app-header{background-color:#1a202c;border-bottom-color:#5a1728;border-bottom-color:var(--primary-dark)}.header-title h1{color:#e2e8f0}}.App{display:flex;flex-direction:column;height:100vh}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}body,html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;height:100%;margin:0;padding:0}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){main{margin-left:0}}
/*# sourceMappingURL=main.c43e0e57.css.map*/