@import"https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600;700&display=swap";:root{--color-accent: #8b1b3f;--color-accent-hover: #6e1432;--color-accent-soft: rgba(139, 27, 63, .08);--color-accent-softer: rgba(139, 27, 63, .04);--color-accent-border: rgba(139, 27, 63, .18);--color-bg: #f7f5f2;--color-surface: #ffffff;--color-border: #ececec;--color-text: #1f1f1f;--color-text-muted: #6b6b6b;--color-text-faint: #9b9b9b;--color-danger: #c0392b;--color-danger-soft: rgba(192, 57, 43, .08);--radius: 12px;--radius-sm: 8px}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#faf7f2;color:#2c2c2c}button{border:none;font-family:inherit;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.7}a{color:inherit}.header{position:sticky;top:0;z-index:1000;box-shadow:0 2px 12px #00000014}.headerTop{background:#fff;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;gap:12px}.headerBar{height:5px;background:#8b1a2b}.headerLeft{display:flex;align-items:center;gap:24px;min-width:0}.logoLink{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.logoImg{height:44px;width:auto;display:block;object-fit:contain}.nav{display:flex;gap:0;align-items:center}.navLink{padding:0 18px;height:56px;display:inline-flex;align-items:center;background:transparent;border:none;color:#2c2c2c;font-size:.95rem;font-weight:600;text-decoration:none;cursor:pointer;transition:background .2s ease,color .2s ease;box-shadow:none!important;text-transform:none;letter-spacing:0;border-bottom:3px solid transparent;margin-bottom:-4px;white-space:nowrap}.navLink:hover{background:#8b1a2b0f;color:#8b1a2b}.headerRight{display:flex;align-items:center;gap:12px;flex-shrink:0}.profileWrap{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#8b1a2b14;border-radius:24px;color:#2c2c2c;font-size:.9rem;font-weight:600}.profileIconWrap{display:flex;align-items:center;justify-content:center;color:#8b1a2b}.logoutBtn{padding:8px 16px;border-radius:20px;border:none;background:#8b1a2b;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s ease}.logoutBtn:hover{background:#6d1422}.burgerBtn{display:none;width:40px;height:40px;border-radius:8px;border:none;background:transparent;color:#2c2c2c;cursor:pointer;align-items:center;justify-content:center}.burgerBtn:hover{background:#8b1a2b14;color:#8b1a2b}.navLinkActive{color:#8b1a2b;border-bottom-color:#8b1a2b;background:#fdf2f4}.navBackdrop{display:none}.profileOptions{display:flex;flex-direction:column}.profileDropdown{position:absolute;top:calc(100% + 8px);right:5rem;min-width:220px;background:#fff;border:1px solid #ddd;border-radius:12px;box-shadow:0 10px 25px #0000001a;padding:8px;display:flex;flex-direction:column;z-index:1000}.profileDropdown button{background:none;border:none;text-align:left;padding:12px;border-radius:8px;cursor:pointer;font-size:14px}.profileDropdown button:hover{background:#f5f5f5}@media(max-width:900px){.profileName{display:none}.profileWrap{padding:8px;border-radius:50%}}@media(max-width:768px){.headerTop{padding:0 16px;gap:8px}.logoImg{height:36px}.burgerBtn{display:inline-flex}.nav{display:none;position:fixed;top:61px;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid rgba(0,0,0,.08);padding:8px 0;box-shadow:0 8px 16px #00000014;z-index:999}.nav.navOpen{display:flex}.navLink{height:auto;padding:14px 20px;border-bottom:none;margin-bottom:0;width:100%;box-sizing:border-box}.navLink:hover{background:#8b1a2b0f}.navLinkActive{background:#8b1a2b14;border-bottom:none}.navBackdrop{display:block;position:fixed;inset:61px 0 0;background:#00000040;z-index:998}.logoutBtn{padding:6px 12px;font-size:.8rem}}@media(max-width:480px){.logoutBtn{display:none}}._tabs_cbdty_3{display:flex;gap:4px;border-bottom:1px solid var(--color-border);margin-bottom:24px}._tab_cbdty_3{background:none;border:none;padding:10px 16px;font-size:.9rem;font-weight:600;text-decoration:none;color:var(--color-text-muted);cursor:pointer;transition:color .15s ease,border-color .15s ease;border-bottom:2px solid transparent;margin-bottom:-1px}._tab_cbdty_3:hover{color:var(--color-text)}._tabActive_cbdty_28{color:var(--color-accent);border-bottom-color:var(--color-accent)}._tabContent_cbdty_33{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:28px 32px}@media(max-width:640px){._tabContent_cbdty_33{padding:20px 18px}}.page-container{min-height:100vh;background:#fff;display:flex;flex-direction:column;overflow-x:hidden}.page-container-start{position:relative;z-index:0;border-radius:1rem;margin:0 -24px;overflow-x:hidden}.message-container{display:flex;justify-content:center;margin:0 12px 26px}.message-display{display:flex;align-items:center;gap:13px;max-width:860px;width:100%;padding:16px 22px;background:var(--color-surface);border:1.5px solid var(--color-accent-border);border-radius:14px;color:var(--color-accent);font-size:1.1rem;font-weight:700;box-shadow:0 4px 16px #8b1b3f12;text-align:left}.message-icon{width:22px;height:22px;flex-shrink:0}.section-label{max-width:1600px;margin:32px auto 14px;padding:0 8px;display:flex;align-items:center;gap:14px;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-faint)}.section-label-line{flex:1;height:1px;background:var(--color-border)}.section-label-prestaties{margin-top:40px}.home-search-section{position:relative;height:280px;margin:32px 0;background-size:cover;background-position:center;background-repeat:no-repeat;overflow:visible;border-radius:16px}.home-search-overlay{position:absolute;inset:0;background:#00000040;display:flex;align-items:center;justify-content:center;padding:0 24px}.home-search-wrapper{position:relative;width:100%;max-width:640px}.home-search-form{display:flex;width:100%;gap:12px;background:#fff;padding:8px;border-radius:12px;box-shadow:0 8px 32px #00000026}.home-search-input-group{flex:1;display:flex;align-items:center;padding:0 12px;background:#f7f5f2;border:1.5px solid #ececec;border-radius:8px;transition:border-color .15s ease,box-shadow .15s ease}.home-search-input-group:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px #8b1b3f14}.home-search-icon{color:var(--color-accent);flex-shrink:0;margin-right:10px}.home-search-input{flex:1;border:none;outline:none;font-size:1rem;color:#1f1f1f;background:transparent;padding:12px 0}.home-search-input::placeholder{color:#9b9b9b}.home-search-button{background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);padding:0 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease;white-space:nowrap}.home-search-button:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.search-suggestions{position:absolute;top:calc(100% + 12px);left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;border:1px solid rgba(0,0,0,.1);overflow:hidden;z-index:1001}.suggestion-item{display:flex;align-items:center;padding:14px 18px;gap:14px;cursor:pointer;transition:background .2s ease}.suggestion-item:hover{background:#f7f5f2}.suggestion-cover{width:44px;height:64px;object-fit:cover;border-radius:4px;box-shadow:0 2px 6px #0000001a}.suggestion-info{flex:1;display:flex;flex-direction:column}.suggestion-title{font-weight:700;color:#1f1f1f;font-size:1rem;line-height:1.3}.suggestion-author{font-size:.9rem;color:#6b6b6b;margin-top:3px}.suggestion-more{justify-content:center;font-weight:700;color:var(--color-accent);border-top:1px solid #ececec;font-size:.95rem;background:#faf7f2}@media(max-width:768px){.message-display{font-size:1.4rem;padding:1rem}.home-search-section{height:220px}.home-search-form{flex-direction:column;padding:12px}.home-search-button{height:48px;width:100%}}.fp-badge-wrapper{overflow:hidden;margin:0 12px}.popular-books-list{display:flex;flex-direction:column;gap:12px}.popular-book-item{display:flex;align-items:center;gap:14px;padding:12px;background:#fff;border-radius:10px;border:1px solid #ececec;cursor:pointer;transition:box-shadow .2s ease}.popular-book-item:hover{box-shadow:0 4px 16px #8b1a2b1a}.popular-rank{font-size:1.2rem;font-weight:800;color:var(--color-accent);min-width:32px;text-align:center}.popular-book-cover{width:44px;height:64px;object-fit:cover;border-radius:4px;box-shadow:0 2px 6px #0000001a}.popular-book-info{display:flex;flex-direction:column;gap:2px}.popular-book-title{font-weight:700;color:#1f1f1f;font-size:.95rem}.popular-book-author{font-size:.85rem;color:#6b6b6b}.popular-book-count{font-size:.8rem;color:var(--color-accent);font-weight:600;margin-top:2px}.featured-triangle{display:flex;flex-direction:column;max-width:1600px;margin:0 auto;padding:0 8px}.featured-stack{max-width:1600px;margin:0 auto;padding:0 8px;display:flex;flex-direction:column;gap:20px}.featured-triangle-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media(max-width:1200px){.featured-triangle-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.featured-triangle-row{grid-template-columns:1fr}}.featured-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:1400px;margin:0 auto;padding:0 12px}.featured-row-item{min-width:0}.featured-row .featured-section{padding:20px 8px;border-top:none}.featured-row .featured-title{font-size:2rem;margin-bottom:20px}.featured-row .carousel-rotate{max-width:100%;gap:12px;min-height:300px;overflow:hidden}.featured-row .carousel-rotate-item{flex:0 0 7rem}.featured-row .carousel-rotate-item.carousel-left,.featured-row .carousel-rotate-item.carousel-right{transform:none;opacity:.9}.featured-row .carousel-rotate-item.carousel-center{transform:none}.featured-row .carousel-rotate-item.carousel-left:hover,.featured-row .carousel-rotate-item.carousel-right:hover{transform:none;opacity:1}.featured-row .featured-card,.featured-row .carousel-center .featured-card,.featured-row .carousel-left .featured-card,.featured-row .carousel-right .featured-card{max-width:140px;padding:10px}.featured-row .carousel-center .featured-card{box-shadow:0 4px 16px #8b1a2b26;border-color:var(--color-accent);border-width:2px}.featured-row .featured-summary{display:none}@media(max-width:900px){.featured-row{grid-template-columns:1fr}}.featured-triangle .featured-section{padding:20px 22px 22px;display:flex;flex-direction:column}.featured-card-header{display:flex;align-items:center;gap:11px;padding-bottom:14px;border-bottom:1px solid var(--color-border);margin-bottom:16px}.featured-card-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--color-accent-soft);border-radius:9px;color:var(--color-accent);flex:none}.featured-card-icon svg{width:18px;height:18px}.featured-triangle .featured-title,.featured-card-header .featured-title{font-size:1.06rem;font-weight:700;color:var(--color-accent);margin:0;text-align:left}.carousel-rotate-wrap{position:relative;display:flex;align-items:center;justify-content:center}.featured-triangle .carousel-rotate{max-width:100%;min-height:0;gap:0;overflow:hidden;justify-content:center}.featured-triangle .carousel-rotate-item.carousel-left,.featured-triangle .carousel-rotate-item.carousel-right{display:none!important}.featured-triangle .carousel-rotate-item.carousel-center{transform:none}.featured-triangle .featured-card,.featured-triangle .carousel-center .featured-card{max-width:100%;width:100%;padding:0;background:transparent;border:none;box-shadow:none;text-align:center}.featured-triangle .featured-cover-wrap{overflow:visible;margin:0 auto 14px;max-width:170px;box-shadow:0 8px 20px #0000001f;border-radius:8px}.featured-triangle .featured-cover,.featured-triangle .featured-cover-placeholder{border-radius:8px}.featured-triangle .featured-card-title{font-size:1rem;font-weight:700;color:var(--color-text);margin-top:4px;-webkit-line-clamp:2;white-space:normal}.featured-triangle .featured-card-author{font-size:.85rem;color:var(--color-text-muted)}.featured-triangle .featured-summary{display:block;-webkit-line-clamp:3;margin-top:10px;font-size:.82rem;text-align:center;color:var(--color-text-muted)}.featured-triangle .carousel-center .featured-summary{max-height:none;overflow:visible}.featured-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);font-size:1.4rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001f;z-index:2;transition:background .15s ease,color .15s ease}.featured-nav-btn:hover{background:var(--color-accent-soft);color:var(--color-accent)}.featured-nav-prev{left:8px}.featured-nav-next{right:8px}.featured-triangle .carousel-dots{margin-top:14px}.featured-section{padding:18px 18px 20px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);height:100%;box-shadow:0 2px 10px #8b1b3f0a;overflow:hidden}.featured-spotlight{display:flex;flex-direction:column}.featured-spotlight .spotlight-book{display:flex;flex-direction:column;align-items:center;gap:6px;max-width:260px;margin:0 auto;padding:4px 0;background:transparent;border:none;cursor:pointer;text-align:center;font:inherit;color:inherit}.featured-spotlight .featured-cover-wrap{width:170px;margin:0 auto 14px;border-radius:8px;box-shadow:0 8px 20px #0000001f;overflow:hidden}.featured-spotlight .featured-cover,.featured-spotlight .featured-cover-placeholder{border-radius:8px;display:block;width:100%}.featured-spotlight .featured-card-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:4px 0 0}.featured-spotlight .featured-card-author{font-size:.86rem;color:var(--color-text-muted);margin:2px 0 0}.featured-spotlight .featured-summary{font-size:.82rem;color:var(--color-text-muted);margin-top:8px;-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.featured-title{text-align:center;font-size:3rem;font-weight:700;color:var(--color-accent);margin:0 0 32px}.carousel-rotate{display:flex;align-items:flex-end;justify-content:center;gap:16px;max-width:900px;margin:0 auto;min-height:340px}.carousel-rotate-item{flex:0 0 10rem;overflow:hidden;transition:transform .4s ease,opacity .4s ease;cursor:default;outline:none;background:none;border:none;padding:0}.carousel-rotate-item.carousel-left,.carousel-rotate-item.carousel-right{cursor:pointer;opacity:.85}.carousel-rotate-item.carousel-left{transform:scale(.78) translate(8px)}.carousel-rotate-item.carousel-center{transform:scale(1);z-index:2;cursor:pointer}.carousel-rotate-item.carousel-right{transform:scale(.78) translate(-8px)}.carousel-rotate-item.carousel-left:hover,.carousel-rotate-item.carousel-right:hover{opacity:1;transform:scale(.82) translate(0)}.carousel-rotate-item:focus-visible .featured-card{box-shadow:0 0 0 3px #ff520e}.featured-card{background:#fff;border-radius:14px;padding:18px;box-shadow:0 8px 24px #8b1a2b1f;border:2px solid rgba(139,26,43,.12);max-width:220px;margin:0 auto;transition:box-shadow .3s ease,border-color .3s ease,transform .2s ease}.carousel-center .featured-card{box-shadow:0 0 0 4px #8b1a2b33,0 16px 40px #8b1a2b2e;border-color:var(--color-accent);max-width:260px;padding:22px}.carousel-left .featured-card,.carousel-right .featured-card{max-width:180px;padding:14px}.featured-summary{font-size:.85rem;line-height:1.45;color:#5a5a5a;margin:10px 0 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.carousel-center .featured-summary{-webkit-line-clamp:unset;display:block;overflow-y:auto;max-height:7.5rem;white-space:pre-wrap;word-break:break-word}.featured-cover-wrap{border-radius:8px;overflow:hidden;margin-bottom:12px}.featured-cover{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.featured-cover-placeholder{width:100%;aspect-ratio:2/3;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;letter-spacing:.05em}.featured-card-title{font-size:1rem;font-weight:700;color:#2c2c2c;margin:0 0 4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.featured-card-author{font-size:.9rem;color:#6b6b6b;margin:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:20px}.carousel-dot{width:10px;height:10px;border-radius:50%;border:none;background:#8b1a2b4d;cursor:pointer;transition:background .2s ease,transform .2s ease}.carousel-dot:hover{background:#8b1a2b80}.carousel-dot-active{background:var(--color-accent);transform:scale(1.2)}.suggested-books-section{padding:20px 24px 24px;border-top:1px solid rgba(139,26,43,.08)}.suggested-books-title{text-align:left;font-size:1.4rem;font-weight:700;color:var(--color-accent);margin:0 0 16px}.suggested-books-section .featured-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;padding:0;margin:0}.suggested-books-section .featured-card{padding:12px;max-width:none}.suggested-books-section .featured-card-title{font-size:.9rem}.suggested-books-section .featured-card-author{font-size:.8rem}.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;max-width:1100px;margin:0 auto;padding:0 12px}.featured-grid .featured-card{cursor:pointer;max-width:none;height:100%}.featured-grid .featured-card:hover{box-shadow:0 12px 32px #8b1a2b2e;border-color:var(--color-accent);transform:translateY(-3px)}@media(max-width:768px){.featured-title{font-size:2.2rem;margin-bottom:20px}.carousel-rotate{gap:8px;min-height:300px}.carousel-rotate-item{flex:0 0 8rem}.carousel-center .featured-card{max-width:220px;padding:16px}.carousel-left .featured-card,.carousel-right .featured-card{max-width:140px;padding:10px}}@media(max-width:480px){.carousel-rotate-item.carousel-left,.carousel-rotate-item.carousel-right{display:none}.carousel-rotate-item.carousel-center{flex:0 0 14rem;transform:none}.carousel-center .featured-card{max-width:240px}}.bom-section{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:18px;box-sizing:border-box}.bom-campaign-title{font-size:1.1rem;font-weight:700;color:var(--color-text);margin:0;text-align:center}.bom-more-btn{align-self:center;background:none;border:1.5px solid var(--color-accent-border);color:var(--color-accent);font-size:.88rem;font-weight:700;cursor:pointer;padding:8px 20px;border-radius:999px;transition:background .15s ease,border-color .15s ease}.bom-more-btn:hover{background:var(--color-accent-soft);border-color:var(--color-accent)}.bom-modal-overlay{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.bom-modal{background:#fff;border-radius:20px;padding:28px;max-width:520px;width:100%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 24px 64px #0003;display:flex;flex-direction:column;gap:16px}.bom-modal-close{position:absolute;top:16px;right:16px;background:#f0e8ea;border:none;border-radius:50%;width:32px;height:32px;font-size:1.2rem;cursor:pointer;color:var(--color-accent);display:flex;align-items:center;justify-content:center}.bom-modal-title{font-size:1.2rem;font-weight:800;color:#2c2c2c;margin:0;padding-right:40px}.bom-modal-subtitle{font-size:.8rem;color:#6b6b6b;margin:-8px 0 0}.bom-modal-list{display:flex;flex-direction:column;gap:6px}.bom-modal-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;cursor:pointer;transition:background .15s ease;border:1px solid transparent;background:none;font:inherit;width:100%;text-align:left}.bom-modal-row:hover{background:#faf7f2}.bom-modal-row-winner{background:#faf7f2;border-color:#8b1a2b26}.bom-modal-row-selected{background:#8b1a2b0f;border-color:#8b1a2b40}.bom-modal-rank{font-size:.9rem;font-weight:800;color:#9b9b9b;width:24px;text-align:center;flex-shrink:0}.bom-modal-cover{width:32px;height:48px;object-fit:cover;border-radius:4px;flex-shrink:0}.bom-modal-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.bom-modal-book-title{font-size:.85rem;font-weight:700;color:#2c2c2c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bom-modal-book-author{font-size:.75rem;color:#6b6b6b}.bom-modal-bar-wrap{width:80px;height:7px;background:#f0e8ea;border-radius:999px;overflow:hidden;flex-shrink:0}.bom-modal-bar{height:100%;border-radius:999px}.bom-modal-votes{font-size:.82rem;font-weight:700;color:var(--color-accent);width:24px;text-align:right;flex-shrink:0}@media(max-width:600px){.bom-section{padding:24px 16px 32px}}.vote-page{min-height:60vh}.vote-hero{background:#fff;padding:40px 24px 32px;text-align:center;border-bottom:1px solid rgba(139,26,43,.08)}.vote-hero-content{max-width:640px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:14px}.vote-hero-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#8b1a2b}.vote-title{font-size:2.2rem;font-weight:800;color:#2c2c2c;margin:0;line-height:1.2}.vote-countdown{font-size:1rem;color:#5a5a5a;background:#faf7f2;border:1px solid rgba(139,26,43,.15);border-radius:999px;padding:8px 20px}.vote-success{background:#e8f5e9;border:1px solid #a5d6a7;border-radius:10px;padding:12px 24px;color:#2e7d32;font-size:.95rem;font-weight:600}.vote-error-msg{background:#fee2e2;border:1px solid #fecaca;border-radius:10px;padding:10px 20px;color:#b91c1c;font-size:.9rem}.vote-books-wrap{padding:40px 24px;max-width:1200px;margin:0 auto}.vote-books-row{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;padding-bottom:8px}.vote-card{background:#fff;border:2px solid rgba(139,26,43,.1);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,opacity .25s ease;display:flex;flex-direction:column;width:200px;flex-shrink:0;box-shadow:0 4px 16px #0000000f}.vote-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px #8b1a2b2e;border-color:#8b1a2b}.vote-card-selected{border-color:#8b1a2b;box-shadow:0 0 0 4px #8b1a2b26,0 16px 40px #8b1a2b2e;transform:translateY(-6px)}.vote-card-dimmed{opacity:.5;cursor:default}.vote-cover-wrap{position:relative;width:100%}.vote-cover{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.vote-cover-placeholder{width:100%;aspect-ratio:2/3;background:linear-gradient(135deg,#8b1a2b,#6e1432);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800}.vote-badge{position:absolute;top:10px;right:10px;background:#8b1a2b;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;box-shadow:0 2px 8px #0003}.vote-card-info{padding:14px;display:flex;flex-direction:column;gap:6px;flex:1}.vote-book-title{font-size:.95rem;font-weight:700;color:#2c2c2c;margin:0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vote-book-author{font-size:.82rem;color:#6b6b6b;margin:0}.vote-btn{margin-top:auto;background:#8b1a2b;color:#fff;border:none;padding:10px 0;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s ease;width:100%}.vote-btn:hover{background:#6e1432}.vote-voted-label{margin-top:auto;text-align:center;font-size:.88rem;font-weight:700;color:#8b1a2b;padding:8px 0}.vote-no-campaign{max-width:860px;margin:0 auto;padding:40px 24px;display:flex;flex-direction:column;gap:40px}.vote-no-campaign-inner{text-align:center;padding:40px 24px;background:#faf7f2;border-radius:16px;border:1px dashed rgba(139,26,43,.2)}.vote-no-icon{font-size:2.5rem;margin-bottom:12px}.vote-no-campaign-inner h2{font-size:1.4rem;color:#8b1a2b;margin:0 0 8px}.vote-no-campaign-inner p{color:#6b6b6b;margin:0}.vote-past-results{display:flex;flex-direction:column;gap:48px}.vote-past-during-active{max-width:860px;margin:0 auto;padding:40px 24px;display:flex;flex-direction:column;gap:40px;border-top:1px solid rgba(139,26,43,.08)}.vote-past-title{font-size:1.8rem;font-weight:800;color:#2c2c2c;text-align:center;margin:0 0 8px}.vote-last-result{display:flex;flex-direction:column;gap:24px}.vote-last-header{text-align:center}.vote-last-label{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#8b1a2b;margin-bottom:6px}.vote-last-campaign{font-size:1.6rem;font-weight:800;color:#2c2c2c;margin:0}.podium-wrap{display:flex;align-items:flex-end;justify-content:center;gap:12px;padding:0 16px}.podium-item{display:flex;flex-direction:column;align-items:center;flex:1;max-width:220px}.podium-book{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;padding:8px;border-radius:12px;transition:transform .2s ease;width:100%;background:none;border:none;font:inherit}.podium-book:hover{transform:translateY(-4px)}.podium-medal{font-size:1.8rem}.podium-cover-wrap{width:90px;border-radius:8px;overflow:hidden;box-shadow:0 6px 20px #00000026}.podium-item:nth-child(2) .podium-cover-wrap{width:120px}.podium-cover{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.podium-book-title{font-size:.85rem;font-weight:700;color:#2c2c2c;text-align:center;margin:0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.podium-book-author{font-size:.75rem;color:#6b6b6b;margin:0;text-align:center}.podium-votes{font-size:.8rem;font-weight:700;color:#8b1a2b;margin:0}.podium-block{width:100%;border-radius:8px 8px 0 0;display:flex;align-items:center;justify-content:center;margin-top:8px}.podium-rank{font-size:1.6rem;font-weight:900;color:#0000004d}.podium-rest{margin-top:24px;display:flex;flex-direction:column;gap:8px;max-width:600px;margin-left:auto;margin-right:auto}.podium-rest-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff;border:1px solid rgba(139,26,43,.1);border-radius:10px;cursor:pointer;transition:background .15s ease}.podium-rest-row:hover{background:#faf7f2}.podium-rest-rank{font-size:1rem;font-weight:800;color:#9b9b9b;width:24px;text-align:center;flex-shrink:0}.podium-rest-cover{width:32px;height:48px;object-fit:cover;border-radius:4px;flex-shrink:0}.podium-rest-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.podium-rest-title{font-size:.88rem;font-weight:700;color:#2c2c2c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.podium-rest-author{font-size:.75rem;color:#6b6b6b}.podium-rest-votes{font-size:.82rem;font-weight:700;color:#8b1a2b;flex-shrink:0}.vote-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.vote-modal{background:#fff;border-radius:20px;padding:32px;max-width:480px;width:100%;position:relative;box-shadow:0 24px 64px #0003;display:flex;flex-direction:column;align-items:center;gap:12px;max-height:90vh;overflow-y:auto}.vote-modal-close{position:absolute;top:16px;right:16px;background:#f0e8ea;border:none;border-radius:50%;width:32px;height:32px;font-size:1.2rem;cursor:pointer;color:#8b1a2b;display:flex;align-items:center;justify-content:center}.vote-modal-cover-wrap{width:120px;border-radius:10px;overflow:hidden;box-shadow:0 8px 24px #00000026}.vote-modal-cover{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.vote-modal-title{font-size:1.3rem;font-weight:800;color:#2c2c2c;margin:0;text-align:center}.vote-modal-author{font-size:.9rem;color:#6b6b6b;margin:0}.vote-modal-results{width:100%;display:flex;flex-direction:column;gap:8px;margin-top:8px}.vote-modal-results-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#8b1a2b;margin:0 0 4px}.vote-modal-row{display:flex;align-items:center;gap:10px;font-size:.85rem;padding:6px 8px;border-radius:8px}.vote-modal-row-active{background:#faf7f2;border:1px solid rgba(139,26,43,.15)}.vote-modal-row-title{width:130px;flex-shrink:0;font-weight:600;color:#2c2c2c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vote-modal-bar-wrap{flex:1;height:8px;background:#f0e8ea;border-radius:999px;overflow:hidden}.vote-modal-bar{height:100%;border-radius:999px;transition:width .6s ease}.vote-modal-count{width:24px;text-align:right;font-weight:700;color:#8b1a2b;flex-shrink:0}.vote-loading{text-align:center;padding:100px 24px;color:#5a5a5a}@media(max-width:600px){.vote-title{font-size:1.6rem}.vote-books-row{gap:14px}.vote-card{width:150px}.podium-cover-wrap{width:70px!important}.podium-rank{font-size:1.2rem}}.rings-wrap{max-width:1600px;margin:0;padding:0 8px}.rings{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media(max-width:680px){.rings{grid-template-columns:1fr}}.ring-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;box-shadow:0 2px 10px #8b1b3f0a}.ring{width:140px;height:140px;border-radius:50%;background:conic-gradient(var(--color-accent) calc(var(--p) * 1%),var(--color-accent-soft) 0);display:flex;align-items:center;justify-content:center;flex:none}.ring-inner{width:110px;height:110px;border-radius:50%;background:var(--color-surface);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.ring-num{font-size:2.2rem;font-weight:800;color:var(--color-accent);line-height:1}.ring-unit{font-size:.78rem;color:var(--color-text-faint)}.ring-icon{font-size:1.5rem;margin-top:4px}.ring-title{font-weight:700;font-size:1.1rem;color:var(--color-text)}.ring-sub{font-size:.88rem;color:var(--color-text-muted);line-height:1.35}.catalog-page{--color-leefwereld: #2563eb;--color-leefwereld-soft: rgba(37, 99, 235, .08);--color-leefwereld-border: rgba(37, 99, 235, .18);--toolbar-h: 124px;min-height:100vh;background:var(--color-bg);color:var(--color-text);display:flex;flex-direction:column}.catalog-header{position:relative;z-index:100;background:#fff;border-bottom:1px solid rgba(139,26,43,.1);padding:24px 40px 20px;overflow:visible}.catalog-header-inner{max-width:1280px;margin:0 auto;padding:20px 32px 16px;box-sizing:border-box}.catalog-page--embedded .catalog-header{position:static;background:transparent;border-bottom:none}.catalog-page--embedded .catalog-header-inner{padding:0}.catalog-page--embedded .catalog-body{padding:24px 0 48px}.catalog-header-top{display:flex;align-items:baseline;gap:16px;margin-bottom:16px}.catalog-title{font-size:1.75rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.01em}.catalog-count{font-size:.9rem;color:var(--color-text-muted);font-weight:500}.catalog-content{max-width:1000px;padding:32px 24px;flex:1;width:100%;box-sizing:border-box}.catalog-loading{text-align:center;padding:80px 20px;color:#6b6b6b}.catalog-spinner{width:44px;height:44px;border:3px solid #faf7f2;border-top-color:#8b1a2b;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.catalog-list{display:flex;flex-direction:column;gap:16px;animation:fadeIn .3s ease}.catalog-item{display:flex;flex-direction:column;gap:24px;padding:20px;align-items:flex-start;background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);overflow:hidden;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.catalog-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px #8b1a2b1f}.catalog-item-cover{flex-shrink:0;width:80px;border-radius:8px;overflow:hidden}.catalog-cover-img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.catalog-cover-placeholder{width:100%;aspect-ratio:2/3;background:#8b1a2b;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700}.catalog-item-info{flex:1;min-width:0}.catalog-item-title{font-size:1.1rem;font-weight:700;color:#2c2c2c;margin:0 0 4px;line-height:1.3;display:inline-block}.catalog-item-author{font-size:.9rem;color:#6b6b6b;margin:0 0 8px}.catalog-item-meta{display:flex;gap:16px;font-size:.8rem;color:#9b8b7e;margin-bottom:8px}.catalog-item-description{font-size:.9rem;color:#4a4a4a;line-height:1.5;margin:0 0 10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catalog-item-tags{display:flex;flex-wrap:wrap;gap:6px}.catalog-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;background:#fdf2f4;color:#8b1a2b;border:1px solid rgba(139,26,43,.15)}.catalog-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:40px;padding-bottom:16px}.page-btn{min-width:40px;height:40px;padding:0 12px;border-radius:10px;border:1px solid rgba(139,26,43,.2);background:#fff;color:#2c2c2c;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.page-btn:hover:not(:disabled){background:#fdf2f4;border-color:#8b1a2b;color:#8b1a2b}.page-btn-active{background:#8b1a2b;color:#fff;border-color:#8b1a2b}.page-btn-active:hover{background:#6e1522!important;color:#fff!important}.page-dots{color:#9b8b7e;font-size:1rem;padding:0 4px}.catalog-empty{text-align:center;color:#6b6b6b;padding:80px 20px;font-size:1.1rem}@media(max-width:640px){.catalog-header{padding:24px 20px 12px}.catalog-content{padding:20px 16px}.catalog-item{gap:16px;padding:16px}.catalog-item-cover{width:60px}}.catalog-search-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.catalog-search-wrap{display:flex;align-items:center;background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);padding:9px 14px;flex:1;min-width:220px;max-width:520px;transition:border-color .15s ease,box-shadow .15s ease}.catalog-search-wrap:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.catalog-search-icon{color:var(--color-accent);flex-shrink:0;margin-right:10px}.catalog-search-input{flex:1;border:none;outline:none;font-size:.95rem;color:var(--color-text);background:transparent}.catalog-search-input::placeholder{color:var(--color-text-faint)}.catalog-clear-btn{background:var(--color-accent-soft);border:none;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-accent);font-size:1rem;flex-shrink:0}.catalog-btn{background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);padding:9px 16px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.catalog-btn:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.catalog-btn:disabled{opacity:.4;cursor:not-allowed}.catalog-btn-outline{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.catalog-btn-outline:hover:not(:disabled){background:var(--color-accent-softer);border-color:var(--color-accent);color:var(--color-accent)}.catalog-sort-group{display:flex;align-items:stretch;background:var(--color-accent);border-radius:var(--radius-sm)}.catalog-dropdown{position:relative;display:inline-block}.catalog-dropbtn-sort{background:var(--color-accent);color:#fff;border:none;padding:9px 16px;border-radius:var(--radius-sm) 0 0 var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s ease;white-space:nowrap}.catalog-dropbtn-sort:hover{background:var(--color-accent-hover)}.catalog-direction-btn{background:var(--color-accent);color:#fff;border:none;border-left:1px solid rgba(255,255,255,.25);padding:0 14px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:background .15s ease;display:flex;align-items:center;justify-content:center;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.catalog-direction-btn:hover{background:var(--color-accent-hover)}.catalog-dropdown-content{display:none;position:absolute;left:0;top:calc(100% + 6px);background:var(--color-surface);border-radius:var(--radius);box-shadow:0 12px 32px #0000001f;border:1px solid var(--color-border);min-width:180px;z-index:1001;padding:6px}.catalog-dropdown-open .catalog-dropdown-content{display:block}.catalog-sort-option{width:100%;background:none;border:none;padding:8px 12px;text-align:left;cursor:pointer;color:var(--color-text);font-size:.9rem;font-weight:500;border-radius:6px;transition:background .15s ease}.catalog-sort-option:hover{background:var(--color-accent-soft);color:var(--color-accent)}.catalog-sidebar-toggle{display:none}.catalog-body{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:32px;max-width:1280px;width:100%;margin:0 auto;padding:24px 32px 48px;box-sizing:border-box;flex:1}.catalog-main{min-width:0}.catalog-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.catalog-chip{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border);border-radius:999px;padding:5px 8px 5px 12px;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease}.catalog-chip:hover{background:#8b1b3f24}.catalog-chip-leefwereld{background:var(--color-leefwereld-soft);color:var(--color-leefwereld);border-color:var(--color-leefwereld-border)}.catalog-chip-leefwereld:hover{background:#2563eb24}.catalog-chip-x{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#fff9;font-size:.85rem;line-height:1}.catalog-list{display:grid;gap:22px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));animation:fadeIn .3s ease}.catalog-item:hover{transform:translateY(-3px);box-shadow:0 10px 24px #00000014;border-color:var(--color-accent-border)}.catalog-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.catalog-item-cover{width:100%;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.catalog-cover-img{width:100%;aspect-ratio:2 / 3;object-fit:cover;display:block}.catalog-cover-placeholder{width:100%;aspect-ratio:2 / 3;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:700;letter-spacing:.04em}.catalog-sidebar{position:sticky;top:calc(var(--toolbar-h) + 16px);align-self:start;max-height:calc(100vh - var(--toolbar-h) - 32px);overflow-y:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:18px;box-sizing:border-box}.catalog-sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.catalog-sidebar-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0}.catalog-sidebar-close{display:none;background:transparent;border:none;font-size:1.4rem;color:var(--color-text-muted);cursor:pointer;padding:4px 8px;border-radius:6px}.catalog-sidebar-close:hover{background:var(--color-accent-soft);color:var(--color-accent)}.catalog-sidebar-section{padding:10px 0;border-top:1px solid var(--color-border)}.catalog-sidebar-section:first-of-type{border-top:none;padding-top:0}.catalog-sidebar-label{display:block;font-size:.78rem;font-weight:700;color:var(--color-text);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.catalog-sidebar-hint{display:block;font-size:.72rem;color:var(--color-text-faint);margin-top:4px}.catalog-filter-input,.catalog-filter-select{width:100%;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;color:var(--color-text);background:var(--color-surface);box-sizing:border-box;font-family:inherit}.didactic-label{display:inline-block;margin-right:1rem}.catalog-filter-didactic{display:inline;border-radius:var(--radius-sm);box-sizing:border-box}.catalog-filter-input:focus,.catalog-filter-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.catalog-pages-row{display:flex;align-items:center;gap:8px}.catalog-pages-row .catalog-filter-input{flex:1}.catalog-pages-sep{color:var(--color-text-faint);font-weight:600}.catalog-sidebar-section details>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;font-weight:700;color:var(--color-text);text-transform:uppercase;letter-spacing:.04em;padding:4px 0;-webkit-user-select:none;user-select:none}.catalog-sidebar-section details>summary::-webkit-details-marker{display:none}.catalog-sidebar-section details>summary:after{content:"▸";color:var(--color-text-muted);font-size:.85rem;transition:transform .18s ease}.catalog-sidebar-section details[open]>summary:after{transform:rotate(90deg)}.catalog-tag-list{margin-top:8px;max-height:240px;overflow-y:auto;padding-right:4px}.catalog-tag-row{display:flex;align-items:center;gap:8px;padding:5px 0}.catalog-tag-row input[type=checkbox]{accent-color:var(--color-accent);width:16px;height:16px;cursor:pointer}.catalog-tag-row label{font-size:.88rem;color:var(--color-text);cursor:pointer;flex:1}.catalog-tag-count{margin-left:auto;font-size:.72rem;font-weight:600;color:var(--color-text-muted);background:var(--color-bg);border-radius:10px;padding:1px 8px;min-width:22px;text-align:center}.catalog-tag-empty{color:var(--color-text-faint);font-size:.85rem;margin:8px 0}.catalog-sidebar-backdrop{display:none}.catalog-loading{text-align:center;padding:80px 20px;color:var(--color-text-muted)}.catalog-spinner{width:44px;height:44px;border:3px solid var(--color-bg);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.catalog-empty{text-align:center;color:var(--color-text-muted);padding:80px 20px;font-size:1.05rem;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius)}.catalog-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:32px}.page-btn{min-width:38px;height:38px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.92rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.page-btn:hover:not(:disabled){background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-btn-active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.page-btn-active:hover{background:var(--color-accent-hover)!important;color:#fff!important;border-color:var(--color-accent-hover)!important}.page-nav{font-size:1.2rem}.page-dots{color:var(--color-text-faint);font-size:1rem;padding:0 4px}@media(max-width:1023px){.catalog-body{grid-template-columns:minmax(0,1fr);padding:20px 24px 40px}.catalog-sidebar-toggle{display:inline-flex}.catalog-sidebar{position:fixed;top:0;right:0;height:100vh;max-height:100vh;width:min(340px,90vw);border-radius:0;border:none;border-left:1px solid var(--color-border);transform:translate(100%);transition:transform .25s ease;z-index:200;box-shadow:-8px 0 24px #00000014}.catalog-sidebar--open{transform:translate(0)}.catalog-sidebar-close{display:inline-flex}.catalog-sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000059;z-index:150}.catalog-sidebar-backdrop--open{display:block}}@media(max-width:640px){.catalog-header{padding:16px 18px 12px}.catalog-header-top{margin-bottom:12px}.catalog-title{font-size:1.45rem}.catalog-search-wrap{flex-basis:100%;max-width:none}.catalog-body{padding:16px}.catalog-list{gap:14px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.catalog-item-body{padding:10px 12px 12px}.catalog-item-title{font-size:.9rem}}.catalog-didactic{display:inline-block;align-self:flex-start;margin-top:4px;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border)}.catalog-availability{display:inline-block;margin-top:6px;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:600}.catalog-availability--ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.catalog-availability--none{background:#f9fafb;color:var(--color-text-muted);border:1px solid var(--color-border)}.review-section{margin-top:20px}.review-section h4{font-size:1rem;font-weight:700;color:#2c2c2c;margin:0 0 12px}.average-rating{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding:12px;background:#fff9f0;border-radius:8px;border:1px solid #ffd700}.rating-value{font-weight:600;color:#2c2c2c;font-size:.9rem}.review-cards{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;max-height:300px;overflow-y:auto}.no-reviews{color:#6b6b6b;font-style:italic;font-size:.9rem}.review-form{display:flex;flex-direction:column;gap:12px;padding:16px;background:#faf7f2;border-radius:10px;border:1px solid rgba(139,26,43,.1)}.rating-selector{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#2c2c2c;font-weight:600}.star{color:#ddd;font-size:1.4rem}.stars.small .star{font-size:1rem}.star.clickable{cursor:pointer;background:none;border:none;padding:0;transition:transform .15s ease,color .15s ease;font-size:1.6rem}.star.clickable:hover{transform:scale(1.2);color:#ffed4e}.review-textarea{padding:10px 14px;border:1px solid rgba(139,26,43,.2);border-radius:8px;font-size:.9rem;font-family:inherit;max-height:120px;min-height:80px;overflow-y:auto;resize:none}.review-textarea:focus{outline:none;border-color:#8b1a2b}.review-submit-btn{padding:12px 20px;border-radius:10px;border:none;font-size:.95rem;font-weight:600;background:#8b1a2b;color:#fff;cursor:pointer;transition:background .2s ease;align-self:flex-start}.review-submit-btn:hover:not(:disabled){background:#6e1522}.review-submit-btn:disabled{background:#ccc;cursor:not-allowed}.review-avatar{width:40px;height:40px;border-radius:50%;background:#8b1a2b;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;flex-shrink:0}.review-card p{margin:4px 0 0;font-size:.9rem;color:#6b6b6b;line-height:1.4}.notification{position:fixed;top:80px;right:24px;padding:16px 24px;border-radius:12px;font-size:.95rem;font-weight:600;box-shadow:0 8px 24px #00000026;z-index:3000;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.notification.success{background:#276749;color:#fff}.notification.error{background:#9b1c1c;color:#fff}.quick-rating-section{padding:16px;background:#fff9f0;border-radius:10px;border:2px solid #ffd700;margin-bottom:20px;text-align:center}.quick-rating-section h4{font-size:1rem;font-weight:600;color:#2c2c2c;margin:0 0 12px}.quick-rating-stars{display:flex;justify-content:center;gap:8px}.quick-rating-stars .star{font-size:2rem}.review-card-content{flex:1}.review-card-actions{display:flex;align-items:flex-start;padding-top:4px}.review-report-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px;border-radius:6px;opacity:.5;transition:opacity .2s ease,background .2s ease}.review-report-btn:hover{opacity:1;background:#f443361a}.form-stars{display:flex;gap:4px}.report-overlay{position:fixed;inset:0;background:#00000080;z-index:4000;display:flex;align-items:center;justify-content:center;border:none;padding:0;margin:0;max-width:none;max-height:none;width:100vw;height:100vh;color:inherit}.report-overlay::backdrop{background:transparent}.report-modal{background:#fff;border-radius:14px;padding:24px;width:380px;max-width:90vw;box-shadow:0 16px 48px #0003}.report-modal h4{margin:0 0 6px;font-size:1.1rem;color:#2c2c2c}.report-subtitle{font-size:.9rem;color:#6b6b6b;margin:0 0 16px}.report-reasons{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.report-reason{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;border:1px solid #e0e0e0;cursor:pointer;font-size:.9rem;transition:border-color .2s ease,background .2s ease}.report-reason input{accent-color:#8b1a2b}.report-reason.selected{border-color:#8b1a2b;background:#8b1a2b0d}.report-textarea{width:100%;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:.9rem;font-family:inherit;resize:vertical;box-sizing:border-box;margin-bottom:12px}.report-error{color:#f44336;font-size:.85rem;margin:0 0 10px}.report-actions{display:flex;gap:10px;justify-content:flex-end}.report-cancel-btn{padding:10px 18px;border-radius:8px;border:1px solid #e0e0e0;background:#fff;cursor:pointer;font-size:.9rem;font-weight:600}.report-submit-btn{padding:10px 18px;border-radius:8px;border:none;background:#8b1a2b;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s ease}.report-submit-btn:hover:not(:disabled){background:#6e1522}.report-submit-btn:disabled{background:#ccc;cursor:not-allowed}.review-delete-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px;border-radius:6px;opacity:.5;transition:opacity .2s ease,background .2s ease}.review-delete-btn:hover:not(:disabled){opacity:1;background:#f443361a}.review-delete-btn:disabled{cursor:not-allowed;opacity:.3}.review-already-notice{font-size:.85rem;color:#8b1a2b;background:#fdf2f4;border-radius:8px;padding:8px 12px;margin:0}.review-card-verborgen{opacity:.6;border:1px dashed rgba(139,26,43,.3);background:#f5f5f5}.review-verborgen-melding{font-size:.8rem;color:#8b1a2b;font-style:italic;margin:4px 0 0}.moderatie-acties{display:flex;flex-direction:column;gap:4px}.review-moderatie-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px;border-radius:6px;opacity:.5;transition:opacity .2s ease,background .2s ease}.review-moderatie-btn:hover:not(:disabled){opacity:1;background:#8b1a2b1a}.review-moderatie-btn:disabled{cursor:not-allowed;opacity:.2}.review-moderatie-btn.verwijder:hover{background:#f443361a}.moderatie-dropdown-wrapper{position:relative}.review-moderatie-toggle{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px;border-radius:6px;opacity:.5;transition:opacity .2s ease,background .2s ease}.review-moderatie-toggle:hover{opacity:1;background:#0000000d}.moderatie-dropdown{position:absolute;right:0;top:100%;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:100;min-width:140px;overflow:hidden}.moderatie-dropdown-item{display:block;width:100%;padding:10px 16px;border:none;background:none;text-align:left;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s ease;color:#2c2c2c}.moderatie-dropdown-item:hover:not(:disabled){background:#f5f5f5}.moderatie-dropdown-item:disabled{color:#bbb;cursor:not-allowed}.moderatie-dropdown-item.verwijder{color:#c0392b}.moderatie-dropdown-item.verwijder:hover{background:#c0392b14}.review-card-reported{opacity:.5;border:1px dashed #8b1a2b}.review-hidden-content{opacity:.4;font-style:italic}.bevestiging-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.bevestiging-modal{background:#fff;border-radius:14px;padding:28px 32px;max-width:380px;width:90%;box-shadow:0 8px 32px #00000026;text-align:center}.bevestiging-modal p{font-size:1rem;color:#2c2c2c;font-weight:600;margin-bottom:20px}.bevestiging-acties{display:flex;gap:12px;justify-content:center}.bevestiging-annuleer{background:#f0ebe3;color:#2c2c2c;border:none;border-radius:8px;padding:9px 20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease}.bevestiging-annuleer:hover{background:#e0d9d0}.bevestiging-bevestig{background:#8b1a2b;color:#fff;border:none;border-radius:8px;padding:9px 20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease}.bevestiging-bevestig:hover{background:#6e1422}.bevestiging-bevestig.negeer{background:#3949ab}.bevestiging-bevestig.negeer:hover{background:#2c3a9a}.bevestiging-bevestig.verberg{background:#3949ab}.bevestiging-bevestig.verberg:hover{background:#2c3a9a}.modal-content{background:#fff;border-radius:16px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 48px #0003;position:relative;animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-body{display:grid;grid-template-columns:200px 1fr;gap:28px;padding:28px}.modal-cover{border-radius:10px;overflow:hidden;position:sticky;top:28px}.modal-cover img,.modal-cover-placeholder{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.modal-cover-placeholder{background:#8b1a2b;color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;letter-spacing:.05em}.modal-author{font-size:1rem;color:#6b6b6b;margin:0 0 12px}.modal-meta{display:flex;flex-wrap:wrap;gap:12px 20px;font-size:.9rem;color:#6b6b6b;margin-bottom:12px}.modal-genres{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.modal-description{font-size:.95rem;line-height:1.55;color:#2c2c2c;margin:0 0 16px}.modal-rating{margin-bottom:20px}@media(max-width:640px){.modal-body{grid-template-columns:1fr}.modal-cover{position:static;max-width:180px;margin:0 auto}.page-title{font-size:1.4rem}}.modal-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.rating-label{font-size:.85rem;font-weight:600;color:#8b1a2b;margin-right:8px}.rating-value{font-size:.85rem;color:#6b6b6b;margin-left:6px}.stars{display:inline-flex;gap:2px}.star{color:#ddd;font-size:1.2rem}.star-filled{color:gold}.stars.small .star{font-size:.9rem}.modal-reviews h4{font-size:1rem;font-weight:700;color:#2c2c2c;margin:0 0 12px}.review-cards{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.review-card{display:flex;gap:12px;padding:12px;background:#faf7f2;border-radius:10px;border:1px solid rgba(139,26,43,.1)}.review-avatar{width:40px;height:40px;border-radius:50%;background:#8b1a2b;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.review-card strong{display:block;font-size:.9rem;color:#2c2c2c;margin-bottom:4px}.review-card .review-input-wrap{display:flex;gap:8px;margin-bottom:20px}.review-input{flex:1;padding:10px 14px;border:1px solid rgba(139,26,43,.2);border-radius:8px;font-size:.9rem;background:#f5f5f5;color:#999}.review-submit{padding:10px 16px;border-radius:8px;border:none;font-size:.85rem;font-weight:600;background:#ccc;color:#666;cursor:not-allowed}.modal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}.btn-ontlenen{padding:12px 24px;border-radius:10px;border:none;font-size:.95rem;font-weight:600;background:#8b1a2b;color:#fff;cursor:pointer;transition:background .2s ease}.btn-verlanglijst{padding:12px 24px;border-radius:10px;border:2px solid #8b1a2b;font-size:.95rem;font-weight:600;color:#8b1a2b;cursor:pointer;transition:background .2s ease,color .2s ease}.btn-verlanglijst:hover{background:#8b1a2b14}.isWishlisted{background-color:transparent}.isNotWishlisted{background-color:#8b1a2b;color:#fff}.isWishlisted:hover,.isNotWishlisted:hover{background:#fdcfd5;color:#8b1a2b}.modal-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.modal-edit-btn{background:none;border:1px solid #ddd;border-radius:8px;padding:4px 10px;cursor:pointer;font-size:16px;flex-shrink:0}.modal-edit-btn:hover{background:#f0f0f0}@media(max-width:640px){.modal-body{grid-template-columns:1fr}.modal-cover{position:static;max-width:180px;margin:0 auto}}.modal-topbar{padding:16px 28px 0}.modal-back-btn{background:none;border:none;font-size:.9rem;font-weight:600;color:#8b1a2b;cursor:pointer;padding:6px 0;display:flex;align-items:center;gap:6px;transition:opacity .2s ease}.modal-back-btn:hover{opacity:.7}.btn-book-tips{padding:12px 20px;border-radius:10px;border:none;font-size:.95rem;font-weight:600;background:#8b1a2b;color:#fff;cursor:pointer;transition:background .2s ease;align-self:flex-start}.modal-availability{display:inline-block;margin-bottom:8px;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:600}.modal-availability--ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.modal-availability--none{background:#f9fafb;color:#6b6b6b;border:1px solid #ececec}.btn-book-tips:hover{background:#6e1522}.btn-preview{padding:12px 20px;border-radius:10px;border:none;font-size:.95rem;font-weight:600;background:#8b1a2b;color:#fff;cursor:pointer;transition:background .2s ease;align-self:flex-start;text-decoration:none;display:inline-flex;align-items:center;gap:6px}.btn-preview:hover{background:#6e1522}.modal-top-actions{display:flex;gap:8px;margin-bottom:8px}.book-preview-section{margin:16px 0;border-radius:12px;overflow:hidden;border:1px solid var(--color-border, #e0e0e0);background:linear-gradient(135deg,#1a0a0f,#2d0f1a,#1a0a0f);box-shadow:0 8px 32px #8b1a2b4d}.book-preview-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;background:#8b1a2b66;border-bottom:1px solid rgba(255,255,255,.1)}.book-preview-title{color:#fff;font-size:.95rem;font-weight:600;display:flex;align-items:center;gap:8px}.book-preview-stars{color:gold;letter-spacing:2px;font-size:.8rem}.book-preview-viewer{padding:0}.preview-modal-overlay{position:fixed;inset:0;z-index:9999;background:#000000bf;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}.preview-modal-box{width:100%;max-width:982px;height:94vh;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 64px #00000080;animation:slideUp .25s ease}.preview-modal-header{background:linear-gradient(135deg,#8b1a2b,#a0222f);padding:14px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.preview-modal-title{color:#fff;font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.preview-modal-close{background:#00000059;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;padding:6px 14px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.preview-modal-close:hover{background:#ffffff47}.favorite-btn{position:absolute;right:2rem;top:5.5rem;background:transparent;border:none;padding:4px;cursor:pointer;line-height:0}.favorite-icon{width:2.5rem;height:2.5rem;fill:none;stroke:var(--color-accent, #8b1b3f);stroke-width:1.8;transition:fill .15s ease,transform .1s ease}.favorite-btn.is-favorited .favorite-icon{fill:var(--color-accent, #8b1b3f)}.favorite-btn:hover .favorite-icon{transform:scale(1.08)}.modal-schools{display:flex;flex-direction:column;gap:4px;margin-top:8px}.modal-schools-label{font-size:.85rem;font-weight:600;color:var(--color-text-muted, #666);text-transform:uppercase;letter-spacing:.04em}.modal-schools-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}.modal-schools-list li{background:var(--color-accent-light, #f5e6eb);color:var(--color-accent, #8b1b3f);border-radius:12px;padding:3px 10px;font-size:.82rem;font-weight:500}.management-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:50}.management-nav-inner{max-width:1280px;margin:0 auto;padding:0 32px;display:flex;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none}.management-nav-inner::-webkit-scrollbar{display:none}.management-nav-link{position:relative;padding:16px 14px 14px;font-size:.9rem;font-weight:600;color:var(--color-text-muted);text-decoration:none;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s ease,border-color .15s ease}.management-nav-link:hover{color:var(--color-text)}.management-nav-link.is-active{color:var(--color-accent);border-bottom-color:var(--color-accent)}@media(max-width:640px){.management-nav-inner{padding:0 18px}.management-nav-link{padding:14px 10px 12px;font-size:.85rem}}.management{margin-left:0;min-height:100vh;background:var(--color-bg);color:var(--color-text)}.management-page-header{max-width:1280px;margin:0 auto;padding:28px 32px 16px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.management-page-title{font-size:1.6rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.01em}.management-page-subtitle{font-size:.9rem;color:var(--color-text-muted);margin:4px 0 0}.management-page-titlewrap{min-width:0}.management-page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.management-btn{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);padding:9px 16px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;font-family:inherit}.management-btn:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.management-btn:disabled{opacity:.4;cursor:not-allowed}.management-btn-outline{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.management-btn-outline:hover:not(:disabled){background:var(--color-accent-softer);border-color:var(--color-accent);color:var(--color-accent)}.management-btn-danger{background:var(--color-surface);color:var(--color-danger);border-color:var(--color-border)}.management-btn-danger:hover:not(:disabled){background:var(--color-danger-soft);border-color:var(--color-danger);color:var(--color-danger)}.management-btn-icon{width:16px;height:16px;flex-shrink:0}.management-content{max-width:1280px;margin:0 auto;padding:0 32px 48px}@media(max-width:640px){.management-page-header{padding:20px 18px 12px}.management-content{padding:0 18px 32px}.management-page-title{font-size:1.35rem}}.school-message{background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:.9rem;margin-bottom:16px}.school-list{list-style:none;margin:0;padding:0;display:grid;gap:12px}.school-item{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:16px 20px;transition:border-color .15s ease,box-shadow .15s ease}.school-item:hover{border-color:var(--color-accent-border);box-shadow:0 4px 12px #0000000a}.school-item-info{min-width:0;flex:1}.school-item-name{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0 0 4px;line-height:1.3}.school-item-url{font-size:.85rem;color:var(--color-text-muted);margin:0;word-break:break-all}.school-item-actions{display:flex;gap:8px;flex-shrink:0}.school-empty{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius)}.selected{background-color:#f0f8ff;color:#000}@media(max-width:640px){.school-item{flex-direction:column;align-items:flex-start;padding:14px 16px}.school-item-actions{width:100%;justify-content:flex-end}}.delete-popup-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.delete-popup{background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);width:380px;overflow:hidden}.delete-popup-header{background:#fcebeb;border-bottom:1px solid #f7c1c1;padding:20px 24px 16px}.delete-popup-header-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.delete-popup-icon{width:32px;height:32px;border-radius:50%;background:#f09595;display:flex;align-items:center;justify-content:center;flex-shrink:0}.delete-popup-title{font-size:.95rem;font-weight:700;color:#501313;margin:0}.delete-popup-subtitle{font-size:.82rem;color:#791f1f;margin:0;line-height:1.5}.delete-popup-body{padding:20px 24px}.delete-popup-school-card{background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:12px 16px;margin-bottom:16px}.delete-popup-school-label{font-size:.7rem;color:var(--color-text-muted);margin:0 0 3px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.delete-popup-school-name{font-size:.9rem;color:var(--color-text);margin:0;font-weight:600}.delete-popup-warning{font-size:.82rem;color:var(--color-text-muted);margin:0 0 20px;line-height:1.6}.delete-popup-actions{display:flex;gap:10px}.delete-popup-btn-cancel{flex:1;padding:9px 16px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s ease}.delete-popup-btn-cancel:hover{background:var(--color-bg)}.delete-popup-btn-delete{flex:1;padding:9px 16px;border-radius:var(--radius-sm);border:1px solid #f09595;background:#fcebeb;color:#a32d2d;font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s ease}.delete-popup-btn-delete:hover{background:#f7c1c1}.add-school-form{display:flex;flex-direction:column;gap:20px;max-width:720px}.add-school-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:24px 28px;display:flex;flex-direction:column;gap:1.1rem}.add-school-section-header{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.add-school-section-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.005em}.add-school-section-hint{font-size:.82rem;color:var(--color-text-muted);margin:0;line-height:1.45}.add-school-code{display:inline-block;margin-top:6px;padding:6px 10px;background:var(--color-accent-softer);border:1px solid var(--color-accent-border);border-radius:var(--radius-sm);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;color:var(--color-accent);word-break:break-all}.add-school-field{display:flex;flex-direction:column;gap:.4rem}.add-school-field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}.add-school-label{font-size:.78rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}.add-school-required{color:var(--color-accent);margin-left:2px}.add-school-input{padding:.65rem .875rem;font-size:.95rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit;width:100%;box-sizing:border-box}.add-school-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.add-school-input::placeholder{color:var(--color-text-faint)}.add-school-input-hint{font-size:.76rem;color:var(--color-text-muted);margin:0;line-height:1.4}.add-school-footer{display:flex;align-items:center;justify-content:flex-end;gap:.875rem;flex-wrap:wrap;padding:16px 0 0}.add-school-message-success,.add-school-message-error{flex:1;margin:0;font-size:.875rem;border-radius:var(--radius-sm);padding:.6rem .875rem}.add-school-message-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.add-school-message-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}@media(max-width:640px){.add-school-section{padding:20px 18px}.add-school-field-row{grid-template-columns:1fr}}.select-managers-panel{display:flex;flex-direction:column;gap:16px;max-width:720px}.select-managers-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.select-managers-search{flex:1;min-width:220px;padding:.6rem .875rem;font-size:.95rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit}.select-managers-search:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.select-managers-search::placeholder{color:var(--color-text-faint)}.select-managers-count{font-size:.82rem;color:var(--color-text-muted);white-space:nowrap}.select-managers-list{list-style:none;margin:0;display:grid;gap:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px;max-height:520px;overflow-y:auto}.select-managers-item{display:block}.select-managers-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s ease;border:1px solid transparent}.select-managers-row:hover{background:var(--color-accent-softer)}.select-managers-row.is-selected{background:var(--color-accent-soft);border-color:var(--color-accent-border)}.select-managers-checkbox{width:18px;height:18px;accent-color:var(--color-accent);flex-shrink:0}.select-managers-person{display:flex;flex-direction:column;gap:2px;min-width:0}.select-managers-name{font-weight:600;color:var(--color-text);font-size:.93rem;line-height:1.25}.select-managers-email{font-size:.8rem;color:var(--color-text-muted);word-break:break-all}.select-managers-empty{text-align:center;color:var(--color-text-muted);padding:40px 20px;font-size:.9rem}.select-managers-status{margin:0;font-size:.9rem;padding:.7rem .9rem;border-radius:var(--radius-sm)}.select-managers-status.is-loading{background:var(--color-accent-softer);color:var(--color-text-muted);border:1px solid var(--color-border)}.select-managers-status.is-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.select-managers-status.is-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.select-managers-footer{display:flex;align-items:center;justify-content:flex-end;gap:.875rem;flex-wrap:wrap;padding-top:8px}.select-managers-footer-spacer{flex:1;font-size:.85rem;color:var(--color-text-muted)}@media(max-width:640px){.select-managers-list{max-height:60vh}}.tag-message{background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:.9rem;margin:0 0 18px}.tag-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.tag-column{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:18px 20px;display:flex;flex-direction:column;gap:12px;min-width:0}.tag-column-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.tag-column-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0}.tag-column-count{font-size:.78rem;color:var(--color-text-muted);font-weight:500}.tag-grid{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}.tag-pill{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border);border-radius:999px;padding:5px 6px 5px 12px;font-size:.85rem;font-weight:600}.tag-pill-name{line-height:1.2}.tag-pill-remove{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#fff9;border:none;color:var(--color-accent);font-size:.95rem;line-height:1;cursor:pointer;transition:background .15s ease,color .15s ease;padding:0}.tag-pill-remove:hover{background:var(--color-accent);color:#fff}.tag-empty{font-size:.85rem;color:var(--color-text-faint);margin:0;padding:8px 0}@media(max-width:768px){.tag-columns{grid-template-columns:minmax(0,1fr)}}.warning-popup{position:fixed;top:10rem;left:10rem;height:22rem;width:25rem;background-color:#fff;border-radius:1rem;padding:1rem;justify-items:center;box-shadow:0 0 1rem 1rem #00000014}.warning-title{color:red;font-size:2rem;font-weight:700;border:.3rem solid red;padding:1rem;border-radius:1rem}.popup-question{font-size:2rem;font-weight:700;margin:0}.popup-buttons{display:flex;width:25rem}.btn-go-back,.btn-delete-confirm{margin:1rem;padding:1rem;font-size:1rem;width:100%;border-radius:1rem;border:.2rem solid #8b1a2b;font-weight:700;color:#fff;background-color:#8b1a2b}.btn-go-back:hover,.btn-delete-confirm:hover{background-color:#fdcfd5;color:#8b1a2b}.add-tag-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:28px 32px;display:flex;flex-direction:column;gap:1.25rem;max-width:640px}.add-tag-field{display:flex;flex-direction:column;gap:.4rem}.add-tag-label{font-size:.78rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}.add-tag-required{color:var(--color-accent);margin-left:2px}.add-tag-input,.add-tag-select{padding:.65rem .875rem;font-size:.95rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit;width:100%;box-sizing:border-box}.add-tag-input:focus,.add-tag-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.add-tag-input::placeholder{color:var(--color-text-faint)}.add-tag-radio-group{display:flex;gap:8px;flex-wrap:wrap}.add-tag-radio{flex:1;min-width:140px;position:relative}.add-tag-radio input{position:absolute;opacity:0;pointer-events:none}.add-tag-radio-label{display:flex;flex-direction:column;gap:2px;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:var(--color-surface);transition:border-color .15s ease,background .15s ease}.add-tag-radio-label:hover{border-color:var(--color-accent);background:var(--color-accent-softer)}.add-tag-radio input:checked+.add-tag-radio-label{border-color:var(--color-accent);background:var(--color-accent-soft)}.add-tag-radio-name{font-weight:700;color:var(--color-text);font-size:.92rem}.add-tag-radio input:checked+.add-tag-radio-label .add-tag-radio-name{color:var(--color-accent)}.add-tag-radio-hint{font-size:.78rem;color:var(--color-text-muted)}.add-tag-footer{display:flex;align-items:center;justify-content:flex-end;gap:.875rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid var(--color-border)}.add-tag-message-success,.add-tag-message-error{flex:1;margin:0;font-size:.875rem;border-radius:var(--radius-sm);padding:.6rem .875rem}.add-tag-message-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.add-tag-message-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.detail-page{background:var(--color-bg);color:var(--color-text);min-height:calc(100vh - 80px)}.detail-page-inner{max-width:1280px;width:100%;margin:0 auto;padding:24px 32px 48px;box-sizing:border-box}.detail-back{display:inline-flex;align-items:center;gap:6px;font-size:.88rem;font-weight:600;color:var(--color-text-muted);text-decoration:none;margin-bottom:16px;background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.detail-back:hover{color:var(--color-accent)}.detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:18px;border-bottom:1px solid var(--color-border);margin-bottom:24px}.detail-title{font-size:1.8rem;font-weight:700;color:var(--color-text);margin:0 0 6px;letter-spacing:-.01em;word-break:break-word}.detail-description{font-size:.95rem;color:var(--color-text-muted);margin:0 0 6px;line-height:1.5}.detail-author{font-size:.82rem;color:var(--color-text-faint);margin:0}.detail-actions{display:flex;gap:8px;flex-shrink:0}.detail-btn{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);padding:9px 16px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;font-family:inherit}.detail-btn:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.detail-btn:disabled{opacity:.4;cursor:not-allowed}.detail-btn-outline{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.detail-btn-outline:hover:not(:disabled){background:var(--color-accent-softer);border-color:var(--color-accent);color:var(--color-accent)}.detail-btn-danger{background:var(--color-surface);color:var(--color-danger);border-color:var(--color-border)}.detail-btn-danger:hover:not(:disabled){background:var(--color-danger-soft);border-color:var(--color-danger)}.detail-btn-icon{width:16px;height:16px;flex-shrink:0}.detail-body{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:32px;align-items:start}@media(max-width:1023px){.detail-body{grid-template-columns:1fr}}.detail-section-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 12px}.detail-books-grid{display:grid;gap:22px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.detail-book-wrap{position:relative}.detail-book-remove{position:absolute;top:8px;right:8px;z-index:2;background:#000000a6;color:#fff;border:none;border-radius:999px;padding:4px 10px;font-size:.72rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s ease}.detail-book-remove:hover{background:var(--color-danger)}.detail-empty{text-align:center;color:var(--color-text-muted);padding:48px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);font-size:.95rem}.detail-sidebar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:18px}.detail-sidebar-section{display:flex;flex-direction:column;gap:10px}.detail-sidebar-section+.detail-sidebar-section{padding-top:18px;border-top:1px solid var(--color-border)}.detail-add-row{display:flex;gap:8px}.detail-input{flex:1;width:100%;padding:.55rem .8rem;font-size:.9rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit;box-sizing:border-box}.detail-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.detail-input::placeholder{color:var(--color-text-faint)}.share-picker{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.share-student-list{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);max-height:240px;overflow-y:auto;display:flex;flex-direction:column}.share-student-row{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;border-bottom:1px solid var(--color-border);transition:background .12s ease}.share-student-row:last-child{border-bottom:none}.share-student-row:hover{background:var(--color-accent-softer)}.share-student-row.is-selected{background:var(--color-accent-soft)}.share-student-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent);flex-shrink:0}.share-student-name{font-size:.88rem;color:var(--color-text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-student-empty{color:var(--color-text-faint);font-size:.85rem;margin:0;padding:16px 12px;text-align:center}.share-picker-actions{display:flex;gap:8px}.share-picker-actions .detail-btn{flex:1;justify-content:center}.share-picker-error{color:var(--color-danger);font-size:.85rem;margin:0}.member-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}.member-pill{display:inline-flex;align-items:center;gap:6px;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:999px;padding:4px 6px 4px 12px;font-size:.82rem;font-weight:600}.member-pill button{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:transparent;border:none;color:var(--color-text-muted);font-size:.95rem;line-height:1;cursor:pointer;padding:0}.member-pill button:hover{background:var(--color-danger);color:#fff}.member-empty{color:var(--color-text-faint);font-size:.85rem;margin:0;font-style:italic}.detail-search-results{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);max-height:220px;overflow-y:auto}.detail-search-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;border-bottom:1px solid var(--color-border);font-size:.85rem}.detail-search-row:last-child{border-bottom:none}.detail-search-row span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-search-row button{background:var(--color-accent);color:#fff;border:none;width:24px;height:24px;border-radius:50%;font-size:1rem;font-weight:700;cursor:pointer;line-height:1;flex-shrink:0}.detail-search-row button:hover{background:var(--color-accent-hover)}.detail-confirm-overlay{position:fixed;inset:0;background:#00000073;z-index:4000;display:flex;align-items:center;justify-content:center;padding:16px}.detail-confirm-modal{background:var(--color-surface);border-radius:var(--radius);padding:24px;width:420px;max-width:100%;box-shadow:0 16px 48px #0000002e}.detail-confirm-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0 0 8px}.detail-confirm-text{font-size:.92rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 20px}.detail-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.detail-loading,.detail-error{text-align:center;padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);color:var(--color-text-muted)}.detail-error{color:var(--color-danger);background:#fef2f2;border-color:#fecaca}.lists-section{padding:4px 0;margin-left:4rem;margin-right:4rem}.lists-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}.lists-title{font-size:1.4rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.01em}.lists-count{font-size:.85rem;color:var(--color-text-muted);font-weight:500;margin-left:10px}.lists-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.list-card{display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:18px 20px 14px;transition:border-color .15s ease,box-shadow .15s ease}.list-card:hover{border-color:var(--color-accent-border);box-shadow:0 4px 14px #0000000d}.list-card-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0 0 4px;line-height:1.3;word-break:break-word}.list-card-author{font-size:.78rem;color:var(--color-text-faint);margin:0 0 10px}.list-card-description{font-size:.88rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.list-card-covers{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}.list-card-cover{aspect-ratio:2/3;border-radius:var(--radius-sm);overflow:hidden;background:var(--color-bg);border:1px solid var(--color-border)}.list-card-cover img{width:100%;height:100%;object-fit:cover;display:block}.list-card-cover-placeholder{width:100%;height:100%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700;text-align:center;padding:4px;word-break:break-word}.list-card-cover-empty{background:var(--color-bg);border:1px dashed var(--color-border)}.list-card-no-books{font-size:.85rem;color:var(--color-text-faint);font-style:italic;padding:12px 0 14px;margin:0;text-align:center}.list-card-link{margin-top:auto;padding-top:10px;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.88rem;font-weight:600;color:var(--color-accent);text-decoration:none;background:none;border-left:none;border-right:none;border-bottom:none;cursor:pointer;font-family:inherit;width:100%;text-align:left}.list-card-link:hover{color:var(--color-accent-hover)}.list-card-link-arrow{font-size:1rem;transition:transform .15s ease}.list-card:hover .list-card-link-arrow{transform:translate(2px)}.user-btn{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);padding:9px 16px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;font-family:inherit}.user-btn:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.user-btn:disabled{opacity:.4;cursor:not-allowed}.user-btn-outline{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.user-btn-outline:hover:not(:disabled){background:var(--color-accent-softer);border-color:var(--color-accent);color:var(--color-accent)}.user-btn-danger{background:var(--color-surface);color:var(--color-danger);border-color:var(--color-border)}.user-btn-danger:hover:not(:disabled){background:var(--color-danger-soft);border-color:var(--color-danger)}.user-btn-icon{width:16px;height:16px;flex-shrink:0}.lists-empty{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);font-size:1rem}.create-overlay{position:fixed;inset:0;background:#00000073;z-index:4000;display:flex;align-items:center;justify-content:center;padding:20px}.create-modal{background:var(--color-surface);border-radius:var(--radius);width:560px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 16px 48px #0000002e;overflow:hidden}.create-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.create-modal-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0}.create-modal-close{background:none;border:none;font-size:1.4rem;color:var(--color-text-muted);cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1}.create-modal-close:hover{background:var(--color-bg);color:var(--color-text)}.create-modal-body{padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}.create-modal-footer{padding:14px 20px;border-top:1px solid var(--color-border);background:var(--color-bg);display:flex;justify-content:flex-end;gap:8px}.field-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:.75rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}.field-input,.field-textarea{width:100%;padding:.6rem .85rem;font-size:.92rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit;box-sizing:border-box}.field-textarea{resize:vertical;min-height:60px;line-height:1.5}.field-input:focus,.field-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.field-input::placeholder,.field-textarea::placeholder{color:var(--color-text-faint)}.add-row{display:flex;gap:8px}.add-row .field-input{flex:1}.pending-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:6px}.pending-pill{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border);border-radius:999px;padding:4px 6px 4px 12px;font-size:.82rem;font-weight:600}.pending-pill button{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#fff9;border:none;color:var(--color-accent);font-size:.9rem;line-height:1;cursor:pointer;padding:0}.pending-pill button:hover{background:var(--color-accent);color:#fff}.search-results{margin-top:6px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);max-height:220px;overflow-y:auto}.search-result-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;border-bottom:1px solid var(--color-border);font-size:.88rem}.search-result-row:last-child{border-bottom:none}.search-result-row span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.search-result-row button{background:var(--color-accent);color:#fff;border:none;width:26px;height:26px;border-radius:50%;font-size:1rem;font-weight:700;cursor:pointer;line-height:1;flex-shrink:0}.search-result-row button:hover{background:var(--color-accent-hover)}.create-error{font-size:.85rem;color:var(--color-danger);background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:8px 12px;margin:0}.create-page{--color-accent: #8b1b3f;--color-accent-hover: #6e1432;--color-accent-soft: rgba(139, 27, 63, .08);--color-accent-softer: rgba(139, 27, 63, .04);--color-accent-border: rgba(139, 27, 63, .18);--color-bg: #f7f5f2;--color-surface: #ffffff;--color-border: #ececec;--color-text: #1f1f1f;--color-text-muted: #6b6b6b;--color-text-faint: #9b9b9b;--color-danger: #c0392b;--color-danger-soft: rgba(192, 57, 43, .08);--radius: 12px;--radius-sm: 8px;background:var(--color-bg);color:var(--color-text);min-height:calc(100vh - 80px)}.create-page-inner{max-width:1280px;width:100%;margin:0 auto;padding:24px 32px 48px;box-sizing:border-box}.create-page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:18px;border-bottom:1px solid var(--color-border);margin-bottom:24px}.create-page-titlewrap{min-width:0}.create-page-title{font-size:1.6rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.01em}.create-page-subtitle{font-size:.9rem;color:var(--color-text-muted);margin:4px 0 0}.create-page-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:28px 32px;display:flex;flex-direction:column;gap:20px;max-width:760px}.create-page-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:18px}.create-page-footer{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;border-top:1px solid var(--color-border)}.check-group{display:flex;flex-direction:row;gap:6px}@media(max-width:640px){.create-page-inner{padding:16px}.create-page-card{padding:20px}}._tagSection_17xzj_3{display:flex;flex-direction:column;gap:1rem;padding:1rem 1.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius)}._fieldGroup_17xzj_13{display:flex;flex-direction:column;gap:.4rem}._label_17xzj_19{font-size:.78rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}._required_17xzj_27{color:var(--color-accent);margin-left:2px}._select_17xzj_32{width:100%;padding:.6rem 2.5rem .6rem .875rem;font-size:.9rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b6b6b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;font-family:inherit}._select_17xzj_32:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}._tagHint_17xzj_56{font-size:.75rem;color:var(--color-text-faint);margin:0}._chipContainer_17xzj_62{display:flex;flex-wrap:wrap;gap:6px}._chip_17xzj_62{padding:5px 12px;font-size:.8rem;font-weight:600;border:1.5px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease;white-space:nowrap;font-family:inherit}._chip_17xzj_62:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-softer)}._chipActive_17xzj_88{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}._chipActive_17xzj_88:hover{background:var(--color-accent-hover);color:#fff;border-color:var(--color-accent-hover)}._panel_wfotg_3{display:flex;flex-direction:column;gap:1.25rem}._formLayout_wfotg_9{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1.75rem;align-items:stretch}._formMain_wfotg_16,._formSide_wfotg_17{display:flex;flex-direction:column;gap:1rem;min-width:0}._formSide_wfotg_17{height:100%}._formSide_wfotg_17>._fieldGroup_wfotg_28{flex:1;display:flex;flex-direction:column}._fieldGroup_wfotg_28{display:flex;flex-direction:column;gap:.4rem}._label_wfotg_40{font-size:.78rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}._input_wfotg_48,._select_wfotg_49{padding:.6rem .875rem;font-size:.92rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit;width:100%;box-sizing:border-box}._input_wfotg_48:focus,._select_wfotg_49:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}._input_wfotg_48::placeholder{color:var(--color-text-faint)}._formGrid_wfotg_73{display:grid;grid-template-columns:1fr 1fr;gap:1rem}._textarea_wfotg_79{resize:vertical;font-family:inherit;line-height:1.5;min-height:110px}._required_wfotg_86{color:var(--color-accent);margin-left:2px}._checkboxRow_wfotg_93{display:inline-flex;align-items:center;gap:10px;cursor:pointer;padding:4px 2px;-webkit-user-select:none;user-select:none;width:fit-content}._checkboxRow_wfotg_93 input[type=checkbox]{accent-color:var(--color-accent);width:18px;height:18px;cursor:pointer;margin:0;flex-shrink:0}._checkboxLabel_wfotg_112{font-size:.92rem;color:var(--color-text);cursor:pointer;font-weight:500}._formFooter_wfotg_121{display:flex;align-items:center;justify-content:flex-end;gap:.875rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid var(--color-border);margin-top:.5rem}._formFooter_wfotg_121 ._messageSuccess_wfotg_132,._formFooter_wfotg_121 ._messageError_wfotg_133{flex:1;margin:0}._messageSuccess_wfotg_132{font-size:.875rem;color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:.6rem .875rem}._messageError_wfotg_133{font-size:.875rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:.6rem .875rem}._btnPrimary_wfotg_156{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease;font-family:inherit}._btnPrimary_wfotg_156:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}._btnPrimary_wfotg_156:disabled{opacity:.5;cursor:not-allowed}._dropzone_wfotg_185{flex:1;position:relative;border:2px dashed var(--color-border);border-radius:var(--radius);padding:1.5rem 1rem;text-align:center;cursor:pointer;background:var(--color-bg);transition:border-color .15s ease,background .15s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem;min-height:240px;justify-content:center;overflow:hidden}._dropzone_wfotg_185:hover{border-color:var(--color-accent);background:var(--color-accent-softer)}._dropzoneActive_wfotg_209{border-color:var(--color-accent);background:var(--color-accent-soft)}._dropzoneFilled_wfotg_214{padding:0;border-style:solid;border-color:var(--color-border);background:var(--color-surface)}._dropzoneFilled_wfotg_214:hover{border-color:var(--color-accent);background:var(--color-surface)}._dropzoneText_wfotg_226{font-size:.9rem;color:var(--color-text);font-weight:500}._dropzoneHint_wfotg_232{font-size:.78rem;color:var(--color-text-faint)}._previewFull_wfotg_237{width:100%;height:100%;object-fit:cover;display:block}._removeBtnFloat_wfotg_244{position:absolute;top:8px;right:8px;background:#000000a6;color:#fff;border:none;border-radius:999px;padding:5px 12px;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s ease;font-family:inherit}._removeBtnFloat_wfotg_244:hover{background:#000000d9}@media(max-width:900px){._formLayout_wfotg_9{grid-template-columns:1fr}}.edit-loading{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius)}.edit-confirm-overlay{position:fixed;inset:0;background:#00000073;z-index:4000;display:flex;align-items:center;justify-content:center;padding:16px}.edit-confirm-modal{background:var(--color-surface);border-radius:var(--radius);padding:24px;width:420px;max-width:100%;box-shadow:0 16px 48px #0000002e}.edit-confirm-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0 0 8px}.edit-confirm-text{font-size:.92rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 20px}.edit-confirm-text strong{color:var(--color-text)}.edit-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.copy-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm, 8px);padding:.6rem 1rem;margin-bottom:1rem;font-size:.875rem}.copy-loading,.copy-empty{color:var(--color-text-muted, #6b6b6b);font-size:.95rem;padding:2rem 0}.copy-empty-hint{font-size:.85rem;color:var(--color-text-faint, #9b9b9b);margin-top:4px}.copy-list{background:var(--color-surface, #fff);border:1px solid var(--color-border, #ececec);border-radius:var(--radius, 12px);overflow:hidden}.copy-list-header,.copy-row{display:grid;grid-template-columns:64px 140px 1fr 44px;align-items:center;gap:12px;padding:10px 16px}.copy-list-header{background:var(--color-bg, #f7f5f2);border-bottom:1px solid var(--color-border, #ececec);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #6b6b6b)}.copy-row{border-bottom:1px solid var(--color-border, #ececec)}.copy-row:last-child{border-bottom:none}.copy-id-badge{font-size:.8rem;font-weight:700;color:var(--color-text-muted, #6b6b6b)}.copy-status{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.copy-status--ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.copy-status--loan{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.copy-status--lost{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.copy-col-condition{display:flex;gap:8px;align-items:center}.copy-status-select,.copy-condition-input{padding:.4rem .6rem;font-size:.875rem;border:1.5px solid var(--color-border, #ececec);border-radius:var(--radius-sm, 8px);background:var(--color-surface, #fff);color:var(--color-text, #1f1f1f);font-family:inherit;outline:none;transition:border-color .15s}.copy-status-select{flex:0 0 auto}.copy-condition-input{flex:1}.copy-status-select:focus,.copy-condition-input:focus{border-color:var(--color-accent, #8b1b3f);box-shadow:0 0 0 3px var(--color-accent-soft, rgba(139, 27, 63, .08))}.copy-status-select:disabled,.copy-condition-input:disabled{opacity:.55;cursor:not-allowed}.copy-delete-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-sm, 8px);background:transparent;color:var(--color-text-muted, #6b6b6b);cursor:pointer;transition:background .15s,color .15s}.copy-delete-btn:hover:not(:disabled){background:#fef2f2;color:#991b1b}.copy-delete-btn:disabled{opacity:.35;cursor:not-allowed}@media(max-width:640px){.copy-list-header{display:none}.copy-row{grid-template-columns:1fr;gap:8px;padding:14px}.copy-col-condition{flex-wrap:wrap}.copy-status-select{flex:1 1 auto}.copy-delete-btn{justify-self:end}}.loan-page-wrapper{max-width:1480px;margin:0 auto;padding:24px 32px 48px}.loan-nav-container{display:inline-flex;gap:4px;padding:4px;background:#f3eee9;border:1px solid #ececec;border-radius:12px;margin-bottom:24px}.loan-link{padding:8px 18px;border-radius:8px;text-decoration:none;color:#6b6b6b;font-weight:600;font-size:.9rem;transition:all .15s ease;border:none}.loan-link:hover{color:#8b1b3f}.loan-link.active{background:#fff;color:#8b1b3f;box-shadow:0 1px 3px #0000000f}@media(max-width:720px){.loan-page-wrapper{padding:16px 16px 32px}}.lsp-stepper{display:flex;align-items:center;gap:0;margin-bottom:24px;padding:14px 20px;background:#fff;border:1px solid #ececec;border-radius:12px;max-width:520px}.lsp-step{display:flex;align-items:center;gap:10px}.lsp-step-circle{width:28px;height:28px;border-radius:50%;border:2px solid #ececec;background:#fff;color:#595959;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.lsp-step--active .lsp-step-circle{border-color:#8b1b3f;background:#8b1b3f;color:#fff}.lsp-step--done .lsp-step-circle{border-color:#16a34a;background:#16a34a;color:#fff}.lsp-step-label{font-size:.85rem;font-weight:600;color:#595959;white-space:nowrap}.lsp-step--active .lsp-step-label{color:#1f1f1f}.lsp-step--done .lsp-step-label{color:#16a34a}.lsp-step-line{flex:1;height:2px;background:#ececec;margin:0 14px}.lsp-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px;align-items:start}.lsp-main{display:flex;flex-direction:column;gap:20px;min-width:0}@media(max-width:980px){.lsp-grid{grid-template-columns:1fr}}.lsp-search-block{position:relative}.lsp-search-row{display:flex;gap:10px}.lsp-input-wrap{flex:1;display:flex;align-items:center;background:#fff;border:1.5px solid #ececec;border-radius:10px;padding:0 16px;transition:all .2s ease}.lsp-input-wrap:focus-within{border-color:#8b1b3f;box-shadow:0 0 0 3px #8b1b3f14}.lsp-input-icon{color:#8b1b3f;margin-right:10px;flex-shrink:0}.lsp-input{flex:1;border:none;background:transparent;padding:14px 0;font-size:1rem;outline:none;color:#1f1f1f;font-family:inherit}.lsp-input::placeholder{color:#9b9b9b}.lsp-btn{background:#8b1b3f;color:#fff;border:none;padding:0 28px;border-radius:10px;font-weight:700;font-size:.95rem;cursor:pointer;transition:background .15s ease;font-family:inherit;white-space:nowrap}.lsp-btn:hover:not(:disabled){background:#6e1432}.lsp-btn:disabled{opacity:.5;cursor:not-allowed}.lsp-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid #ececec;overflow:hidden;z-index:100}.lsp-suggestion{display:flex;align-items:center;gap:14px;padding:12px 16px;cursor:pointer;transition:background .12s ease}.lsp-suggestion:hover{background:#faf7f2}.lsp-suggestion-img{width:36px;height:52px;object-fit:cover;border-radius:4px;flex-shrink:0;border:1px solid #ececec}.lsp-suggestion-title{font-size:.9rem;font-weight:600;color:#1f1f1f;margin:0}.lsp-suggestion-author{font-size:.78rem;color:#9b9b9b;margin:2px 0 0}.lsp-placeholder{display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;border:1px dashed #e0ddd9;border-radius:14px;padding:60px 24px;color:#9b9b9b;gap:8px}.lsp-placeholder-icon{color:#d4cfc7;margin-bottom:4px}.lsp-placeholder-title{font-size:1rem;font-weight:700;color:#6b6b6b;margin:0}.lsp-placeholder-hint{font-size:.85rem;margin:0}.lsp-error{padding:12px 16px;background:#fff5f5;color:#c53030;border-radius:8px;font-size:.9rem;font-weight:500;border:1px solid #fed7d7}.lsp-results-label{font-size:.72rem;font-weight:700;color:#9b9b9b;text-transform:uppercase;letter-spacing:.06em;margin:0 0 12px}.lsp-book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.lsp-book-card{border:1.5px solid #ececec;border-radius:10px;overflow:hidden;cursor:pointer;transition:all .15s ease;background:#fff}.lsp-book-card:hover{border-color:#8b1b3f;transform:translateY(-2px);box-shadow:0 4px 16px #8b1b3f1a}.lsp-book-img{width:100%;height:180px;object-fit:cover;display:block}.lsp-book-info{padding:10px 12px}.lsp-book-title{font-size:.85rem;font-weight:700;color:#1f1f1f;margin:0 0 2px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lsp-book-author{font-size:.75rem;color:#9b9b9b;margin:0}.lsp-user-loans{display:flex;flex-direction:column;gap:10px}.lsp-loan-row{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1px solid #ececec;border-radius:10px;padding:14px 18px}.lsp-loan-info{flex:1;min-width:0}.lsp-loan-title{font-size:.95rem;font-weight:700;color:#1f1f1f;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lsp-loan-due{font-size:.8rem;color:#9b9b9b;margin:0}.lsp-return-btn{background:#fff;color:#8b1b3f;border:1.5px solid #8b1b3f;padding:7px 16px;border-radius:8px;font-size:.83rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s ease;font-family:inherit;flex-shrink:0}.lsp-return-btn:hover{background:#8b1b3f;color:#fff}.blc-wrapper{display:flex;flex-direction:column;gap:28px;animation:blcFadeIn .25s ease}@keyframes blcFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.blc-book-hero{display:flex;gap:24px;align-items:flex-start;background:#faf7f2;border:1px solid #f0ede9;border-radius:16px;padding:24px}.blc-book-hero-cover{width:100px;height:145px;flex-shrink:0;border-radius:8px;overflow:hidden;box-shadow:0 6px 20px #00000026}.blc-hero-img{width:100%;height:100%;object-fit:cover;display:block}.blc-book-hero-info{flex:1;min-width:0;padding-top:4px}.blc-hero-label{font-size:.7rem;font-weight:700;color:#9b9b9b;text-transform:uppercase;letter-spacing:.06em;margin:0 0 8px}.blc-hero-title{font-size:1.4rem;font-weight:700;color:#1f1f1f;margin:0 0 4px;line-height:1.3}.blc-hero-author{font-size:.95rem;color:#6b6b6b;margin:0 0 12px}.blc-hero-badge{display:inline-block;padding:5px 14px;background:#fdf1f5;color:#8b1b3f;border-radius:999px;font-size:.78rem;font-weight:700}.blc-copies-section{display:flex;flex-direction:column;gap:16px}.blc-copies-label{font-size:.72rem;font-weight:700;color:#767676;text-transform:uppercase;letter-spacing:.06em;margin:0}.blc-empty{padding:28px;background:#faf7f2;border-radius:12px;color:#595959;font-size:.95rem;text-align:center;border:1px dashed #e0ddd9}.blc-copies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.blc-copy-card{position:relative;padding:18px 14px 14px;border-radius:14px;border:2px solid #ececec;background:#fff;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease;text-align:center;display:flex;flex-direction:column;gap:6px;align-items:center;min-height:138px;justify-content:flex-start}.blc-copy-card:hover{border-color:#8b1b3f;transform:translateY(-2px);box-shadow:0 6px 18px #8b1b3f1a}.blc-copy--available{border-top:4px solid #16a34a}.blc-copy--loaned{border-top:4px solid #d97706}.blc-copy--selected{border-color:#8b1b3f!important;background:#8b1b3f0a;box-shadow:0 0 0 3px #8b1b3f1f}.blc-copy-icon{color:#9b9b9b;display:flex;align-items:center;justify-content:center;height:24px}.blc-copy--available .blc-copy-icon{color:#16a34a}.blc-copy--loaned .blc-copy-icon{color:#d97706}.blc-copy--selected .blc-copy-icon{color:#8b1b3f}.blc-copy-number{font-weight:700;font-size:1.1rem;color:#1f1f1f}.blc-copy-condition{font-size:.75rem;color:#9b9b9b}.blc-copy-action{margin-top:auto;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.blc-copy-action--add{background:#faf7f2;color:#6b6b6b;border:1px solid #ececec}.blc-copy-card:hover .blc-copy-action--add{background:#f3e9ec;color:#8b1b3f;border-color:#f3e9ec}.blc-copy-action--remove{background:#8b1b3f;color:#fff}.blc-copy-action--remove:before{content:"✓";font-size:.85rem}.blc-message{padding:14px 18px;border-radius:12px;font-weight:600;font-size:.95rem}.blc-message--success{background:#f0fff4;color:#276749;border:1px solid #c6f6d5}.blc-message--error{background:#fff5f5;color:#9b1c1c;border:1px solid #fed7d7}.psp-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px;align-items:start;animation:pspIn .25s ease}@keyframes pspIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.psp-main{display:flex;flex-direction:column;gap:20px;min-width:0}@media(max-width:980px){.psp-grid{grid-template-columns:1fr}}.psp-section-label{font-size:.72rem;font-weight:700;color:#9b9b9b;text-transform:uppercase;letter-spacing:.06em;margin:0 0 12px}.psp-type-toggle{display:flex;gap:6px;margin-bottom:16px}.psp-toggle-btn{padding:7px 18px;border-radius:8px;border:1.5px solid #ececec;background:#fff;font-family:inherit;font-size:.85rem;font-weight:600;color:#6b6b6b;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease}.psp-toggle-btn:hover{border-color:#8b1b3f;color:#8b1b3f}.psp-toggle-btn--active{background:#8b1b3f;border-color:#8b1b3f;color:#fff}.psp-toggle-btn--active:hover{background:#6e1532;border-color:#6e1532;color:#fff}.psp-search-block{background:#fff;border:1px solid #ececec;border-radius:14px;padding:20px}.psp-pickers{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.psp-picker label{display:block;font-size:.72rem;font-weight:700;color:#6b6b6b;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.psp-input{width:100%;padding:10px 14px;border-radius:10px;border:1.5px solid #ececec;background:#fff;font-size:.95rem;color:#1f1f1f;font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.psp-input:focus{border-color:#8b1b3f;box-shadow:0 0 0 3px #8b1b3f14}.psp-input:disabled{background:#faf7f2;color:#9b9b9b;cursor:not-allowed}.psp-person-block{background:#fff;border:1px solid #ececec;border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:20px}.psp-person-top{display:flex;align-items:center;gap:14px}.psp-person-avatar{width:48px;height:48px;border-radius:50%;background:#8b1b3f;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0;text-transform:uppercase}.psp-person-info{flex:1;min-width:0}.psp-person-name{font-size:1.05rem;font-weight:700;color:#1f1f1f;margin:0}.psp-person-sub{font-size:.82rem;color:#6b6b6b;margin:2px 0 0}.psp-change-btn{background:transparent;color:#6b6b6b;border:1px solid #ececec;border-radius:8px;padding:6px 12px;font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit}.psp-change-btn:hover{border-color:#8b1b3f;color:#8b1b3f}.psp-loans-block{display:flex;flex-direction:column}.psp-loans-list{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto}.psp-loan-row{display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:center;padding:10px;background:#faf7f2;border:1px solid #f0ede9;border-radius:10px}.psp-loan-cover{width:44px;height:62px;border-radius:4px;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center}.psp-loan-cover-img{width:100%;height:100%;object-fit:cover;display:block}.psp-loan-cover-ph{font-size:.8rem;font-weight:700;color:#9b9b9b}.psp-loan-info{min-width:0}.psp-loan-title{font-size:.88rem;font-weight:700;color:#1f1f1f;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.psp-loan-author{font-size:.75rem;color:#9b9b9b;margin:0 0 6px}.psp-loan-progress{display:flex;align-items:center;gap:8px}.psp-progress-bar{flex:1;height:4px;background:#ececec;border-radius:2px;overflow:hidden}.psp-progress-fill{height:100%;border-radius:2px;transition:width .3s ease}.psp-loan-days{font-size:.72rem;font-weight:700;white-space:nowrap}.psp-no-loans{padding:16px;background:#f0fff4;border:1px solid #c6f6d5;border-radius:10px;font-size:.88rem;color:#2f855a;font-weight:600}.psp-no-loans p{margin:0}.psp-loading{text-align:center;color:#9b9b9b;font-size:.9rem;margin:0;padding:20px}.psp-placeholder{display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;border:1px dashed #e0ddd9;border-radius:14px;padding:60px 24px;color:#9b9b9b;gap:8px}.psp-placeholder-icon{color:#d4cfc7;margin-bottom:4px}.psp-placeholder-title{font-size:1rem;font-weight:700;color:#6b6b6b;margin:0}.psp-placeholder-hint{font-size:.85rem;margin:0}.psp-message{margin-top:12px;padding:10px 12px;border-radius:8px;font-size:.85rem;font-weight:600}.psp-message--error{background:#fff5f5;color:#c53030;border:1px solid #fed7d7}.psp-continue-btn{align-self:flex-end;background:#8b1b3f;color:#fff;border:none;border-radius:10px;padding:11px 22px;font-size:.95rem;font-weight:700;font-family:inherit;cursor:pointer;transition:background .15s ease}.psp-continue-btn:hover{background:#6e1532}.psp-warn-btn{margin-top:6px;padding:5px 12px;background:#fff7ed;color:#c2410c;border:1.5px solid #fed7aa;border-radius:6px;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s ease}.psp-warn-btn:hover:not(:disabled){background:#fed7aa}.psp-warn-btn:disabled{opacity:.6;cursor:not-allowed}.rlp-container{max-width:680px;margin:0 auto;padding:32px 24px;display:flex;flex-direction:column;gap:24px;animation:rlpIn .25s ease}@keyframes rlpIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.rlp-header{display:flex;flex-direction:column;gap:4px}.rlp-title{font-size:1.75rem;font-weight:700;color:#1f1f1f;margin:0;letter-spacing:-.02em}.rlp-sub{font-size:.92rem;color:#6b6b6b;margin:0}.rlp-label{font-size:.72rem;font-weight:700;color:#9b9b9b;text-transform:uppercase;letter-spacing:.06em;margin:0 0 10px}.rlp-optional{font-weight:400;text-transform:none;font-size:.72rem;color:#9b9b9b}.rlp-search-block{display:flex;flex-direction:column;gap:10px}.rlp-input-wrap{display:flex;align-items:center;background:#f7f5f2;border:2px solid #ececec;border-radius:12px;padding:0 18px;transition:all .2s ease}.rlp-input-wrap:focus-within{border-color:#8b1b3f;background:#fff;box-shadow:0 0 0 3px #8b1b3f14}.rlp-input-icon{color:#9b9b9b;margin-right:12px;flex-shrink:0}.rlp-input-wrap:focus-within .rlp-input-icon{color:#8b1b3f}.rlp-input{flex:1;border:none;background:transparent;padding:16px 0;font-size:1rem;outline:none;color:#1f1f1f;font-family:inherit}.rlp-input::placeholder{color:#9b9b9b}.rlp-clear-btn{background:none;border:none;color:#9b9b9b;cursor:pointer;font-size:.9rem;padding:4px;flex-shrink:0;transition:color .15s}.rlp-clear-btn:hover{color:#1f1f1f}.rlp-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:14px;border:1px solid #ececec;box-shadow:0 12px 40px #0000001f;z-index:100;overflow:hidden}.rlp-suggestion{display:flex;align-items:center;gap:14px;padding:14px 18px;cursor:pointer;transition:background .12s ease}.rlp-suggestion:hover{background:#faf7f2}.rlp-suggestion+.rlp-suggestion{border-top:1px solid #f5f5f5}.rlp-avatar{width:42px;height:42px;border-radius:50%;background:#8b1b3f;color:#fff;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}.rlp-sug-info{flex:1}.rlp-sug-name{font-size:.95rem;font-weight:600;color:#1f1f1f;margin:0}.rlp-sug-meta{font-size:.75rem;color:#9b9b9b;margin:2px 0 0}.rlp-person-block{background:#fff;border:1px solid #ececec;border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:20px;animation:rlpIn .2s ease}.rlp-person-top{display:flex;align-items:center;gap:14px}.rlp-person-avatar{width:52px;height:52px;border-radius:50%;background:#8b1b3f;color:#fff;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}.rlp-person-name{font-size:1.05rem;font-weight:700;color:#1f1f1f;margin:0}.rlp-person-sub{font-size:.8rem;color:#595959;margin:2px 0 0}.rlp-loading{font-size:.88rem;color:#595959;margin:0}.rlp-empty{padding:20px;background:#faf7f2;border-radius:10px;color:#595959;font-size:.9rem;text-align:center}.rlp-loans-block{display:flex;flex-direction:column;gap:10px}.rlp-loans-list{display:flex;flex-direction:column;gap:8px}.rlp-loan-card{display:flex;align-items:center;gap:14px;background:#faf7f2;border:2px solid #f0ede9;border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .15s ease}.rlp-loan-card:hover{border-color:#8b1b3f}.rlp-loan-card--selected{border-color:#8b1b3f;background:#8b1b3f08}.rlp-loan-cover{width:48px;height:68px;flex-shrink:0;border-radius:6px;overflow:hidden;border:1px solid #ececec}.rlp-loan-cover-img{width:100%;height:100%;object-fit:cover;display:block}.rlp-loan-cover-ph{width:100%;height:100%;background:#8b1b3f;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700}.rlp-loan-info{flex:1;min-width:0}.rlp-loan-title{font-size:.95rem;font-weight:700;color:#1f1f1f;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rlp-loan-author{font-size:.78rem;color:#9b9b9b;margin:0 0 6px}.rlp-loan-days{font-size:.78rem;font-weight:700}.rlp-loan-check{width:28px;height:28px;border-radius:50%;border:2px solid #ececec;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0;transition:all .15s ease}.rlp-loan-check--on{background:#8b1b3f;border-color:#8b1b3f}.rlp-return-block{background:#fff;border:1px solid #ececec;border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:20px;animation:rlpIn .2s ease}.rlp-status-options{display:flex;flex-direction:column;gap:10px}.rlp-status-btn{flex:1;padding:12px 16px;border-radius:12px;border:2px solid #ececec;background:#fff;color:#6b6b6b;font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s ease;white-space:nowrap;min-width:140px}.rlp-status-btn:hover{border-color:#9b9b9b;color:#1f1f1f}.rlp-status-btn--normaal{border-color:#16a34a;background:#f0fdf4;color:#15803d}.rlp-status-btn--beschadigd{border-color:#d97706;background:#fffbeb;color:#b45309}.rlp-status-btn--verloren{border-color:#c0392b;background:#fff5f5;color:#991b1b}.rlp-opmerking-block{display:flex;flex-direction:column;gap:8px}.rlp-textarea{padding:12px 16px;border:2px solid #ececec;border-radius:10px;font-size:.92rem;font-family:inherit;outline:none;resize:vertical;transition:border-color .2s ease;color:#1f1f1f}.rlp-textarea:focus{border-color:#8b1b3f;box-shadow:0 0 0 3px #8b1b3f14}.rlp-message{padding:14px 18px;border-radius:12px;font-weight:600;font-size:.92rem}.rlp-message--success{background:#f0fff4;color:#276749;border:1px solid #c6f6d5}.rlp-message--error{background:#fff5f5;color:#9b1c1c;border:1px solid #fed7d7}.rlp-actions{display:flex;gap:12px}.rlp-btn-cancel{padding:14px 20px;border-radius:12px;border:1.5px solid #ececec;background:#fff;color:#6b6b6b;font-size:.92rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s ease;flex-shrink:0}.rlp-btn-cancel:hover:not(:disabled){border-color:#9b9b9b;color:#1f1f1f}.rlp-btn-confirm{flex:1;padding:14px 20px;border-radius:12px;border:none;background:#8b1b3f;color:#fff;font-size:.92rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s ease}.rlp-btn-confirm:hover:not(:disabled){background:#6e1432}.rlp-btn-confirm:disabled{opacity:.5;cursor:not-allowed}.rlp-status-btn--teruggebracht{border-color:#16a34a;background:#f0fdf4;color:#15803d}.rlp-conditie-input{width:100%;padding:12px 16px;border:2px solid #ececec;border-radius:10px;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s ease;box-sizing:border-box}.rlp-conditie-input:focus{border-color:#8b1b3f;box-shadow:0 0 0 3px #8b1b3f14}@media(max-width:480px){.rlp-container{padding:20px 16px}.rlp-status-options{flex-direction:column}}.bsk-sidebar{position:sticky;top:24px;background:#fff;border:1px solid #ececec;border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:14px;box-shadow:0 2px 10px #0000000a;max-height:calc(100vh - 48px)}.bsk-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid #f0ede9}.bsk-label{font-size:.72rem;font-weight:700;color:#8b1b3f;text-transform:uppercase;letter-spacing:.08em}.bsk-count{font-size:.82rem;font-weight:600;color:#6b6b6b;background:#faf7f2;padding:3px 10px;border-radius:999px}.bsk-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 8px;gap:8px;color:#9b9b9b}.bsk-empty-icon{color:#d4cfc7}.bsk-empty-text{font-weight:600;font-size:.9rem;color:#6b6b6b;margin:0}.bsk-empty-hint{font-size:.78rem;margin:0;line-height:1.4}.bsk-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;min-height:0}.bsk-item{display:grid;grid-template-columns:36px 1fr auto;gap:10px;align-items:flex-start;padding:8px;background:#faf7f2;border:1px solid #f0ede9;border-radius:8px}.bsk-item-cover{width:36px;height:50px;object-fit:cover;border-radius:4px;background:#fff;display:block}.bsk-item-info{min-width:0}.bsk-item-title{font-size:.85rem;font-weight:600;color:#1f1f1f;margin:0 0 2px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.bsk-item-author{font-size:.72rem;color:#9b9b9b;margin:0 0 4px}.bsk-item-copy{font-size:.7rem;font-weight:700;color:#8b1b3f;background:#fff;padding:2px 8px;border-radius:4px;display:inline-block}.bsk-item-remove{background:transparent;color:#9b9b9b;border:none;width:22px;height:22px;border-radius:50%;font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.bsk-item-remove:hover{background:#8b1b3f;color:#fff}.bsk-footer{display:flex;gap:8px;padding-top:12px;border-top:1px solid #f0ede9}.bsk-btn-secondary{flex:0 0 auto;background:transparent;color:#6b6b6b;border:1px solid #ececec;border-radius:8px;padding:10px 14px;font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit}.bsk-btn-secondary:hover:not(:disabled){color:#8b1b3f;border-color:#8b1b3f}.bsk-btn-secondary:disabled{opacity:.5;cursor:not-allowed}.bsk-btn-primary{flex:1;background:#8b1b3f;color:#fff;border:none;border-radius:8px;padding:10px 16px;font-size:.9rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s ease}.bsk-btn-primary:hover:not(:disabled){background:#6e1432}.bsk-btn-primary:disabled{background:#c8c4be;cursor:not-allowed}.bsk-confirm{display:flex;flex-direction:column;gap:12px}.bsk-capacity{padding:12px;background:#faf7f2;border-radius:8px;display:flex;flex-direction:column;gap:8px}.bsk-capacity-row{display:flex;justify-content:space-between;font-size:.78rem;color:#6b6b6b;font-weight:600}.bsk-capacity-count{color:#1f1f1f;font-weight:700}.bsk-capacity-bar{display:flex;gap:4px}.bsk-capacity-slot{flex:1;height:6px;border-radius:3px;background:#ececec}.bsk-slot--used{background:#6b6b6b}.bsk-slot--new{background:#8b1b3f}.bsk-slot--empty{background:#ececec}.bsk-message{padding:10px 12px;border-radius:8px;font-size:.82rem;font-weight:600;line-height:1.4}.bsk-message--success{background:#f0fff4;color:#2f855a;border:1px solid #c6f6d5}.bsk-message--error{background:#fff5f5;color:#c53030;border:1px solid #fed7d7}.bsk-message--warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}@media(max-width:980px){.bsk-sidebar{position:static;max-height:none}}.rapportage-empty,.rapportage-loading{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);font-size:1rem}.rapportage-list{display:flex;flex-direction:column;gap:14px}.rapportage-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px 22px;transition:border-color .15s ease,box-shadow .15s ease}.rapportage-card:hover{border-color:var(--color-accent-border);box-shadow:0 4px 12px #0000000a}.rapportage-card.is-hidden{background:var(--color-bg);border-style:dashed}.rapportage-card-head{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px}.rapportage-badge{font-weight:700;font-size:.7rem;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;border:1px solid transparent}.rapportage-badge--BAD_LANGUAGE{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.rapportage-badge--SPAM{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.rapportage-badge--IRRELEVANT{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.rapportage-badge--BULLYING{background:#fdf2f8;color:#9d174d;border-color:#fbcfe8}.rapportage-badge--OTHER{background:#eef2ff;color:#3730a3;border-color:#c7d2fe}.rapportage-badge--hidden{background:var(--color-bg);color:var(--color-text-muted);border-color:var(--color-border)}.rapportage-date{font-size:.8rem;color:var(--color-text-faint);margin-left:auto}.rapportage-review{background:var(--color-bg);border-left:3px solid var(--color-accent);padding:12px 14px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:12px;font-size:.92rem;color:var(--color-text);line-height:1.5;white-space:pre-wrap;word-break:break-word}.rapportage-meta{display:flex;flex-wrap:wrap;gap:4px 16px;font-size:.82rem;color:var(--color-text-muted);margin-bottom:4px}.rapportage-meta strong{color:var(--color-text);font-weight:600}.rapportage-toelichting{margin-top:8px;padding:10px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;color:var(--color-text-muted);line-height:1.5}.rapportage-toelichting-label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-faint);margin-bottom:4px}.rapportage-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--color-border)}.rapportage-actions .management-btn-ghost{margin-right:auto}.management-btn-ghost{background:transparent;color:var(--color-text-muted);border:1.5px solid transparent;padding:9px 14px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease;font-family:inherit}.management-btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.confirm-overlay{position:fixed;inset:0;background:#00000073;z-index:4000;display:flex;align-items:center;justify-content:center;padding:16px}.confirm-modal{background:var(--color-surface);border-radius:var(--radius);padding:24px;width:420px;max-width:100%;box-shadow:0 16px 48px #0000002e}.confirm-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0 0 8px}.confirm-text{font-size:.92rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 20px}.confirm-actions{display:flex;gap:8px;justify-content:flex-end}.title{font-size:3rem;font-weight:700;margin:0 0 10px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.subtitle{font-size:1rem;margin:0 0 20px;font-weight:400}.loginSchoolPicker{display:flex;flex-direction:column;gap:6px;margin:0 auto 14px;max-width:280px;text-align:left}.loginSchoolLabel{font-size:.78rem;font-weight:700;color:#475569;letter-spacing:.04em;text-transform:uppercase}.loginSchoolSelect{padding:8px 12px;font-size:.95rem;border:1.5px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b;font-family:inherit;cursor:pointer;outline:none;transition:border-color .15s ease}.loginSchoolSelect:focus{border-color:#ff520e}.loginSchoolSelect:disabled{background:#f1f5f9;cursor:not-allowed}.loginSchoolError{font-size:.78rem;color:#c0392b;margin:4px 0 0}.loginBtn{display:flex;align-items:center;justify-content:center;gap:12px;padding:7px 16px;border-radius:6px;border:none;background:#ff520e;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;white-space:nowrap}.loginBtn:hover:not(:disabled){background:#e04e0c}.loginBtn:disabled{opacity:.5;cursor:not-allowed}.loginBtn:active{transform:translateY(0)}.ssBtnLogo{padding-right:8px;border-right:#dc4208 solid 1px;width:32px;height:24px;object-fit:contain}.privacyDisclaimer{font-size:xx-small}.devButtons{display:grid;grid-template-columns:1fr 1fr;row-gap:6px;column-gap:6px;margin-top:1rem}.devButton{border-radius:4px;padding-top:4px;padding-bottom:4px}@media(max-width:768px){.mainLogo{max-width:120px}.title{font-size:2.5rem}.subtitle{font-size:.95rem}.loginBtn{padding:12px 24px;font-size:.95rem}.privacyDisclaimer{bottom:20px;left:20px;right:20px;transform:none;max-width:none}}.App{min-height:100vh;display:flex;flex-direction:column}body{overflow-x:hidden}#root{width:100%;min-height:100vh}.bt-page{min-height:100vh;background:#f5f0eb;font-family:Georgia,serif}.bt-book-header{background:#8b1a2b;padding:1.25rem 2rem 2rem;position:sticky;top:0;z-index:10}.bt-back{background:none;border:none;color:#ffffffbf;font-size:.85rem;cursor:pointer;padding:0;margin-bottom:1rem;letter-spacing:.03em;transition:color .15s}.bt-back:hover{color:#fff}.bt-book-card{display:flex;gap:1.25rem;align-items:flex-start;max-width:900px}.bt-book-cover{width:72px;flex-shrink:0;border-radius:6px;overflow:hidden;box-shadow:0 4px 16px #0000004d}.bt-book-cover img{width:100%;display:block;aspect-ratio:2/3;object-fit:cover}.bt-cover-placeholder{width:72px;aspect-ratio:2/3;background:#0000004d;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;font-weight:700}.bt-book-info{flex:1}.bt-book-title{color:#fff;font-size:1.25rem;font-weight:700;margin:0 0 4px;line-height:1.3}.bt-book-author{color:#ffffffb3;font-size:.9rem;margin:0 0 8px;font-style:italic}.bt-book-desc{color:#ffffffa6;font-size:.82rem;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.bt-main{max-width:900px;margin:0 auto;padding:2rem 2rem 4rem;display:grid;grid-template-columns:1fr 380px;gap:2rem;align-items:start}@media(max-width:720px){.bt-main{grid-template-columns:1fr;padding:1.25rem}.bt-book-header{padding:1rem 1.25rem 1.5rem}}.bt-section-title{font-size:1rem;font-weight:700;color:#2c2c2c;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;letter-spacing:.01em}.bt-tip-count{background:#8b1a2b;color:#fff;font-size:.72rem;font-weight:700;border-radius:20px;padding:2px 8px;font-family:sans-serif}.bt-empty{text-align:center;padding:3rem 1rem;color:#999;font-size:.9rem}.bt-empty-icon{font-size:2rem;display:block;margin-bottom:.75rem}.bt-tips-grid{display:flex;flex-direction:column;gap:1rem}.bt-tip-card{background:#fff;border-radius:10px;padding:1.25rem;border:1px solid rgba(139,26,43,.08);box-shadow:0 1px 4px #0000000d;transition:box-shadow .2s}.bt-tip-card:hover{box-shadow:0 4px 12px #00000014}.bt-tip-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.6rem}.bt-tip-title{font-size:.95rem;font-weight:700;color:#2c2c2c;margin:0}.bt-tip-content{font-size:.88rem;color:#555;line-height:1.6;margin:0 0 .75rem;white-space:pre-wrap}.bt-delete-btn{background:none;border:none;color:#ccc;font-size:.8rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s,color .15s;flex-shrink:0}.bt-delete-btn:hover{background:#fdecea;color:#c0392b}.bt-attachment-link{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;color:#8b1a2b;text-decoration:none;font-weight:600;padding:4px 10px;border:1px solid rgba(139,26,43,.25);border-radius:6px;transition:background .15s;margin-bottom:.5rem}.bt-attachment-link:hover{background:#8b1a2b0f}.bt-inline-upload{margin-top:.5rem}.bt-upload-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.bt-file-label{font-size:.82rem;color:#555;background:#f5f0eb;border:1px dashed #ccc;border-radius:6px;padding:5px 10px;cursor:pointer;transition:border-color .15s}.bt-file-label:hover{border-color:#8b1a2b}.bt-btn-sm{font-size:.8rem;padding:5px 12px;border-radius:6px;border:none;cursor:pointer;font-weight:600;transition:opacity .15s}.bt-btn-sm:disabled{opacity:.5;cursor:not-allowed}.bt-btn-primary{background:#8b1a2b;color:#fff}.bt-btn-primary:hover{opacity:.88}.bt-btn-ghost{background:#eee;color:#555}.bt-btn-ghost:hover{background:#ddd}.bt-add-attachment-btn{background:none;border:1px dashed rgba(139,26,43,.3);color:#8b1a2b;font-size:.8rem;padding:5px 12px;border-radius:6px;cursor:pointer;transition:background .15s;font-family:inherit}.bt-add-attachment-btn:hover{background:#8b1a2b0f}.bt-form-section{position:sticky;top:160px}.bt-form{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid rgba(139,26,43,.1);box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:1rem}.bt-field{display:flex;flex-direction:column;gap:5px}.bt-label{font-size:.78rem;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.06em;font-family:sans-serif}.bt-input,.bt-textarea{border:1.5px solid #e0d8d8;border-radius:8px;padding:10px 12px;font-size:.9rem;font-family:inherit;color:#2c2c2c;background:#fdf9f6;transition:border-color .15s;resize:vertical}.bt-input:focus,.bt-textarea:focus{outline:none;border-color:#8b1a2b}.bt-input::placeholder,.bt-textarea::placeholder{color:#bbb}.bt-file-drop{display:flex;align-items:center;gap:.6rem;border:1.5px dashed #d0c8c8;border-radius:8px;padding:10px 14px;cursor:pointer;background:#fdf9f6;transition:border-color .15s,background .15s}.bt-file-drop:hover{border-color:#8b1a2b;background:#8b1a2b08}.bt-file-icon{font-size:1rem}.bt-file-text{font-size:.85rem;color:#888;font-family:sans-serif}.bt-remove-file{background:none;border:none;font-size:.78rem;color:#c0392b;cursor:pointer;padding:0;font-family:sans-serif;text-align:left}.bt-remove-file:hover{text-decoration:underline}.bt-submit-btn{background:#8b1a2b;color:#fff;border:none;border-radius:8px;padding:12px;font-size:.9rem;font-weight:700;cursor:pointer;font-family:inherit;letter-spacing:.02em;transition:opacity .15s,transform .1s}.bt-submit-btn:hover{opacity:.88}.bt-submit-btn:active{transform:scale(.98)}.bt-submit-btn:disabled{opacity:.5;cursor:not-allowed}.bt-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:8px;font-size:.88rem;font-weight:600;font-family:sans-serif;z-index:100;box-shadow:0 4px 20px #00000026;animation:bt-fadein .2s ease}.bt-toast--success{background:#2d6a4f;color:#fff}.bt-toast--error{background:#c0392b;color:#fff}@keyframes bt-fadein{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.bt-share-bar{margin-top:1rem}.bt-share-btn{background:#0000004d;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:6px;font-size:.85rem;cursor:pointer;font-family:inherit;transition:background .15s}.bt-share-btn:hover{background:#ffffff40}.bt-share-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.bt-share-input{flex:1;min-width:200px;background:#00000040;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:7px 10px;font-size:.82rem;color:#fff;font-family:monospace}.bt-share-copy,.bt-share-oneroster{background:#0000004d;border:1px solid rgba(255,255,255,.3);color:#fff;padding:7px 14px;border-radius:6px;font-size:.82rem;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s}.bt-share-copy:hover,.bt-share-oneroster:hover{background:#ffffff40}.bt-modal-overlay{position:fixed;inset:0;background:#0006;z-index:50;display:flex;align-items:center;justify-content:center}.bt-modal{background:#fff;border-radius:12px;padding:1.75rem;width:420px;max-width:90vw;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 8px 32px #0003}.bt-modal-title{font-size:1rem;font-weight:700;color:#2c2c2c;margin:0 0 .25rem}.bt-modal-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.bt-tip-share{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.bt-tip-share-btn{background:none;border:1px solid rgba(139,26,43,.2);color:#8b1a2b;font-size:.78rem;padding:4px 10px;border-radius:6px;cursor:pointer;font-family:inherit;transition:background .15s}.bt-tip-share-btn:hover{background:#8b1a2b0f}.bt-tip-author{font-size:.78rem;color:#999;font-style:italic;margin:0 0 .5rem;font-family:sans-serif}.config-page-wrapper{display:flex;justify-content:center;padding:32px 24px 64px;width:100%;box-sizing:border-box}.config-body{display:flex;flex-direction:column;gap:12px;width:100%;max-width:640px}.config-body>*{background:#fff;border:1px solid #efefef;border-radius:14px;padding:22px 24px;box-shadow:0 1px 6px #0000000d}.school-name{font-size:1.4rem;font-weight:800;color:#8b1a2b;margin:0 0 14px;display:block;letter-spacing:-.02em}.input-label{font-size:.72rem;font-weight:700;color:#a0a0a0;text-transform:uppercase;letter-spacing:.07em;margin:0 0 6px;display:block}.new-message-input,.config-input,.new-campus-input{width:100%;box-sizing:border-box;background:#f8f7f6;border:1.5px solid #e6e6e6;border-radius:8px;padding:10px 13px;font-size:.93rem;color:#1a1a1a;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease;min-width:unset}.new-message-input:focus,.config-input:focus,.new-campus-input:focus{outline:none;border-color:#8b1a2b;box-shadow:0 0 0 3px #8b1a2b14;background:#fff}.config-form-input{display:flex;flex-direction:column;gap:6px}.current-message-display{padding:12px 16px;background:#fdf5f6;border-radius:8px;border:1.5px solid rgba(139,26,43,.1);font-size:.92rem;font-weight:600;color:#8b1a2b;min-height:40px;margin:0 0 12px;line-height:1.5}.new-message-form{display:flex;flex-direction:column;gap:8px}.campus-wrapper{display:flex;flex-direction:column;justify-content:center;padding:32px 24px 64px;width:100%;box-sizing:border-box}.campus-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px}.campus-display{display:flex;align-items:center;justify-content:space-between;background:#f4f6ff;border:1.5px solid #dde2f8;border-radius:8px;padding:10px 14px;gap:12px}.campus-display h3,.campus-display h5{margin:0;font-size:.9rem;font-weight:600;color:#1a1a1a;display:inline}.campus-btn{background:transparent;border:none;color:#595959;font-size:.78rem;font-weight:700;cursor:pointer;padding:3px 8px;border-radius:6px;transition:all .15s ease;flex-shrink:0}.campus-btn:hover{background:#8b1a2b12;color:#8b1a2b}.management-btn{padding:13px;background:#8b1a2b;color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .15s ease,transform .1s ease;font-family:inherit;letter-spacing:.01em}.management-btn:hover{background:#6e1422;transform:translateY(-1px)}.management-btn:active{transform:translateY(0)}.deleted-campus{background:#fff6f6;border-color:#fbb5b5}.deleted-campus h5{color:#b91c1c}.added-campus-display{background:#f4fdf6;border-color:#90e0ab}.added-campus-display h5{color:#166534}.campus-form{display:flex;gap:8px;margin-top:10px}.campus-add-btn{padding:10px 16px;background:#8b1a2b;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s ease;font-family:inherit;white-space:nowrap}.campus-add-btn:hover{background:#6e1422}.apply-btn{width:100%;padding:13px;background:#8b1a2b;color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .15s ease,transform .1s ease;font-family:inherit;letter-spacing:.01em}.apply-btn:hover{background:#6e1422;transform:translateY(-1px)}.apply-btn:active{transform:translateY(0)}.notification-popup{position:fixed;bottom:24px;right:24px;padding:12px 18px;border-radius:10px;font-weight:600;font-size:.85rem;box-shadow:0 4px 16px #0000001f;z-index:9999;animation:slideIn .2s ease;background:#f4fdf6;border:1px solid #90e0ab;color:#166534}.notification-popup.error{background:#fff6f6;border-color:#fbb5b5;color:#b91c1c}@keyframes slideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.config-page-wrapper{padding:16px 12px 48px}.config-body>*{padding:18px 16px;border-radius:10px}.campus-form{flex-direction:column}.campus-add-btn,.new-campus-input{width:100%}.notification-popup{left:16px;right:16px;bottom:16px;text-align:center}}._panel_1jri9_3{display:flex;flex-direction:column;gap:1.25rem;max-width:720px}._fieldGroup_1jri9_10{display:flex;flex-direction:column;gap:.4rem}._label_1jri9_16{font-size:.78rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}._input_1jri9_24,._select_1jri9_25{width:100%;padding:.65rem .875rem;font-size:.95rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit;box-sizing:border-box}._input_1jri9_24:focus,._select_1jri9_25:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}._input_1jri9_24::placeholder{color:var(--color-text-faint)}._checkboxRow_1jri9_51{display:inline-flex;align-items:center;gap:10px;cursor:pointer;padding:4px 2px;-webkit-user-select:none;user-select:none;width:fit-content}._checkboxRow_1jri9_51 input[type=checkbox]{accent-color:var(--color-accent);width:18px;height:18px;cursor:pointer;margin:0;flex-shrink:0}._checkboxLabel_1jri9_70{font-size:.92rem;color:var(--color-text);cursor:pointer;font-weight:500}._btnPrimary_1jri9_77{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease;font-family:inherit}._btnPrimary_1jri9_77:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}._btnPrimary_1jri9_77:disabled{opacity:.5;cursor:not-allowed}._messageSuccess_1jri9_104{font-size:.875rem;color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:.6rem .875rem}._messageError_1jri9_113{font-size:.875rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:.6rem .875rem}._formFooter_1jri9_122{display:flex;align-items:center;justify-content:flex-end;gap:.875rem;flex-wrap:wrap;padding-top:.75rem;border-top:1px solid var(--color-border)}._formFooter_1jri9_122 ._messageSuccess_1jri9_104,._formFooter_1jri9_122 ._messageError_1jri9_113{flex:1;margin:0}._panel_h3rmt_3{display:flex;flex-direction:column;gap:1.25rem}._fieldGroup_h3rmt_9{display:flex;flex-direction:column;gap:.4rem}._label_h3rmt_15{font-size:.78rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}._btnPrimary_h3rmt_23{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease;font-family:inherit}._btnPrimary_h3rmt_23:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}._btnPrimary_h3rmt_23:disabled{opacity:.5;cursor:not-allowed}._bulkHeader_h3rmt_51{margin-bottom:8px}._bulkTitle_h3rmt_55{font-size:1.1rem;font-weight:700;color:var(--color-text);margin:0 0 6px}._bulkDescription_h3rmt_62{color:var(--color-text-muted);font-size:.9rem;line-height:1.5;margin:0}._downloadBtn_h3rmt_69{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:var(--color-surface);color:var(--color-text);text-decoration:none;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-weight:600;font-size:.88rem;width:fit-content;transition:border-color .15s ease,color .15s ease,background .15s ease}._downloadBtn_h3rmt_69:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-softer)}._fileUploadArea_h3rmt_91{position:relative;margin-top:4px}._fileInput_h3rmt_96{position:absolute;opacity:0;width:0;height:0}._fileLabel_h3rmt_103{display:block;padding:36px 20px;border:2px dashed var(--color-border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease;background:var(--color-bg);color:var(--color-text-muted);font-weight:500}._fileLabel_h3rmt_103:hover{border-color:var(--color-accent);background:var(--color-accent-softer);color:var(--color-accent)}._uploadBtnContainer_h3rmt_122{display:flex;justify-content:flex-end;margin-top:4px}._messageSuccess_h3rmt_128{font-size:.875rem;color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:.6rem .875rem}._messageError_h3rmt_137{font-size:.875rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:.6rem .875rem}._resultsCard_h3rmt_147{margin-top:12px;padding:20px;background:var(--color-bg);border-radius:var(--radius);border:1px solid var(--color-border)}._resultsTitle_h3rmt_155{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 14px}._statsGrid_h3rmt_162{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}._statBox_h3rmt_168{padding:14px;background:var(--color-surface);border-radius:var(--radius-sm);text-align:center;border:1px solid var(--color-border)}._statSuccess_h3rmt_176{background:#f0fdf4;border-color:#86efac}._statError_h3rmt_181{background:#fef2f2;border-color:#fca5a5}._statNumber_h3rmt_186{display:block;font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:4px}._statLabel_h3rmt_194{display:block;font-size:.72rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}._errorSection_h3rmt_203{margin-top:12px;padding:14px 16px;background:var(--color-surface);border-radius:var(--radius-sm);border-left:4px solid var(--color-danger)}._errorTitle_h3rmt_211{font-size:.85rem;font-weight:700;color:var(--color-danger);margin:0 0 8px}._errorList_h3rmt_218{list-style:none;padding:0;margin:0}._errorItem_h3rmt_224{padding:4px 0;color:#7f1d1d;font-size:.85rem}._modalOverlay_h3rmt_231{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}._modal_h3rmt_231{background:var(--color-surface);border-radius:var(--radius);width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;overflow:hidden}._modalHeader_h3rmt_254{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--color-border)}._modalNav_h3rmt_262{display:flex;align-items:center;gap:12px}._navArrow_h3rmt_268{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--color-border);border-radius:50%;background:var(--color-surface);color:var(--color-text);font-size:1.2rem;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease;line-height:1}._navArrow_h3rmt_268:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-softer)}._navArrow_h3rmt_268:disabled{opacity:.3;cursor:not-allowed}._navCounter_h3rmt_295{font-size:.9rem;font-weight:600;color:var(--color-text);min-width:60px;text-align:center}._modalClose_h3rmt_303{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-muted);padding:4px 8px;border-radius:6px;line-height:1}._modalClose_h3rmt_303:hover{background:var(--color-accent-soft);color:var(--color-accent)}._modalBody_h3rmt_319{padding:20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}._modalFooter_h3rmt_328{padding:14px 20px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:10px;background:var(--color-bg)}._modalActions_h3rmt_337{display:flex;justify-content:flex-end;gap:8px}._btnSecondary_h3rmt_343{padding:.6rem 1.1rem;font-size:.88rem;font-weight:600;background:var(--color-surface);color:var(--color-text);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s ease,background .15s ease;font-family:inherit}._btnSecondary_h3rmt_343:hover{border-color:var(--color-accent);background:var(--color-accent-softer);color:var(--color-accent)}._btnDanger_h3rmt_362{padding:.6rem 1.1rem;font-size:.88rem;font-weight:600;background:var(--color-surface);color:var(--color-danger);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s ease,background .15s ease;font-family:inherit}._btnDanger_h3rmt_362:hover{border-color:var(--color-danger);background:var(--color-danger-soft)}._bookDetailCard_h3rmt_381{padding:14px 16px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm)}._bookDetailTitle_h3rmt_388{font-size:1.05rem;font-weight:700;color:var(--color-text);margin:0 0 4px}._bookDetailAuthor_h3rmt_395{font-size:.9rem;color:var(--color-text-muted);margin:0 0 8px}._bookDetailMeta_h3rmt_401{display:flex;flex-wrap:wrap;gap:6px 16px;font-size:.78rem;color:var(--color-text-faint);margin-bottom:8px}._bookDetailDesc_h3rmt_410{font-size:.85rem;color:var(--color-text-muted);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}._select_h3rmt_421{width:100%;padding:.6rem .875rem;font-size:.9rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;color:var(--color-text);background:var(--color-surface);font-family:inherit}._select_h3rmt_421:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}._required_h3rmt_438{color:var(--color-accent);margin-left:2px}._tagHint_h3rmt_443{font-size:.75rem;color:var(--color-text-faint);margin:0}._chipContainer_h3rmt_449{display:flex;flex-wrap:wrap;gap:6px}._chip_h3rmt_449{padding:5px 12px;font-size:.8rem;font-weight:600;border:1.5px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}._chip_h3rmt_449:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-softer)}._chipActive_h3rmt_473{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}._chipActive_h3rmt_473:hover{background:var(--color-accent-hover);color:#fff;border-color:var(--color-accent-hover)}._selectedSummary_h3rmt_485{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:10px 12px;background:var(--color-accent-soft);border:1px solid var(--color-accent-border);border-radius:var(--radius-sm)}._summaryLabel_h3rmt_496{font-size:.75rem;font-weight:700;color:var(--color-accent);text-transform:uppercase;letter-spacing:.04em;margin-right:4px}._summaryChip_h3rmt_505{padding:3px 10px;font-size:.78rem;font-weight:600;background:var(--color-accent);color:#fff;border-radius:999px}._summaryChipAlt_h3rmt_514{padding:3px 10px;font-size:.78rem;font-weight:500;background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:999px}._csvBadge_h3rmt_523{display:inline-flex;align-items:center;margin-left:8px;font-size:.68rem;background:linear-gradient(135deg,#dbeafe,#eff6ff);color:#1d4ed8;padding:2px 8px;border-radius:999px;font-weight:600;border:1px solid #bfdbfe;letter-spacing:.03em;vertical-align:middle}._input_h3rmt_537{width:100%;padding:.6rem .875rem;font-size:.9rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;color:var(--color-text);background:var(--color-surface);font-family:inherit}._input_h3rmt_537:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}._checkboxRow_h3rmt_554{display:flex;align-items:center;gap:10px;cursor:pointer;padding:4px 0}._checkboxLabel_h3rmt_562{font-size:.88rem;font-weight:500;color:var(--color-text)}._filledBadge_h3rmt_568{font-size:.85rem;font-weight:600;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:4px 10px}.edit-manager-panel{display:flex;flex-direction:column;gap:16px;max-width:720px}.edit-manager-current{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:18px 22px;display:flex;flex-direction:column;gap:6px}.edit-manager-current-label{font-size:.72rem;font-weight:700;color:var(--color-text-muted);letter-spacing:.06em;text-transform:uppercase}.edit-manager-current-name{font-size:1.05rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.edit-manager-arrow{color:var(--color-text-muted);font-weight:400}.edit-manager-pending{color:var(--color-accent)}.edit-manager-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.edit-manager-search{flex:1;min-width:220px;padding:.6rem .875rem;font-size:.95rem;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease;color:var(--color-text);background:var(--color-surface);font-family:inherit}.edit-manager-search:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.edit-manager-search::placeholder{color:var(--color-text-faint)}.edit-manager-count{font-size:.82rem;color:var(--color-text-muted);white-space:nowrap}.edit-manager-list{list-style:none;margin:0;padding:10px;display:grid;gap:6px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);max-height:520px;overflow-y:auto}.edit-manager-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;text-align:left;background:transparent;border:1.5px solid transparent;border-radius:var(--radius-sm);padding:10px 12px;cursor:pointer;font-family:inherit;transition:background .12s ease,border-color .12s ease}.edit-manager-row:hover:not(:disabled){background:var(--color-accent-softer)}.edit-manager-row.is-picked{background:var(--color-accent-soft);border-color:var(--color-accent-border)}.edit-manager-row.is-current{background:#f0fdf4;border-color:#bbf7d0;cursor:default}.edit-manager-row:disabled{opacity:1}.edit-manager-person{display:flex;flex-direction:column;gap:2px;min-width:0}.edit-manager-name{font-weight:600;color:var(--color-text);font-size:.93rem}.edit-manager-email{font-size:.8rem;color:var(--color-text-muted);word-break:break-all}.edit-manager-badge{flex-shrink:0;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 8px;border-radius:var(--radius-sm);background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.edit-manager-badge-pending{background:var(--color-accent-soft);color:var(--color-accent);border-color:var(--color-accent-border)}.edit-manager-empty{text-align:center;color:var(--color-text-muted);padding:40px 20px;font-size:.9rem}.edit-manager-status{margin:0;font-size:.9rem;padding:.7rem .9rem;border-radius:var(--radius-sm)}.edit-manager-status.is-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.edit-manager-status.is-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.edit-manager-footer{display:flex;align-items:center;justify-content:flex-end;gap:.875rem;flex-wrap:wrap;padding-top:8px}.stats-page{min-height:100vh}.stats-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;align-items:end;margin-bottom:20px;padding:20px 24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.stats-filter-group{display:flex;flex-direction:column;gap:5px;min-width:0}.stats-filter-group label{font-size:.78rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.stats-filter-group select,.stats-filter-group input{padding:8px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.88rem;background:var(--color-surface);color:var(--color-text);width:100%;min-width:0;box-sizing:border-box;font-family:inherit;outline:none;transition:border-color .15s ease}.stats-filter-group select:focus,.stats-filter-group input:focus{border-color:var(--color-accent)}.stats-student-list{margin-top:4px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);max-height:280px;overflow-y:auto;display:flex;flex-direction:column}.stats-student-option{padding:10px 14px;font-size:.9rem;color:var(--color-text);cursor:pointer;border:none;background:transparent;text-align:left;font-family:inherit;width:100%;border-bottom:1px solid var(--color-border);transition:background .1s ease;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-student-option:last-child{border-bottom:none}.stats-student-option:hover{background:var(--color-accent-softer)}.stats-student-option.is-selected{background:var(--color-accent-soft);color:var(--color-accent);font-weight:700;border-left:3px solid var(--color-accent);padding-left:11px}.stats-student-option.is-placeholder{color:var(--color-text-faint);font-style:italic;border-bottom:2px solid var(--color-border)}.stats-filter-actions{display:flex;gap:8px;align-items:end}@media(max-width:640px){.stats-filters{grid-template-columns:1fr;padding:16px}.stats-section{padding:16px}.stats-section h2{font-size:.95rem}}.stats-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:24px;margin-bottom:20px}.stats-section h2{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 20px}.stats-empty{color:var(--color-text-muted);font-size:.9rem;margin:0}.stats-loading{color:var(--color-text-muted);font-size:.9rem}.stats-error{color:var(--color-danger);font-size:.9rem;padding:12px 16px;background:var(--color-danger-soft);border-radius:var(--radius-sm);margin-bottom:16px}*{font-family:Open Sans,sans-serif}.loginContainer{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px}.logoSection{margin-bottom:10px}.mainLogo{max-width:180px;height:auto}.contentSection{text-align:center}.loginForm{display:flex;flex-direction:column}.formInput{margin-top:8px;width:100%;box-sizing:border-box;background:#f8f7f6;border:1.5px solid #e6e6e6;border-radius:8px;padding:10px 13px;font-size:.93rem;color:#1a1a1a;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease;min-width:unset}.form-btn{margin-top:8px;padding:13px;background:#8b1a2b;color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .15s ease,transform .1s ease;font-family:inherit;letter-spacing:.01em}.form-btn:hover{background:#6e1422;transform:translateY(-1px)}.message{font-size:.875rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:.6rem .875rem}@media(max-width:768px){.mainLogo{max-width:120px}.title{font-size:2.5rem}.subtitle{font-size:.95rem}.loginBtn{padding:12px 24px;font-size:.95rem}}.purchase-request-page{--color-accent: #8b1b3f;--color-accent-hover: #6e1432;--color-accent-soft: rgba(139, 27, 63, .08);--color-accent-softer: rgba(139, 27, 63, .04);--color-accent-border: rgba(139, 27, 63, .18);--color-bg: #f7f5f2;--color-surface: #ffffff;--color-border: #ececec;--color-text: #1f1f1f;--color-text-muted: #6b6b6b;--color-text-faint: #9b9b9b;--color-danger: #b3261e;--color-danger-soft: rgba(179, 38, 30, .08);--radius: 12px;--radius-sm: 8px;min-height:100vh;background:var(--color-bg);color:var(--color-text);width:100%;box-sizing:border-box}.purchase-request-inner{max-width:1280px;width:100%;margin:0 auto;padding:24px 32px 48px;box-sizing:border-box}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:8px}.page-header-left{flex:1;min-width:0}.page-header h1{font-size:1.75rem;font-weight:700;margin:0 0 4px;letter-spacing:-.01em}.page-subtitle{color:var(--color-text-muted);margin:0;font-size:.95rem}.primary-button{padding:10px 22px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .1s ease;white-space:nowrap;flex-shrink:0}.primary-button:hover:not(:disabled){background:var(--color-accent-hover)}.primary-button:active:not(:disabled){transform:translateY(1px)}.primary-button:disabled{background:#ccc;cursor:not-allowed}.search-bar{display:flex;align-items:center;gap:10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:12px 16px;margin:24px 0 32px;transition:border-color .15s ease,box-shadow .15s ease}.search-bar:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.search-icon{color:var(--color-text-faint);flex-shrink:0}.search-bar input{border:none;outline:none;flex:1;font-size:.95rem;font-family:inherit;background:transparent;color:var(--color-text)}.search-bar input::placeholder{color:var(--color-text-faint)}.loading{text-align:center;padding:80px 20px;color:var(--color-text-muted)}.empty-message{text-align:center;padding:60px 20px;color:var(--color-text-muted);background:var(--color-surface);border-radius:var(--radius);border:1px dashed var(--color-border);font-size:1rem}.list-container{margin-top:8px}.requests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.request-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.request-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #8b1a2b1f;border-color:var(--color-accent-border)}.request-card-cover{width:100%;aspect-ratio:2 / 3;background:var(--color-accent-softer);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.request-card-cover img{width:100%;height:100%;object-fit:cover;display:block}.request-cover-placeholder{width:100%;height:100%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:700;letter-spacing:.02em}.request-cover-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.request-cover-loading:before{content:"";width:32px;height:32px;border:3px solid var(--color-accent-softer);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.vote-badge{position:absolute;top:10px;right:10px;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;padding:4px 10px;display:flex;align-items:center;gap:4px;box-shadow:0 2px 8px #0000001f;font-weight:700;color:var(--color-accent);font-size:.85rem}.vote-badge-icon{font-size:.9rem}.request-card-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1}.request-title{font-size:.95rem;font-weight:700;color:var(--color-text);margin:0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.request-author{font-size:.85rem;color:var(--color-text-muted);margin:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.request-isbn{font-size:.75rem;color:var(--color-text-faint);font-family:SF Mono,Monaco,monospace;margin:0}.stem-button{margin-top:auto;padding:9px 12px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease;width:100%;text-align:center}.stem-button:hover:not(.disabled):not(:disabled){background:var(--color-accent-hover)}.stem-button.disabled,.stem-button:disabled{background:#10b98124;color:#059669;border:1.5px solid rgba(16,185,129,.35);cursor:default;font-weight:600}.error-message{padding:10px 14px;background:var(--color-danger-soft);border:1px solid rgba(179,38,30,.2);border-radius:var(--radius-sm);color:var(--color-danger);font-size:.9rem;margin:12px 0}.form-page-header{display:flex;align-items:center;gap:14px;margin-bottom:4px}.form-page-header h1{margin:0}.back-button{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:8px 14px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.back-button:hover{background:var(--color-accent-softer);border-color:var(--color-accent-border);color:var(--color-text)}.form-container{background:var(--color-surface);border-radius:var(--radius);padding:32px 40px;margin-top:24px;border:1px solid var(--color-border);box-shadow:0 1px 3px #0000000a;max-width:820px}.mode-selector{display:flex;gap:4px;margin-bottom:24px;background:var(--color-accent-softer);padding:4px;border-radius:var(--radius-sm);width:fit-content}.mode-selector label{display:flex;align-items:center;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--color-text-muted);padding:8px 16px;border-radius:6px;transition:all .2s ease}.mode-selector label:has(input:checked){background:var(--color-accent);color:#fff}.mode-selector input[type=radio]{display:none}form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:600;color:var(--color-text)}.required{color:var(--color-accent)}.form-group input,.form-group textarea{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;background:#fff;color:var(--color-text);transition:border-color .15s ease,box-shadow .15s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.form-group textarea{resize:vertical;min-height:100px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.cancel-button{padding:10px 18px;background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-button:hover{background:var(--color-accent-softer);border-color:var(--color-accent-border);color:var(--color-text)}.submit-button{padding:10px 20px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease}.submit-button:hover:not(:disabled){background:var(--color-accent-hover)}.submit-button:disabled{background:#ccc;cursor:not-allowed}.vote-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.vote-modal{background:var(--color-surface);border-radius:var(--radius);padding:24px 28px;max-width:480px;width:90%;box-shadow:0 12px 40px #0003}.vote-modal h4{margin:0 0 6px;font-size:1.1rem;font-weight:700;color:var(--color-text)}.modal-subtitle{color:var(--color-text-muted);font-size:.9rem;margin:0 0 16px}.vote-modal textarea{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;margin-bottom:14px;resize:vertical;min-height:90px;box-sizing:border-box}.vote-modal textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.modal-buttons{display:flex;gap:10px;justify-content:flex-end}@media(max-width:1023px){.purchase-request-inner{padding:20px 24px 40px}.requests-grid{gap:20px}}@media(max-width:640px){.purchase-request-inner{padding:16px}.page-header{flex-direction:column;align-items:stretch;gap:12px}.page-header h1{font-size:1.45rem}.primary-button{width:100%}.search-bar{margin:18px 0 24px;padding:10px 14px}.requests-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}.request-card-body{padding:10px 12px 12px;gap:4px}.request-title{font-size:.9rem}.request-author{font-size:.8rem}.stem-button{padding:8px 10px;font-size:.85rem}.form-container{padding:20px}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.form-page-header{flex-wrap:wrap}}.req-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid var(--color-border)}.req-tab-btn{position:relative;padding:8px 16px;border:none;background:none;font-family:inherit;font-size:.92rem;font-weight:600;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s ease,border-color .15s ease}.req-tab-btn:hover{color:var(--color-text)}.req-tab-btn.is-active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.req-loading,.req-empty,.req-error{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);font-size:1rem}.req-error{color:var(--color-danger);background:#fef2f2;border-color:#fecaca}.req-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.req-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease}.req-item:has(.req-item-header[aria-expanded=true]){border-color:var(--color-accent-border);box-shadow:0 4px 12px #0000000d}.req-item-header{display:flex;align-items:center;gap:16px;width:100%;padding:14px 18px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left}.req-item-header:hover{background:var(--color-accent-soft)}.req-item-info{flex:1;min-width:0}.req-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 4px;line-height:1.3;word-break:break-word}.req-sub{font-size:.85rem;color:var(--color-text-muted);margin:0}.req-item-meta{display:flex;align-items:center;gap:12px;flex-shrink:0}.req-vote-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border, var(--color-accent));border-radius:999px;padding:2px 10px;font-size:.78rem;font-weight:700}.req-chevron{font-size:.7rem;color:var(--color-text-muted)}.req-detail{border-top:1px solid var(--color-border);padding:16px 18px;background:var(--color-bg)}.req-detail-isbn{font-size:.85rem;color:var(--color-text-muted);margin:0 0 12px}.req-votes-list{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:10px}.req-vote-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 14px}.req-vote-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;font-size:.88rem}.req-vote-header strong{color:var(--color-text)}.req-vote-date{font-size:.78rem;color:var(--color-text-muted)}.req-vote-motivation{font-size:.88rem;color:var(--color-text);margin:0;line-height:1.5}.req-actions{display:flex;gap:8px;flex-wrap:wrap}.req-btn{padding:6px 14px;border-radius:var(--radius-sm);font-family:inherit;font-size:.82rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:background .15s ease,opacity .15s ease}.req-btn:disabled{opacity:.45;cursor:not-allowed}.req-btn--approve{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.req-btn--approve:hover:not(:disabled){background:#bbf7d0}.req-btn--decline{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.req-btn--decline:hover:not(:disabled){background:#fecaca}.req-btn--reset{background:var(--color-bg);color:var(--color-text-muted);border-color:var(--color-border)}.req-btn--reset:hover:not(:disabled){background:var(--color-accent-soft);color:var(--color-accent);border-color:var(--color-accent)}@media(max-width:640px){.req-item-header{flex-direction:column;align-items:flex-start;gap:8px}.req-item-meta{width:100%;justify-content:space-between}}.user-page-container{background:var(--color-bg);color:var(--color-text);min-height:calc(100vh - 80px)}.ml-section{padding:4px 0;margin-left:4rem;margin-right:4rem}.ml-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px}.ml-title{font-size:1.4rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.01em}.ml-count{font-size:.85rem;color:var(--color-text-muted);font-weight:500}.ml-faint{color:var(--color-text-faint)}.ml-empty{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);font-size:1rem}.ml-list{display:flex;flex-direction:column;gap:10px}.ml-card{display:flex;align-items:center;gap:20px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:16px 20px;transition:border-color .15s ease,box-shadow .15s ease;cursor:pointer}.ml-card:hover{border-color:var(--color-accent-border);box-shadow:0 4px 14px #0000000d}.ml-card-cover{width:64px;height:90px;object-fit:cover;flex-shrink:0;border-radius:6px;border:1px solid var(--color-border);overflow:hidden}.ml-circle-wrap{position:relative;flex-shrink:0;width:68px;height:68px}.ml-circle-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700}.ml-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ml-card-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ml-card-author{margin:0;font-size:.88rem;color:var(--color-text-faint)}.ml-card-due{margin:4px 0 0;font-size:.85rem;color:var(--color-text-muted)}.ml-due--soon{color:#d97706;font-weight:600}.ml-due--overdue{color:var(--color-danger);font-weight:600}.ml-card-msg{margin:2px 0 0;font-size:.78rem;color:#16a34a}.ml-card-msg--error{color:var(--color-danger)}.ml-btn{flex-shrink:0;background:var(--color-surface);color:var(--color-accent);border:1.5px solid var(--color-accent-border);padding:8px 14px;border-radius:var(--radius-sm);font-size:.83rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s ease,border-color .15s ease;white-space:nowrap}.ml-btn:hover:not(:disabled){background:var(--color-accent-soft);border-color:var(--color-accent)}.ml-btn:disabled{opacity:.45;cursor:not-allowed}@media(max-width:640px){.ml-card{flex-wrap:wrap}.ml-btn{width:100%}}.ml-cover-img{width:100%;height:100%;object-fit:cover;display:block}.ml-cover-placeholder{width:100%;height:100%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700}.ml-history{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border)}.ml-history-title{font-size:.78rem;font-weight:700;color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.06em;margin:0 0 12px}.ml-list--history .ml-card{opacity:.6}.ml-list--history .ml-card:hover{opacity:.85}.ml-card--done{background:var(--color-bg)}.ml-done-badge{flex-shrink:0;font-size:.78rem;font-weight:700;color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;padding:4px 10px;border-radius:999px;white-space:nowrap}.ml-filter{display:flex;gap:8px;margin-bottom:20px}.ml-filter-btn{padding:6px 14px;border-radius:999px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);font-size:.83rem;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:inherit}.ml-filter-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-softer)}.ml-filter-btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.ml-filter-btn--active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.ml-card-dates{margin:2px 0 0;font-size:.78rem;color:var(--color-text-faint)}.vote-create-success{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;border-radius:10px;padding:14px 20px;font-weight:600;margin-bottom:20px;display:flex;align-items:center;gap:8px}.vote-form-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:28px;margin-bottom:28px}.vote-form-title{font-size:1.1rem;font-weight:700;color:var(--color-text);margin:0 0 20px}.vote-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.vote-form-field{display:flex;flex-direction:column;gap:6px}.vote-form-field label{font-size:.78rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.vote-form-input{padding:10px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;color:var(--color-text);background:var(--color-bg);font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease;width:100%;box-sizing:border-box}.vote-form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.vote-book-filters{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}.vote-search-input{flex:1;min-width:160px}.vote-filter-select{min-width:160px}.vote-select-all-btn{white-space:nowrap}.vote-book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;max-height:420px;overflow-y:auto;padding:4px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg)}.vote-book-pick{position:relative;cursor:pointer;border-radius:var(--radius-sm);border:2px solid transparent;font:inherit;padding:8px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:border-color .15s ease,background .15s ease;text-align:center;background:var(--color-surface)}.vote-book-pick:hover{border-color:var(--color-accent)}.vote-book-pick-selected{border-color:var(--color-accent);background:#8b1a2b0a}.vote-book-pick-cover{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:4px}.vote-book-pick-check{position:absolute;top:4px;right:4px;background:var(--color-accent);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;box-shadow:0 2px 6px #00000026}.vote-book-pick-title{font-size:.75rem;font-weight:600;color:var(--color-text);margin:0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vote-no-books{grid-column:1 / -1;text-align:center;color:var(--color-text-muted);padding:32px}.vote-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:20px;border-top:1px solid var(--color-border)}.vote-campaign-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px 24px;transition:box-shadow .15s ease;cursor:pointer}.vote-campaign-card:hover{box-shadow:0 4px 16px #0000000f}.vote-campaign-card-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.vote-status-badge{font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.vote-status-active{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.vote-status-closed{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.vote-campaign-date{margin-left:auto;font-size:.82rem;color:var(--color-text-muted)}.vote-campaign-title-text{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 10px}.vote-campaign-books-preview{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.vote-campaign-book-thumb{width:36px;height:54px;object-fit:cover;border-radius:4px;border:1px solid var(--color-border);transition:transform .15s ease}.vote-campaign-book-thumb:hover{transform:scale(1.1)}.vote-campaign-more{font-size:.8rem;font-weight:700;color:var(--color-accent);background:var(--color-accent-soft);border-radius:999px;padding:2px 10px}.vote-campaign-actions{display:flex;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--color-border)}@media(max-width:600px){.vote-form-row{grid-template-columns:1fr}.vote-book-filters{flex-direction:column}}.vote-form-error{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;border-radius:8px;padding:10px 16px;font-size:.9rem;font-weight:600}.vote-detail-modal{background:#fff;border-radius:20px;padding:32px;max-width:600px;width:100%;position:relative;box-shadow:0 24px 64px #0003;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.vote-detail-head{display:flex;flex-direction:column;gap:6px}.vote-detail-title{font-size:1.4rem;font-weight:800;color:#2c2c2c;margin:0}.vote-detail-date{font-size:.88rem;color:#6b6b6b;margin:0}.vote-detail-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#8b1a2b;margin:0 0 12px}.vote-detail-books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:12px}.vote-detail-book{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.vote-detail-book-cover{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:6px;box-shadow:0 2px 8px #0000001a}.vote-detail-book-title{font-size:.72rem;font-weight:600;color:#2c2c2c;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vote-detail-actions{display:flex;justify-content:flex-end;padding-top:12px;border-top:1px solid #ececec}.vote-detail-results{display:flex;flex-direction:column}.vote-form-input-error{border-color:#b91c1c!important;box-shadow:0 0 0 3px #b91c1c1a!important}.vote-book-grid-error{border-color:#b91c1c}.vote-detail-tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border);margin-bottom:16px}.vote-detail-tab{background:none;border:none;padding:10px 18px;font-size:.9rem;font-weight:600;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s ease,border-color .15s ease}.vote-detail-tab:hover{color:var(--color-text)}.vote-detail-tab-active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.vote-detail-info{display:flex;flex-direction:column;gap:12px}.vote-detail-info-row{display:flex;gap:16px;font-size:.9rem;align-items:baseline}.vote-detail-info-label{font-weight:700;color:var(--color-text-muted);min-width:100px;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.badge-section{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.badge-card{background:#fff;border:1.5px solid rgba(139,26,43,.12);border-radius:1rem;padding:1.5rem;box-shadow:0 2px 12px #8b1a2b0f;display:flex;flex-direction:column}.badge-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.badge-card-icon{font-size:2rem;width:52px;height:52px;background:#8b1a2b14;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.badge-card-title{font-size:1.1rem;font-weight:700;color:#2c2c2c;margin:0}.badge-card-sub{font-size:.85rem;color:#6b6b6b;margin:2px 0 0}.badge-card-count{margin-left:auto;background:#fdf2f4;border:1.5px solid rgba(139,26,43,.2);border-radius:.75rem;padding:.4rem .8rem;font-size:1.4rem;font-weight:800;color:#8b1a2b;text-align:center;min-width:56px}.badge-card-count span{display:block;font-size:.7rem;font-weight:500;color:#8b1a2b}.badge-track{display:flex;align-items:flex-start;flex-wrap:wrap;padding-bottom:.5rem;width:100%}.badge-track-entry{display:flex;align-items:center;flex:1;min-width:0}.badge-track-step{display:flex;flex-direction:column;align-items:center;gap:.3rem;width:72px}.badge-track-icon{font-size:1.6rem;width:48px;height:48px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;filter:grayscale(1);opacity:.35;transition:all .2s}.badge-track-step.earned .badge-track-icon{filter:none;opacity:1;background:#8b1a2b14}.badge-track-name{font-size:.68rem;font-weight:600;color:#ccc;text-align:center;max-width:68px;line-height:1.2}.badge-track-step.earned .badge-track-name{color:#2c2c2c}.badge-track-threshold{font-size:.62rem;color:#ccc;text-align:center}.badge-track-step.earned .badge-track-threshold{color:#9b9b9b}.badge-track-entry:last-child{flex:0 0 auto}.badge-track-line{flex:1;height:4px;background:#e0e0e0;border-radius:2px;margin-bottom:28px;min-width:8px}.badge-track-line.earned{background:#8b1a2b}.challenge-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.challenge-empty{color:#9b9b9b;font-size:.9rem;text-align:center;padding:1rem}.challenge-item{display:flex;align-items:center;gap:1rem;background:#faf7f2;border:1.5px solid #ececec;border-radius:.75rem;padding:.9rem 1rem;transition:border-color .2s}.challenge-item.completed{border-color:#8b1a2b40;background:#8b1a2b08}.challenge-check{flex-shrink:0}.challenge-circle{width:20px;height:20px;border-radius:50%;border:2px solid #ccc}.challenge-info{flex:1}.challenge-title{font-weight:600;font-size:.95rem;color:#2c2c2c}.challenge-type{font-size:.78rem;color:#9b9b9b;margin-top:2px}.challenge-progress-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:80px}.challenge-progress-text{font-size:.82rem;font-weight:700;color:#8b1a2b}.challenge-progress-bar{width:80px;height:5px;background:#8b1a2b1f;border-radius:99px;overflow:hidden}.challenge-progress-fill{height:100%;background:#8b1a2b;border-radius:99px;transition:width .3s ease}.challenge-completed-header{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#9b9b9b;padding:.75rem 0 .25rem;border-top:1px solid #ececec;margin-top:.5rem}.challenge-mgmt{padding:2rem}.challenge-mgmt-layout{display:grid;grid-template-columns:380px 1fr;gap:2rem;margin-top:1.5rem;align-items:start}.challenge-form-card,.challenge-list-card{background:#fff;border:1.5px solid rgba(139,26,43,.12);border-radius:1rem;padding:1.5rem;box-shadow:0 2px 8px #8b1a2b0f;display:flex;flex-direction:column;gap:.5rem}.challenge-form-title{font-size:1rem;font-weight:700;color:#2c2c2c;margin:0 0 .75rem}.challenge-label{font-size:.82rem;font-weight:600;color:#6b6b6b;margin-top:.4rem}.challenge-input{border:1.5px solid #ececec;border-radius:8px;padding:.55rem .75rem;font-size:.92rem;color:#1f1f1f;background:#faf7f2;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.challenge-input:focus{border-color:#8b1a2b}.challenge-save-btn{margin-top:.75rem;background:#8b1a2b;color:#fff;border:none;border-radius:8px;padding:.7rem 1.25rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.challenge-save-btn:hover{background:#6e1432}.challenge-save-btn:disabled{opacity:.6;cursor:not-allowed}.challenge-error{color:#c0392b;font-size:.82rem;margin:0}.challenge-mgmt-item{display:flex;align-items:center;justify-content:space-between;padding:.85rem 0;border-bottom:1px solid #ececec;gap:1rem}.challenge-mgmt-item:last-child{border-bottom:none}.challenge-mgmt-title{font-weight:600;font-size:.92rem;color:#2c2c2c}.challenge-mgmt-meta{font-size:.78rem;color:#9b9b9b;margin-top:2px}.challenge-delete-btn{background:#fbf1ef;color:#c0392b;border:1.5px solid rgba(192,57,43,.2);border-radius:8px;padding:.4rem .85rem;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.challenge-delete-btn:hover{background:#f8eae7}.challenge-empty-msg{color:#9b9b9b;font-size:.88rem;text-align:center;padding:1rem}.challenge-hint{font-size:.78rem;color:#9b9b9b;margin:0}.challenge-mgmt-item.expired{opacity:.6}.challenge-expired-tag{margin-left:.5rem;background:#faf0ef;color:#c0392b;font-size:.72rem;font-weight:600;padding:.15rem .5rem;border-radius:99px;border:1px solid rgba(192,57,43,.2)}._page_x3kn9_1{max-width:1080px;margin:0 auto;padding:2.5rem 1.5rem 5rem}._hero_x3kn9_8{background:linear-gradient(135deg,#0c5c50,#1a4db5);border-radius:20px;padding:2.75rem 2.5rem 2.5rem;margin-bottom:2.5rem;position:relative;overflow:hidden;color:#fff}._hero_x3kn9_8:before{content:"";position:absolute;width:360px;height:360px;background:#ffffff0e;border-radius:50%;top:-120px;right:-80px;pointer-events:none}._hero_x3kn9_8:after{content:"";position:absolute;width:220px;height:220px;background:#ffffff0a;border-radius:50%;bottom:-70px;right:160px;pointer-events:none}._heroBadge_x3kn9_42{display:inline-flex;align-items:center;gap:.4rem;background:#0000004d;border:1px solid rgba(255,255,255,.25);color:#fff;font-size:.78rem;font-weight:600;padding:.3rem .75rem;border-radius:20px;letter-spacing:.03em;margin-bottom:.9rem}._heroTitle_x3kn9_57{font-size:2.1rem;font-weight:800;margin:0 0 .6rem;color:#fff;display:flex;align-items:center;gap:.65rem;letter-spacing:-.02em;line-height:1.15}._heroTitle_x3kn9_57 i{font-size:1.9rem;opacity:.9}._heroSub_x3kn9_74{font-size:1rem;color:#ffffffbf;margin:0 0 1.5rem;max-width:500px;line-height:1.55}._heroStats_x3kn9_82{display:flex;gap:.65rem;flex-wrap:wrap}._heroStat_x3kn9_82{display:inline-flex;align-items:center;gap:.35rem;background:#00000040;border:1px solid rgba(255,255,255,.18);color:#fff;font-size:.8rem;font-weight:600;padding:.3rem .7rem;border-radius:8px}._grid_x3kn9_102{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;align-items:start}@media(max-width:640px){._grid_x3kn9_102{grid-template-columns:1fr}._hero_x3kn9_8{padding:1.75rem 1.5rem 1.5rem}._heroTitle_x3kn9_57{font-size:1.6rem}}._card_x3kn9_122{border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 1px 4px #0000000a,0 2px 10px #0000000a;transition:box-shadow .18s ease,transform .18s ease}._card_x3kn9_122:hover{box-shadow:0 4px 16px #00000017,0 1px 4px #0000000d;transform:translateY(-2px)}._cardHeader_x3kn9_137{display:flex;align-items:center;gap:.65rem;padding:1rem 1.25rem;border-left:4px solid transparent}._cardIcon_x3kn9_145{font-size:1.3rem;display:flex;align-items:center;flex-shrink:0}._cardTitle_x3kn9_152{font-size:.95rem;font-weight:700;margin:0;flex:1;color:#111827;letter-spacing:-.005em}._countBadge_x3kn9_161{font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.02em}._cardBody_x3kn9_170{padding:.25rem 0}._item_x3kn9_175{border-bottom:1px solid #f3f4f6}._item_x3kn9_175:last-child{border-bottom:none}._question_x3kn9_184{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.9rem 1.25rem;background:none;border:none;cursor:pointer;text-align:left;font-size:.9rem;font-weight:500;color:#1f2937;line-height:1.5;transition:background .13s,color .13s}._question_x3kn9_184:hover{background:#f9fafb}._chevron_x3kn9_206{font-size:13px;flex-shrink:0;margin-top:3px;transition:transform .22s ease;color:#9ca3af}._chevronOpen_x3kn9_214{transform:rotate(180deg);color:inherit}._itemOpen_x3kn9_219 ._question_x3kn9_184{font-weight:600;background:transparent}._answer_x3kn9_225{margin:.1rem 1rem 1rem;padding:.85rem 1rem;font-size:.92rem;color:#374151;line-height:1.8;border-left:3px solid transparent;border-radius:8px;animation:_fadeSlideIn_x3kn9_1 .18s ease}@keyframes _fadeSlideIn_x3kn9_1{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ps-section{display:flex;flex-direction:column;gap:1.25rem;padding:.25rem 0 1.5rem}.ps-faint{color:var(--color-text-faint);padding:1rem 0;font-size:.9rem}.ps-pills{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.ps-pill{display:flex;align-items:center;gap:1.1rem;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.15rem;transition:box-shadow .15s,border-color .15s}.ps-pill:hover{box-shadow:0 4px 16px #00000012;border-color:color-mix(in srgb,var(--ps-color, #8b1a2b) 35%,transparent)}.ps-pill-icon{font-size:1.45rem;width:52px;height:52px;border-radius:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ps-pill-body{display:flex;flex-direction:column;gap:3px}.ps-pill-value{font-size:2rem;font-weight:800;line-height:1}.ps-pill-label{font-size:.72rem;font-weight:600;color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.06em}.ps-filter{display:flex;gap:.5rem;background:var(--color-bg, #f7f5f2);border-radius:.75rem;padding:.3rem;margin-bottom:.25rem;width:fit-content}.ps-filter-btn{padding:.45rem 1.1rem;border-radius:.55rem;border:none;background:transparent;font-size:.85rem;font-weight:600;color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s,box-shadow .15s;white-space:nowrap}.ps-filter-btn:hover{background:#ffffffb3;color:var(--color-text)}.ps-filter-btn--active{background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 4px #0000001a}.ps-rings{display:flex;align-items:center;justify-content:center;gap:3rem;padding:1.25rem 0 .75rem;flex-wrap:wrap}.ps-rings-divider{width:1px;height:90px;background:var(--color-border)}.ps-ring-wrap{display:flex;flex-direction:column;align-items:center;gap:.6rem;position:relative}.ps-ring-wrap svg{display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.12))}.ps-ring-inner{position:absolute;top:0;left:0;width:124px;height:124px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.ps-ring-pct{font-size:.65rem;font-weight:700;color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.1em;line-height:1}.ps-ring-num{font-size:1.55rem;font-weight:800;line-height:1}.ps-ring-label{font-size:.85rem;font-weight:600;color:var(--color-text-muted)}.ps-rings-note{font-size:.75rem;color:var(--color-text-faint);text-align:center;margin:.25rem 0 0;padding-top:.75rem;border-top:1px solid var(--color-border)}@media(max-width:480px){.ps-pills{grid-template-columns:1fr 1fr;gap:.6rem}.ps-pill{padding:1rem .9rem;gap:.8rem}.ps-pill-icon{width:44px;height:44px}.ps-pill-value{font-size:1.65rem}.ps-rings{gap:2rem}.ps-rings-divider{display:none}}.loan-loading,.loan-empty,.loan-error{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);font-size:1rem}.permission-denied{display:inline-block;background:var(--color-danger);border:1px solid var(--color-danger);color:#fff;border-radius:999px;padding:1px 8px;font-size:.72rem;font-weight:600;line-height:1.4;margin-right:8px}.loan-error{color:var(--color-danger);background:#fef2f2;border-color:#fecaca}.loan-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.loan-item{display:flex;align-items:center;gap:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:14px 18px;transition:border-color .15s ease,box-shadow .15s ease}.loan-item:hover{border-color:var(--color-accent-border);box-shadow:0 4px 12px #0000000a}.loan-item.is-overdue{border-color:#fecaca;background:#fff8f8}.loan-info{flex:1;min-width:0}.loan-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 4px;line-height:1.3;word-break:break-word}.loan-sub{font-size:.85rem;color:var(--color-text-muted);margin:0;line-height:1.4}.loan-sub strong{color:var(--color-text);font-weight:600}.loan-copy-tag{display:inline-block;background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:999px;padding:1px 8px;font-size:.72rem;font-weight:600;margin-right:6px}.loan-due{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;text-align:right;min-width:130px}.loan-due-label{font-size:.7rem;font-weight:700;color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.loan-due-date{font-size:.92rem;font-weight:600;color:var(--color-text)}.loan-due-status{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:4px;padding:2px 8px;border-radius:999px;border:1px solid transparent}.loan-due-status--ok{color:var(--color-text-muted);background:var(--color-bg);border-color:var(--color-border)}.loan-due-status--soon{color:#c2410c;background:#fff7ed;border-color:#fed7aa}.loan-due-status--overdue{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.loan-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px}.loan-page-btn{min-width:38px;height:38px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.92rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;font-family:inherit}.loan-page-btn:hover:not(:disabled){background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent)}.loan-page-btn:disabled{opacity:.35;cursor:not-allowed}.loan-page-btn.is-active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.loan-page-btn.is-active:hover{background:var(--color-accent-hover);color:#fff;border-color:var(--color-accent-hover)}.loan-page-dots{color:var(--color-text-faint);padding:0 4px}@media(max-width:640px){.loan-item{flex-direction:column;align-items:flex-start;padding:14px 16px}.loan-due{align-items:flex-start;text-align:left;min-width:0}}.loan-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid var(--color-border);padding-bottom:0}.loan-tab-btn{position:relative;padding:8px 16px;border:none;background:none;font-family:inherit;font-size:.92rem;font-weight:600;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s ease,border-color .15s ease}.loan-tab-btn:hover{color:var(--color-text)}.loan-tab-btn.is-active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.loan-tab-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--color-accent);color:#fff;font-size:.68rem;font-weight:700;border-radius:999px;min-width:18px;height:18px;padding:0 5px;margin-left:6px}.loan-ext-actions{display:flex;gap:8px;flex-shrink:0}.loan-ext-btn{padding:6px 14px;border-radius:var(--radius-sm);font-family:inherit;font-size:.82rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:background .15s ease,opacity .15s ease}.loan-ext-btn:disabled{opacity:.45;cursor:not-allowed}.loan-ext-btn--approve{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.loan-ext-btn--approve:hover:not(:disabled){background:#bbf7d0}.loan-ext-btn--decline{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.loan-ext-btn--decline:hover:not(:disabled){background:#fecaca}.sanction-moderation-toggle{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px;border-radius:6px;opacity:.5;transition:opacity .2s ease,background .2s ease;border:1px solid var(--color-text-muted)}.sanction-moderation-toggle:hover{opacity:1;background:#0000000d}.low-prio{background:#adff2f;border:1px solid greenyellow}.mid-prio{background:orange;border:1px solid orange;color:#000}.high-prio{background:var(--color-danger);border:1px solid var(--color-danger);color:#fff}.catalog-dropbtn-sort{background:var(--color-accent);color:#fff;border:none;padding:9px 16px;border-radius:10px;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s ease;white-space:nowrap}.wishlist-section{--color-accent-hover: #6e1432;--color-accent-soft: rgba(139, 27, 63, .08);--color-accent-softer: rgba(139, 27, 63, .04);--color-accent-border: rgba(139, 27, 63, .18);--color-leefwereld: #2563eb;--color-leefwereld-soft: rgba(37, 99, 235, .08);--color-leefwereld-border: rgba(37, 99, 235, .18);--color-bg: #f7f5f2;--color-surface: #ffffff;--color-border: #ececec;--color-text: #1f1f1f;--color-text-muted: #6b6b6b;--color-text-faint: #9b9b9b;--toolbar-h: 124px;--radius: 12px;--radius-sm: 8px;padding:4px 0;margin-left:4rem;margin-right:4rem}.wishlist-header{gap:12px;margin-bottom:18px}.wishlist-title{font-size:1.4rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.01em}.wishlist-count{display:inline;font-size:.85rem;color:var(--color-text-muted);font-weight:500}.wishlist-empty{text-align:center;color:var(--color-text-muted);padding:60px 20px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius);font-size:1rem}.wishlist-grid{display:grid;gap:22px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.catalog-item-body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:4px;flex:1}.catalog-item-title{font-size:.98rem;font-weight:700;color:var(--color-text);margin:0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catalog-item-author{font-size:.85rem;color:var(--color-text-muted);margin:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.catalog-item-meta{font-size:.75rem;color:var(--color-text-faint);margin-top:2px}.catalog-item-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto;padding-top:8px}.catalog-tag{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:600;background:var(--color-accent-soft);color:var(--color-accent);border:1px solid var(--color-accent-border)}.catalog-tag-leefwereld{background:var(--color-leefwereld-soft);color:var(--color-leefwereld);border-color:var(--color-leefwereld-border)}.catalog-tag-more{background:transparent;color:var(--color-text-muted);border-color:var(--color-border)}@media(max-width:640px){.wishlist-grid{gap:14px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}
