:root{--navy: #2ba6e2;--navy-grad: linear-gradient(105deg, #36b4ec 0%, #1f93d4 100%);--navy-2: #1f93d4;--navy-3: #1a7eba;--bg: #fff8ec;--surface: #ffffff;--surface-2: #fffaf0;--ink: #28384a;--ink-2: #44586a;--muted: #6a7c8a;--muted-2: #93a3ad;--link: #1aa6c2;--link-hover: #f7941e;--yellow: #f7941e;--yellow-hover: #ec8513;--btn: #f9a01b;--btn-hover: #ee8f10;--btn-border: #e0820f;--border: #e9e1d2;--border-2: #c7d4dc;--control: #eaf5fb;--control-hover: #d8ecf7;--ring: rgba(43, 166, 226, .4);--chip-bg: #def1fb;--chip-ink: #1487b1;--pink: #ff7eb3;--pink-soft: #ffe6f0;--shadow-sm: 0 1px 2px rgba(31, 147, 212, .1);--shadow: 0 3px 10px rgba(31, 147, 212, .14);--shadow-lg: 0 12px 28px rgba(31, 147, 212, .22);--radius: 16px;--radius-sm: 10px}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:radial-gradient(900px 480px at 100% -12%,#e2f3fb 0%,transparent 58%),radial-gradient(760px 420px at -6% 0%,#fff3d6 0%,transparent 55%),var(--bg);background-attachment:fixed;color:var(--ink);font-family:Inter,Amazon Ember,Arial,system-ui,-apple-system,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.app{min-height:100vh;display:flex;flex-direction:column}.hdr{position:sticky;top:0;z-index:30}.hdr-bar{display:flex;align-items:center;gap:12px;background:var(--navy-grad);padding:6px 14px}.hdr-logo{display:flex;align-items:center;gap:8px;color:#fff;padding:8px 9px;border-radius:3px;border:1px solid transparent;white-space:nowrap}.hdr-logo:hover{border-color:#fff}.hdr-logo-mark{font-size:1.45rem;line-height:1}.hdr-logo-text{font-weight:800;font-size:1.3rem;letter-spacing:-.5px}.hdr-logo-accent{color:var(--yellow)}.hdr-search{flex:1 1 auto;max-width:820px;display:flex;height:40px;border-radius:var(--radius);overflow:hidden;background:#fff}.hdr-search:focus-within{box-shadow:0 0 0 3px var(--yellow);border-radius:var(--radius)}.hdr-search-scope{display:flex;align-items:center;padding:0 12px;background:var(--control);color:#555;font-size:.8rem;border-right:1px solid #cdcdcd;white-space:nowrap}.hdr-search-input{flex:1;min-width:0;border:none;border-radius:0;height:100%;padding:0 14px;font-size:.95rem;color:var(--ink)}.hdr-search-input:focus{outline:none;border:none;box-shadow:none}.hdr-search-btn{width:46px;border:none;border-radius:0;background:var(--yellow);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:none}.hdr-search-btn:hover{background:var(--yellow-hover)}.hdr-nav{display:flex;align-items:center;gap:2px}.hdr-nav-item{display:flex;flex-direction:column;line-height:1.2;color:#fff;padding:7px 9px;border-radius:3px;border:1px solid transparent;white-space:nowrap}.hdr-nav-item:hover{border-color:#fff}.hdr-nav-l1{font-size:.72rem;color:#d9dbdc}.hdr-nav-l2{font-size:.86rem;font-weight:700}.hdr-sub{display:flex;align-items:center;gap:6px;background:var(--navy-2);color:#fff;padding:7px 12px;font-size:.88rem}.hdr-sub-all{display:inline-flex;align-items:center;gap:6px;font-weight:700;padding:4px 8px;border-radius:3px;border:1px solid transparent}.hdr-sub-burger{font-size:1rem}.hdr-sub a{color:#fff;padding:4px 8px;border-radius:3px;border:1px solid transparent}.hdr-sub-all:hover,.hdr-sub a:hover{border-color:#fff}.hdr-sub-tag{margin-left:auto;color:#cdd3d8;font-size:.82rem}.content{flex:1;width:100%;max-width:1500px;margin:0 auto;padding:16px 18px 48px}.ftr{margin-top:auto;background:var(--navy-2);color:#fff}.ftr-top{display:block;text-align:center;background:var(--navy-3);color:#fff;padding:14px;font-size:.85rem}.ftr-top:hover{background:#485769}.ftr-body{text-align:center;padding:26px 16px 34px}.ftr-brand{font-weight:800;font-size:1.2rem;letter-spacing:-.5px;display:inline-flex;align-items:center;gap:8px}.ftr-note{color:#aeb6bd;font-size:.8rem;margin:10px 0 0}.catalog{display:grid;grid-template-columns:248px 1fr;gap:18px;align-items:start}.rail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;position:sticky;top:104px}.rail-group{padding:12px 0;border-bottom:1px solid #ededed}.rail-group:last-child{border-bottom:none}.rail-title{margin:0 0 8px;font-size:.95rem;font-weight:800;color:#1f93d4}.rail select{width:100%}.results{min-width:0}.results-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:16px}.results-count{margin:0;font-size:1.05rem;color:var(--ink)}.results-count strong{font-weight:700}.results-q{font-weight:700;color:var(--link-hover)}.results-sort{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--muted)}input,select,textarea{font:inherit;padding:9px 12px;border:1px solid var(--border-2);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);outline:none;transition:box-shadow .12s ease,border-color .12s ease}select{cursor:pointer;background:var(--control);border-color:#cdcfcf}select:hover{background:var(--control-hover)}input::placeholder{color:#8a8f8f}input:focus,select:focus,textarea:focus{border-color:#e77600;box-shadow:0 0 0 3px var(--ring)}.filter-check{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:var(--ink-2);cursor:pointer}.filter-check input{width:16px;height:16px;padding:0;margin:0;accent-color:var(--navy-2);cursor:pointer}.search{width:100%}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}.card{display:flex;flex-direction:column;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;transition:box-shadow .15s ease,border-color .15s ease}.card:hover{box-shadow:var(--shadow-lg);border-color:#c3c8c8}.card:hover .card-title{color:var(--link-hover)}.cover{position:relative;background:#fff;overflow:hidden}.cover img{width:100%;height:100%;object-fit:contain;display:block}.cover-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#1aa6c2;font-weight:800;font-size:2.6rem;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#dff2fb,#eaf7ee,#fff3d6)}.cover-card{aspect-ratio:3 / 4;margin:-14px -14px 8px;padding:10px;background:#fff;border-bottom:1px solid #eee}.cover-detail{flex:0 0 240px;width:240px;aspect-ratio:3 / 4;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:#fff}.card-title{margin:0;font-size:1rem;font-weight:500;line-height:1.3;color:var(--link);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .12s ease}.card-author{margin:0;color:var(--muted);font-size:.85rem}.card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px}.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:8px;border-top:1px solid #f0f0f0}.book-no{font-size:.74rem;font-weight:600;color:var(--muted-2);font-variant-numeric:tabular-nums}.chip{background:var(--chip-bg);color:var(--chip-ink);font-size:.72rem;padding:3px 9px;border-radius:var(--radius-sm);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.loc{font-size:.78rem;color:var(--muted);white-space:nowrap}.badge{font-size:.66rem;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px;display:inline-flex;align-items:center;border:1px solid transparent}.badge-available{background:#e6f4ea;color:#007600;border-color:#c2e6cc}.badge-missing{background:#fdeaea;color:#b12704;border-color:#f6cfcf}.badge-cancelled{background:#eef1f3;color:#5b6b78;border-color:#dde3e8}.badge-unknown{background:#f3f4f6;color:#6f7373;border-color:#e2e5e7}.load-more{display:flex;justify-content:center;padding:28px 0 8px}.list-end{text-align:center;font-size:.85rem;padding:26px 0 8px}.loading{padding:22px 0}.muted{color:var(--muted)}.pagination{display:flex;gap:8px;align-items:center;justify-content:center;margin:28px 0 10px;flex-wrap:wrap}.page-info{color:var(--muted);font-size:.9rem;padding:0 10px;font-variant-numeric:tabular-nums}button{font:inherit;cursor:pointer;border:1px solid var(--btn-border);background:var(--btn);color:#fff;padding:9px 18px;border-radius:999px;font-weight:600;box-shadow:var(--shadow-sm);transition:background .12s ease,box-shadow .12s ease,transform .1s ease}button:hover:not(:disabled){background:var(--btn-hover);box-shadow:var(--shadow)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}button.secondary{background:var(--control);color:var(--ink);border:1px solid #cdcfcf}button.secondary:hover:not(:disabled){background:var(--control-hover)}button.link{background:none;border:none;color:var(--link);padding:4px 8px;box-shadow:none;font-weight:600}button.link:hover:not(:disabled){background:none;color:var(--link-hover);text-decoration:underline;box-shadow:none}button.link.danger{color:#b12704}.empty,.error{padding:18px 20px;border-radius:var(--radius);margin:12px 0;background:var(--surface);border:1px solid var(--border)}.empty{border-style:dashed;color:var(--muted);text-align:center}.error{background:#fff4f4;color:#b12704;border-color:#f3c9c9}.detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}.back{color:var(--link);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:4px;margin-bottom:18px}.back:hover{color:var(--link-hover);text-decoration:underline}.detail-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:22px;padding-bottom:20px;border-bottom:1px solid var(--border)}.detail-head h1{margin:0;font-size:1.7rem;font-weight:600;letter-spacing:-.3px}.detail-body{display:flex;gap:32px;align-items:flex-start;flex-wrap:wrap}.detail-table{flex:1;min-width:280px;border-collapse:collapse}.detail-table th,.detail-table td{text-align:left;padding:12px 14px;border-bottom:1px solid #ededed;vertical-align:top}.detail-table tr:last-child th,.detail-table tr:last-child td{border-bottom:none}.detail-table th{width:200px;color:var(--muted);font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.5px}.detail-table td{font-size:.95rem;color:var(--ink-2)}.login-wrap{display:flex;justify-content:center;padding-top:6vh}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow)}.login-card input{width:100%}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.page-head h1{margin:0;font-size:1.5rem;font-weight:700}.admin h1{font-size:1.5rem;font-weight:700}.admin-table,.admin-table th,.admin-table td{border-collapse:collapse}.admin-table{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-top:14px;box-shadow:var(--shadow-sm)}.admin-table th,.admin-table td{text-align:left;padding:11px 14px;border-bottom:1px solid #ededed;font-size:.92rem}.admin-table tbody tr{transition:background .1s ease}.admin-table tbody tr:hover{background:var(--surface-2)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table thead th{background:var(--navy-2);color:#fff;font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.5px}.admin-table .t-title{font-weight:600;color:var(--link)}.row-actions{white-space:nowrap;text-align:right}.admin .search{width:100%;margin-bottom:4px}.book-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px;max-width:640px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-sm)}.book-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.82rem;color:var(--ink)}.book-form input,.book-form select,.book-form textarea{font-weight:400}.form-row{display:flex;gap:16px}.form-row label{flex:1}.form-actions{display:flex;gap:10px;margin-top:8px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.grid>.card,.detail,.login-card,.book-form{animation:fade-in .25s ease both}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:900px){.catalog{grid-template-columns:1fr}.rail{position:static;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:4px 16px}.rail-group{border-bottom:none;padding:8px 0}}@media(max-width:640px){.content{padding:12px 12px 40px}.hdr-bar{flex-wrap:wrap;gap:8px;padding:6px 10px}.hdr-search{order:3;flex-basis:100%;max-width:none}.hdr-logo{padding:6px 4px}.hdr-logo-text{font-size:1.1rem}.hdr-nav{margin-left:auto}.hdr-nav-item{padding:6px}.hdr-nav-l1{font-size:.66rem}.hdr-nav-l2{font-size:.8rem}.hdr-sub{padding:6px 10px}.hdr-sub-tag{display:none}.grid{grid-template-columns:repeat(2,1fr);gap:12px}.card{padding:10px;border-radius:var(--radius-sm)}.cover-card{margin:-10px -10px 6px;padding:8px}.card-title{font-size:.9rem}.card-author{font-size:.78rem}.results-bar{padding:10px 12px}.results-count{font-size:.95rem}.detail{padding:16px}.detail-head h1{font-size:1.3rem}.detail-body{gap:18px}.cover-detail{flex-basis:auto;width:100%;max-width:220px;margin:0 auto}.detail-table{min-width:0}.detail-table th{width:120px;font-size:.68rem;padding:10px 8px}.detail-table td{font-size:.9rem;padding:10px 8px}.form-row{flex-direction:column;gap:16px}.admin-table{font-size:.82rem}.page-head{flex-wrap:wrap}.book-form,.detail{padding:16px}}@media(max-width:360px){.grid{gap:8px}.chip{max-width:100%}}
