:root{--color-bg: #F5F5F7;--color-surface: #FFFFFF;--color-surface-2: #F9F9F9;--color-border: rgba(0, 0, 0, .08);--color-border-strong: rgba(0, 0, 0, .14);--color-accent: #E4002B;--color-accent-hover: #C8002A;--color-accent-light: #FFF0F2;--color-accent-glow: rgba(228, 0, 43, .15);--color-text-primary: #1A1A2E;--color-text-secondary: #6B7280;--color-text-tertiary: #9CA3AF;--color-text-inverse: #FFFFFF;--color-available: #10B981;--color-available-bg: #ECFDF5;--color-borrowed: #F59E0B;--color-borrowed-bg: #FFFBEB;--color-reserved: #3B82F6;--color-reserved-bg: #EFF6FF;--color-overdue: #EF4444;--color-overdue-bg: #FEF2F2;--color-ebook: #8B5CF6;--color-ebook-bg: #F5F3FF;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08), 0 2px 6px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .1), 0 4px 12px rgba(0, 0, 0, .06);--shadow-card: 0 2px 20px rgba(0, 0, 0, .07);--shadow-accent: 0 4px 20px var(--color-accent-glow);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Outfit", "Inter", sans-serif;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--nav-height: 72px;--nav-safe-area: max(env(safe-area-inset-bottom), 8px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}a,button,select,input,textarea{outline:none}a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-weight:400;line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100dvh;display:flex;flex-direction:column}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;background:none;outline:none}input,textarea,select{font-family:inherit;outline:none;border:none;background:none}a{text-decoration:none;color:inherit}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-layout{display:flex;flex-direction:column;min-height:100dvh;width:100%;max-width:480px;margin:0 auto;background:var(--color-surface);position:relative;overflow-x:hidden}.page-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:calc(var(--nav-height) + var(--nav-safe-area) + 24px);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;container-type:inline-size}:root{--sidebar-w: 0px}@media(min-width:768px){:root{--sidebar-w: 60px}html{height:100%;overflow:hidden}body{height:100%;overflow:hidden;font-size:13px}#root{height:100%;overflow:hidden}.app-layout{max-width:100%;width:100%;height:100%;display:flex;flex-direction:row;margin:0;background:var(--color-bg);overflow:hidden}.page-content{flex:1;min-width:0;height:100%;overflow-y:auto;overflow-x:hidden;padding:14px 16px;background:var(--color-bg);scroll-behavior:smooth;container-type:inline-size}.page-title{font-size:clamp(15px,1.5vw,22px)!important}.page-subtitle{font-size:clamp(11px,.85vw,13px)!important}.section{padding:12px 0 0!important}.section-title{font-size:clamp(13px,1.1vw,16px)!important}}@media(min-width:1100px){:root{--sidebar-w: clamp(180px, 14vw, 220px)}.page-content{padding:clamp(14px,1.4vw,22px) clamp(16px,2vw,28px)}body{font-size:clamp(12px,1vw,14px)}}@media(min-width:1440px){:root{--sidebar-w: clamp(200px, 15vw, 250px)}.page-content{padding:clamp(16px,1.5vw,28px) clamp(20px,2.5vw,40px)}}@media(min-width:1920px){:root{--sidebar-w: 260px}.page-content{padding:28px 48px}body{font-size:14px}}.page-header{padding:20px 20px 0;position:sticky;top:0;z-index:100;background:var(--color-surface)}.page-title{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.5px;line-height:1.2}.page-subtitle{font-size:14px;color:var(--color-text-secondary);margin-top:4px}.card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}.card:active{transform:scale(.98)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-weight:600;font-size:15px;line-height:1;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn-primary{background:var(--color-accent);color:var(--color-text-inverse);padding:14px 24px;box-shadow:var(--shadow-accent)}.btn-primary:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 6px 24px var(--color-accent-glow)}.btn-primary:active{transform:translateY(0) scale(.97);box-shadow:var(--shadow-accent)}.btn-secondary{background:var(--color-accent-light);color:var(--color-accent);padding:14px 24px}.btn-secondary:hover{background:#e4002b1f}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:10px 16px;border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-bg);border-color:var(--color-border-strong)}.btn-sm{font-size:13px;padding:8px 16px}.btn-lg{font-size:17px;padding:16px 32px}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;line-height:1}.status-available{background:var(--color-available-bg);color:var(--color-available)}.status-borrowed{background:var(--color-borrowed-bg);color:var(--color-borrowed)}.status-reserved{background:var(--color-reserved-bg);color:var(--color-reserved)}.status-overdue{background:var(--color-overdue-bg);color:var(--color-overdue)}.status-ebook{background:var(--color-ebook-bg);color:var(--color-ebook)}.input-wrapper{position:relative;display:flex;align-items:center}.input{width:100%;height:48px;padding:0 16px;background:var(--color-bg);border:1.5px solid transparent;border-radius:var(--radius-md);font-size:15px;color:var(--color-text-primary);transition:all var(--transition-fast)}.input:focus{border-color:var(--color-accent);background:var(--color-surface);box-shadow:0 0 0 3px var(--color-accent-glow)}.input::placeholder{color:var(--color-text-tertiary)}.input-icon{position:absolute;left:14px;color:var(--color-text-tertiary);pointer-events:none}.input.has-icon{padding-left:44px}.search-bar{display:flex;align-items:center;gap:8px;background:var(--color-bg);border-radius:var(--radius-xl);padding:12px 16px;border:1.5px solid transparent;transition:all var(--transition-fast)}.search-bar:focus-within{background:var(--color-surface);border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.search-bar input{flex:1;font-size:15px;color:var(--color-text-primary);background:none}.search-bar input::placeholder{color:var(--color-text-tertiary)}.filter-chips{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:2px 4px}.filter-chips::-webkit-scrollbar{display:none}.chip{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;background:var(--color-bg);color:var(--color-text-secondary);border:1.5px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.chip:hover{border-color:var(--color-accent);color:var(--color-accent)}.chip.active{background:var(--color-accent);color:var(--color-text-inverse);border-color:var(--color-accent)}.section{padding:24px 20px 0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.3px}.section-link{font-size:14px;font-weight:500;color:var(--color-accent);cursor:pointer}.book-cover{aspect-ratio:2/3;border-radius:var(--radius-md);overflow:hidden;background:linear-gradient(135deg,#f0f0f5,#e0e0e8);position:relative;flex-shrink:0}.book-cover img{width:100%;height:100%;object-fit:cover}.book-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px;background:linear-gradient(135deg,#ffe4e9,#ffd4dc)}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 37%,#f0f0f0 63%);background-size:800px 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--radius-sm)}.stars{display:flex;gap:2px}.star{color:#f59e0b;font-size:14px}.star.empty{color:var(--color-border-strong)}.avatar{border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--color-accent-light);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:var(--color-accent)}.avatar-sm{width:32px;height:32px;font-size:12px}.avatar-md{width:44px;height:44px;font-size:16px}.avatar-lg{width:64px;height:64px;font-size:22px}.avatar-xl{width:88px;height:88px;font-size:32px}.avatar img{width:100%;height:100%;object-fit:cover}.progress-bar{height:4px;background:var(--color-bg);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width var(--transition-slow)}.divider{height:1px;background:var(--color-border);margin:16px 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 32px;text-align:center}.empty-state-icon{font-size:56px;margin-bottom:20px}.empty-state-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--color-text-primary);margin-bottom:8px}.empty-state-text{font-size:14px;color:var(--color-text-secondary);line-height:1.6}.toast-wrapper{font-family:var(--font-sans);font-size:14px;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:0}.modal-sheet{background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-height:90dvh;overflow-y:auto;padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom))}.modal-handle{width:36px;height:4px;background:var(--color-border-strong);border-radius:var(--radius-full);margin:0 auto 20px}.points-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:linear-gradient(135deg,#fff7ed,#fef3c7);color:#d97706;border-radius:var(--radius-full);font-size:12px;font-weight:700}.gamification-card{background:linear-gradient(135deg,var(--color-accent) 0%,#FF1744 100%);color:#fff;border-radius:var(--radius-xl);padding:20px}.horizontal-scroll{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:4px 20px 16px;margin:0 -20px}.horizontal-scroll::-webkit-scrollbar{display:none}@media(min-width:768px){.horizontal-scroll{scrollbar-width:thin;scrollbar-color:rgba(228,0,43,.2) transparent;padding-bottom:8px}.horizontal-scroll::-webkit-scrollbar{display:block;height:5px}.horizontal-scroll::-webkit-scrollbar-track{background:transparent}.horizontal-scroll::-webkit-scrollbar-thumb{background:#0000001a;border-radius:9999px;transition:background var(--transition-base)}.horizontal-scroll:hover::-webkit-scrollbar-thumb{background:#e4002b59}}.horizontal-scroll>*{scroll-snap-align:start;flex-shrink:0}.carousel-container-relative{position:relative;width:100%}.carousel-btn{display:none}@media(min-width:768px){.carousel-btn{display:flex;align-items:center;justify-content:center;position:absolute;top:calc(50% - 28px);width:40px;height:40px;border-radius:50%;background:#ffffffbf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,.08);box-shadow:0 4px 12px #0000001a;color:var(--color-text-primary);cursor:pointer;z-index:10;transition:all var(--transition-base);opacity:0}.carousel-container-relative:hover .carousel-btn{opacity:1}.carousel-btn-left{left:8px}.carousel-btn-right{right:8px}.carousel-btn:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:0 4px 16px var(--color-accent-glow);transform:scale(1.1)}.carousel-btn:active{transform:scale(.95)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-base) both}.animate-fade-in-up{animation:fadeInUp var(--transition-base) both}.animate-scale-in{animation:scaleIn var(--transition-base) both}.delay-1{animation-delay:50ms}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}.delay-4{animation-delay:.2s}.delay-5{animation-delay:.25s}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:24px;height:24px;border:2.5px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent)}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-lg{font-size:17px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-display{font-family:var(--font-display)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.flex-1{flex:1}.px-5{padding-left:20px;padding-right:20px}.py-4{padding-top:16px;padding-bottom:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}._nav_1kb69_6{position:fixed;bottom:0;left:0;right:0;z-index:500;background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.07);padding-bottom:max(env(safe-area-inset-bottom),8px)}._inner_1kb69_19{display:flex;align-items:stretch;width:100%;max-width:480px;margin:0 auto;height:60px}._item_1kb69_28{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);color:#9ca3af;text-decoration:none;position:relative}._item_1kb69_28:active{transform:scale(.92)}._item_1kb69_28._active_1kb69_43{color:#e4002b}._iconWrap_1kb69_45{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:28px}._dot_1kb69_54{position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:#e4002b}._label_1kb69_65{font-family:Inter,sans-serif;font-size:10px;font-weight:500;line-height:1}._item_1kb69_28:nth-child(3){color:#e4002b}._item_1kb69_28:nth-child(3)._active_1kb69_43{color:#c8002a}._logo_1kb69_76{display:none}@media(min-width:768px){._nav_1kb69_6{position:static;bottom:auto;left:auto;right:auto;width:60px;min-width:60px;flex-shrink:0;height:100%;border-top:none;border-right:1px solid rgba(0,0,0,.07);padding:16px 8px;background:var(--color-surface);display:flex;flex-direction:column;gap:8px;align-items:center;overflow:hidden}._inner_1kb69_19{flex-direction:column;width:100%;max-width:none;height:auto;gap:2px;margin:0;align-items:center}._item_1kb69_28{flex:none;flex-direction:column;align-items:center;justify-content:center;padding:10px 4px;height:48px;width:44px;border-radius:12px;gap:4px;transform:none}._item_1kb69_28:active{transform:scale(.95)}._item_1kb69_28._active_1kb69_43{background:var(--color-accent-light);color:var(--color-accent)}._iconWrap_1kb69_45{width:20px;height:20px;flex-shrink:0}._dot_1kb69_54{display:none}._label_1kb69_65{font-size:9px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:44px;text-align:center;display:none}._item_1kb69_28:nth-child(3){color:#9ca3af}._item_1kb69_28:nth-child(3)._active_1kb69_43{color:var(--color-accent);background:var(--color-accent-light)}._logo_1kb69_76{display:flex;flex-direction:column;align-items:center;gap:0;padding:0;margin-bottom:8px;flex-shrink:0}._logoIcon_1kb69_77{font-size:20px;flex-shrink:0}._logoText_1kb69_78{display:none}}@media(min-width:1100px){._nav_1kb69_6{width:clamp(180px,14vw,220px);min-width:clamp(180px,14vw,220px);padding:clamp(18px,2.2vh,28px) clamp(10px,1vw,14px);gap:clamp(12px,1.5vh,20px);align-items:stretch}._inner_1kb69_19{align-items:stretch;gap:4px}._item_1kb69_28{flex-direction:row;align-items:center;justify-content:flex-start;padding:clamp(8px,.9vh,11px) clamp(8px,.9vw,12px);height:clamp(38px,4vh,46px);width:100%;border-radius:var(--radius-md);gap:clamp(8px,.7vw,12px)}._label_1kb69_65{display:block;font-size:clamp(11px,.85vw,13px);max-width:none}._logo_1kb69_76{flex-direction:row;align-items:center;padding:0 clamp(6px,.7vw,12px);gap:clamp(6px,.5vw,10px);margin-bottom:clamp(2px,.4vh,6px)}._logoText_1kb69_78{display:block;font-family:Outfit,sans-serif;font-size:clamp(12px,.95vw,16px);font-weight:700;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}@media(min-width:1440px){._nav_1kb69_6{width:clamp(200px,15vw,250px);min-width:clamp(200px,15vw,250px);padding:clamp(22px,2.8vh,36px) clamp(12px,1.2vw,18px);gap:clamp(16px,2vh,26px)}._item_1kb69_28{height:clamp(42px,4.5vh,50px);padding:clamp(10px,1vh,13px) clamp(12px,1vw,16px);gap:clamp(10px,.8vw,14px)}._label_1kb69_65{font-size:clamp(12px,.9vw,14px)}._logoText_1kb69_78{font-size:clamp(14px,1.1vw,18px)}}@media(min-width:1920px){._nav_1kb69_6{width:260px;min-width:260px;padding:32px 18px;gap:24px}._item_1kb69_28{height:50px;padding:13px 16px;gap:14px}._label_1kb69_65{font-size:14px}._logoText_1kb69_78{font-size:17px}}._splash_vujyj_1{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:linear-gradient(160deg,#fff,#fff0f2 40%,#fff5f7);display:flex;align-items:center;justify-content:center}._content_vujyj_11{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px}._logoWrap_vujyj_19{width:96px;height:96px;background:#fff;border-radius:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #e4002b26,0 2px 8px #00000014;margin-bottom:24px}._logoIcon_vujyj_31{font-size:48px;line-height:1}._title_vujyj_36{font-family:Outfit,sans-serif;font-size:32px;font-weight:800;color:#1a1a2e;letter-spacing:-.8px;margin-bottom:8px}._subtitle_vujyj_45{font-family:Inter,sans-serif;font-size:15px;color:#9ca3af;font-weight:400;margin-bottom:48px}._loaderWrap_vujyj_53{display:flex;flex-direction:column;align-items:center;gap:12px;width:200px}._loader_vujyj_53{width:100%;height:3px;background:#e4002b26;border-radius:9999px;overflow:hidden}@keyframes _loading_vujyj_83{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}._loaderBar_vujyj_75{height:100%;width:60%;background:linear-gradient(90deg,transparent,#E4002B,transparent);border-radius:9999px;animation:_loading_vujyj_83 1.4s ease-in-out infinite}._loadingText_vujyj_83{font-family:Inter,sans-serif;font-size:13px;color:#9ca3af;font-weight:500}
