@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary: #4f46e5;--primary-light: #6366f1;--primary-dark: #3730a3;--accent: #0ea5e9;--accent-light: #38bdf8;--secondary: #6366f1;--secondary-light: #818cf8;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--sidebar-bg: #0f172a;--sidebar-text: #94a3b8;--sidebar-active-bg: rgba(79, 70, 229, .15);--sidebar-active-text: #ffffff;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--border: #e2e8f0;--border-light: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(135deg,#f8fafc,#e0e7ff);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-lg)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.container{max-width:1400px;margin:0 auto;padding:0 2rem}.card{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1.5rem;transition:var(--transition)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:500;font-size:.875rem;cursor:pointer;transition:var(--transition);border:none;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-tertiary)}.input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.875rem;transition:var(--transition);background:var(--bg-primary);color:var(--text-primary)}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.badge-success{background:#10b9811a;color:var(--success)}.badge-warning{background:#f59e0b1a;color:var(--warning)}.badge-error{background:#ef44441a;color:var(--error)}.badge-info{background:#2563eb1a;color:#2563eb}.badge-secondary{background:#64748b1a;color:#64748b}.badge-purple{background:#8b5cf61a;color:#8b5cf6}.badge-indigo{background:#4f46e51a;color:#4f46e5}.badge-danger{background:#e11d481a;color:#e11d48}.modal-overlay{position:fixed;inset:0;background-color:#0f172abf;display:flex;justify-content:center;align-items:flex-start;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto;padding:2rem 1rem}.modal-content{background:var(--bg-primary);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:500px;position:relative;border:1px solid var(--border);animation:fadeIn .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.875rem;transition:var(--transition);background:var(--bg-primary);color:var(--text-primary);appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em}.select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.btn-icon{background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);transition:var(--transition);display:flex;align-items:center;justify-content:center}.btn-icon.danger:hover{background:#fee2e2;color:var(--error)}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn .5s ease-out}.slide-in{animation:slideIn .5s ease-out}.spinner{border:3px solid var(--border);border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.items-start{align-items:flex-start!important}.items-end{align-items:flex-end!important}.gap-1{gap:.25rem!important}.mt-6{margin-top:1.5rem!important}.my-4{margin-top:1rem!important;margin-bottom:1rem!important}.p-3{padding:.75rem!important}.p-6{padding:1.5rem!important}.px-2{padding-left:.5rem!important;padding-right:.5rem!important}.py-05{padding-top:.125rem!important;padding-bottom:.125rem!important}.text-center{text-align:center!important}.italic{font-style:italic!important}.text-red-600{color:#dc2626!important}.text-green-600{color:#16a34a!important}.bg-white{background-color:#fff!important}.bg-red-100{background-color:#fee2e2!important}.bg-green-100{background-color:#dcfce7!important}.bg-green-soft{background-color:#f0fdf44d!important}.bg-orange-100{background-color:#ffedd5!important}.text-orange-600{color:#ea580c!important}.border-2{border-width:2px!important}.border-gray-100{border-color:#f1f5f9!important}.border-blue-100{border-color:#dbeafe!important}.last\:border-0:last-child{border:0!important}.rounded-2xl{border-radius:1rem!important}.shadow-lg{box-shadow:var(--shadow-lg)!important}.shadow-xl{box-shadow:var(--shadow-xl)!important}.z-50{z-index:50!important}.animate-spin{animation:spin 1s linear infinite!important}.overflow-hidden{overflow:hidden!important}.h-55{height:55px!important}.h-45{height:45px!important}.text-xxs{font-size:.625rem!important}.border-none{border:none!important}.hover\:border-blue-200:hover{border-color:#bfdbfe!important}.hover\:border-green-200:hover{border-color:#bbf7d0!important}.btn-primary-gradient{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;color:#fff!important;border:none!important;transition:all .2s ease!important}.btn-primary-gradient:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #2563eb66!important}.feedback-form-inplace{border-top:1px solid #f1f5f9;padding-top:1.5rem}.section-label-sm{font-size:.65rem;font-weight:800;color:#94a3b8;letter-spacing:.05em;display:block}.status-toggle-group{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.toggle-item-sm{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;border-radius:12px;border:2px solid #f1f5f9;background:#fff;cursor:pointer;font-weight:700;font-size:.85rem;color:#64748b;transition:all .2s}.toggle-item-sm.active{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.toggle-item-sm.active-warning{border-color:#f59e0b;background:#fff7ed;color:#b45309}.damage-grid-sm{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.damage-btn-sm{padding:.6rem;border-radius:10px;border:1px solid #f1f5f9;background:#fff;font-size:.75rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.damage-btn-sm:hover{background:#f8fafc}.damage-btn-sm.active{background:#1e293b;color:#fff;border-color:#1e293b}.suspicious-alert-sm{background:#fff1f2;border-left:4px solid #e11d48;color:#9f1239}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-background{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,#e0e7ff,#fce7f3,#dbeafe)}.floating-shape{position:absolute;border-radius:50%;filter:blur(60px);opacity:.3;animation:float 20s ease-in-out infinite}.shape-1{width:400px;height:400px;background:linear-gradient(135deg,#6366f1,#f472b6);top:-100px;left:-100px;animation-delay:0s}.shape-2{width:300px;height:300px;background:linear-gradient(135deg,#22d3ee,#6366f1);bottom:-50px;right:-50px;animation-delay:5s}.shape-3{width:250px;height:250px;background:linear-gradient(135deg,#f472b6,#22d3ee);top:50%;right:20%;animation-delay:10s}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(120deg)}66%{transform:translate(-20px,20px) rotate(240deg)}}.login-card{position:relative;z-index:1;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:3rem;width:100%;max-width:450px;border:1px solid rgba(255,255,255,.5)}.login-header{text-align:center;margin-bottom:2.5rem}.logo-container{display:flex;flex-direction:column;align-items:center;gap:.75rem}.logo-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-lg);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.logo-text{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.logo-subtitle{font-size:.875rem;color:var(--text-secondary);font-weight:500;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary)}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--error);font-size:.875rem}.btn-login{width:100%;padding:1rem;font-size:1rem;font-weight:600;margin-top:.5rem}.btn-login:disabled{opacity:.7;cursor:not-allowed}.spinner-small{border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;width:16px;height:16px;animation:spin 1s linear infinite}.login-footer{margin-top:2rem;text-align:center;padding-top:1.5rem;border-top:1px solid var(--border-light)}.login-footer p{font-size:.875rem;color:var(--text-secondary);margin:0}.login-footer strong{color:var(--primary);font-weight:600}.alt-login-buttons{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.btn-outline{width:100%;padding:.75rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:var(--transition);text-decoration:none;font-size:.875rem}.btn-outline:hover{background:var(--bg-secondary);border-color:var(--primary);color:var(--primary)}.separator{display:flex;align-items:center;text-align:center;color:var(--text-tertiary);font-size:.75rem;font-weight:500;margin:1.5rem 0}.separator:before,.separator:after{content:"";flex:1;border-bottom:1px solid var(--border-light)}.separator:before{margin-right:.5em}.separator:after{margin-left:.5em}@media(max-width:640px){.login-card{padding:2rem}.logo-text{font-size:1.5rem}.logo-icon{width:60px;height:60px}.logo-icon svg{width:32px;height:32px}}.detail-modal{max-width:800px;width:95%}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;padding:1rem 0}.detail-card{background:#f8fafc;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0}.detail-card h3{font-size:1.1rem;color:#475569;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid #cbd5e1}.info-row{display:flex;justify-content:space-between;margin-bottom:.75rem;font-size:.95rem}.info-row:last-child{margin-bottom:0}.label{color:#64748b;display:flex;align-items:center;gap:.25rem;min-width:80px}.value{color:#1e293b;text-align:right;font-weight:500}.font-mono{font-family:JetBrains Mono,monospace;letter-spacing:-.5px}.warning{background:#fef2f2;padding:.5rem;border-radius:6px;margin-top:.5rem}.status-overview{text-align:center;margin-bottom:1rem}.dates-grid{display:grid;gap:1rem}.date-item{display:flex;flex-direction:column;gap:.25rem}.date-label{font-size:.8rem;color:#64748b}.date-val{font-weight:600;color:#334155;font-size:1rem}.days-remaining{margin-top:1rem;padding:.75rem;text-align:center;background:#ecfdf5;color:#059669;font-weight:600;border-radius:8px}.days-remaining.overdue{background:#fef2f2;color:#dc2626}.detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:#64748b}.dashboard-page{display:flex;flex-direction:column;gap:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}.premium-stat-card{background:#fff;padding:1.25rem;border-radius:20px;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid #f1f5f9;transition:all .3s cubic-bezier(.4,0,.2,1)}.premium-stat-card.clickable{cursor:pointer}.premium-stat-card:hover{transform:translateY(-5px);box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border-color:var(--primary-light)}.stat-icon-wrapper{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 8px 16px -4px #0000001a}.stat-info{display:flex;flex-direction:column;min-width:0}.stat-label{font-size:.75rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.stat-number{font-size:1.5rem;font-weight:800;color:var(--text-primary);line-height:1.1}.stat-subtitle{font-size:.75rem;color:var(--text-tertiary);font-weight:500;margin-top:2px}.dashboard-main-grid{display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}.dashboard-content-left{display:flex;flex-direction:column;gap:2rem}.charts-container{display:grid;grid-template-columns:1fr 340px;gap:2rem}.glass-card{background:#fff;border-radius:24px;border:1px solid #f1f5f9;box-shadow:0 4px 6px -1px #0000000d}.box-header{padding:1.5rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;gap:.75rem}.box-header h3{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0;flex:1}.chart-area{padding:1.5rem}.dashboard-table-box{overflow:hidden}.premium-table{width:100%;border-collapse:collapse}.premium-table th{text-align:left;padding:1rem 1.5rem;font-size:.75rem;font-weight:700;color:var(--text-tertiary);background:#f8fafc;text-transform:uppercase;letter-spacing:.05em}.premium-table td{padding:1rem 1.5rem;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid #f1f5f9}.premium-table tr.clickable-row{cursor:pointer;transition:background .2s}.premium-table tr.clickable-row:hover td{background:#f8fafc;color:var(--primary)}.view-all-btn{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:var(--primary);background:none;border:none;cursor:pointer;transition:var(--transition)}.view-all-btn:hover{gap:.75rem}.activity-timeline{padding-bottom:1rem}.timeline-items{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;position:relative;max-height:500px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.timeline-items::-webkit-scrollbar{width:4px}.timeline-items::-webkit-scrollbar-track{background:transparent}.timeline-items::-webkit-scrollbar-thumb{background-color:#e2e8f0;border-radius:10px}.timeline-items:before{content:"";position:absolute;left:2.25rem;top:0;bottom:0;width:2px;background:#f1f5f9;z-index:0}.timeline-item{display:flex;gap:1.25rem;position:relative;z-index:1}.timeline-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:3px solid white}.timeline-icon.is-loan{background:#eff6ff;color:#3b82f6;box-shadow:0 0 0 4px #eff6ff80}.timeline-icon.is-return{background:#ecfdf5;color:#10b981;box-shadow:0 0 0 4px #ecfdf580}.timeline-content{flex:1}.activity-text{font-size:.875rem;line-height:1.5;color:var(--text-secondary);margin:0 0 .25rem}.activity-text strong{color:var(--text-primary)}.activity-time{font-size:.75rem;color:var(--text-tertiary)}.full-timeline-btn{display:block;width:calc(100% - 3rem);margin:0 auto .5rem;padding:.75rem;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0;color:var(--text-secondary);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s}.full-timeline-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.dashboard-loading{height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.loading-spinner{width:48px;height:48px;border:4px solid #f1f5f9;border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:1440px){.charts-container{grid-template-columns:1fr}}@media(max-width:1280px){.dashboard-main-grid{grid-template-columns:1fr}.dashboard-content-right{order:-1}}@media(max-width:768px){.dashboard-page{padding:1rem}}.modal-overlay{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;z-index:9999;padding:2rem 1rem;overflow-y:auto}.modal-container{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:800px;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);margin:auto;position:relative;max-height:none}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:var(--transition);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-secondary);color:var(--error)}.modal-body{padding:1.5rem;overflow-y:auto}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-container.slide-in{animation:slideInUp .3s cubic-bezier(.16,1,.3,1)}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.pagination-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.pagination-btn:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-secondary)}.pagination-info{font-size:.875rem;color:var(--text-secondary);font-weight:500}.book-detail-modal{background:#fff;width:90%;max-width:900px;max-height:90vh;border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl);animation:modalSlideUp .3s ease-out}.modal-header-premium{padding:1.5rem 2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.header-main{display:flex;align-items:center;gap:1rem}.book-icon-bg{width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);color:var(--primary)}.header-main h2{margin:0;font-size:1.25rem;color:#1e293b}.detail-grid{display:grid;grid-template-columns:240px 1fr;gap:2.5rem}.detail-sidebar{display:flex;flex-direction:column;gap:1.5rem}.book-cover-container{position:relative;width:100%;aspect-ratio:2/3;background:#f1f5f9;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md)}.book-cover-large{width:100%;height:100%;object-fit:cover}.book-cover-placeholder-large{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#94a3b8}.status-badge-floating{position:absolute;top:10px;right:10px;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff;box-shadow:0 2px 4px #0003}.status-badge-floating.success{background:#10b981}.status-badge-floating.warning{background:#f59e0b}.mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mini-stat-item{background:#f8fafc;padding:.75rem;border-radius:var(--radius-md);text-align:center;border:1px solid #e2e8f0}.sidebar-section{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.sidebar-title{font-size:.85rem;font-weight:700;color:#475569;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px dashed #e2e8f0}.reading-list-mini{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto;padding-right:5px}.reading-log-item{display:flex;gap:.75rem;position:relative}.log-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);margin-top:5px;flex-shrink:0}.log-info{display:flex;flex-direction:column;gap:.1rem}.log-user{background:none;border:none;padding:0;text-align:left;font-size:.8rem;font-weight:600;color:#1e293b;cursor:pointer}.log-user:hover{color:var(--primary);text-decoration:underline}.log-date{font-size:.7rem;color:#64748b}.log-status{font-size:.65rem;font-weight:700;text-transform:uppercase}.log-status.success{color:#10b981}.log-status.warning{color:#f59e0b}.stat-label{display:block;font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.stat-value{font-weight:700;font-size:1.1rem;color:#1e293b}.detail-main{display:flex;flex-direction:column;gap:2rem}.detail-section{display:flex;flex-direction:column;gap:1rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:#334155;padding-bottom:.5rem;border-bottom:2px solid #f1f5f9}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{font-size:.75rem;color:#64748b;display:flex;align-items:center;gap:.25rem}.info-item span{font-weight:500;color:#1e293b}.condition-box.success-premium{background:#f0fdf4;border:1px solid #bbf7d0;display:flex;gap:1.25rem;padding:1.25rem;border-radius:16px}.condition-box.danger-premium{background:#fff1f2;border:1px solid #fecdd3;display:flex;gap:1.25rem;padding:1.25rem;border-radius:16px}.condition-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.condition-icon.success{background:#dcfce7;color:#16a34a}.condition-icon.danger{background:#ffe4e6;color:#e11d48}.condition-text strong{display:block;font-size:1.1rem;margin-bottom:.25rem}.condition-text p{margin:0;font-size:.9rem;color:#475569}.history-hint{display:block;margin-top:.5rem;font-size:.75rem;color:#64748b;font-style:italic}.damage-timeline{position:relative;padding-left:1.5rem}.damage-timeline:before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:2px;background:#e2e8f0}.timeline-item{position:relative;margin-bottom:1.5rem}.timeline-marker{position:absolute;left:-1.5rem;top:6px;width:10px;height:10px;border-radius:50%;background:#fff;border:2px solid var(--primary);transform:translate(-4px);z-index:1}.timeline-content{background:#f8fafc;padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid #e2e8f0}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.timeline-date{font-size:.75rem;color:#64748b}.member-link-btn{background:none;border:none;color:var(--primary);font-weight:600;font-size:.85rem;cursor:pointer;padding:0}.member-link-btn:hover{text-decoration:underline}.timeline-body{display:flex;flex-direction:column;gap:.4rem}.damage-tag{display:inline-block;padding:.1rem .5rem;background:#fee2e2;color:#b91c1c;font-size:.7rem;font-weight:600;border-radius:4px;align-self:flex-start}.timeline-note{margin:0;font-size:.8rem;color:#475569;display:flex;align-items:flex-start;gap:.3rem}@media(max-width:768px){.detail-grid{grid-template-columns:1fr}.detail-sidebar{align-items:center}.book-cover-container{max-width:200px}}.page-container{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem}.page-header h1{font-size:1.875rem;font-weight:800;color:var(--text-primary);margin:0 0 .25rem;letter-spacing:-.01em}.page-header p{color:var(--text-tertiary);font-size:.9375rem;margin:0}.filters-card{background:#fff;padding:1rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.search-box{position:relative;max-width:400px;width:100%}.search-box input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.875rem;transition:var(--transition)}.search-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.table-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem;min-height:400px;display:flex;flex-direction:column}.table-responsive{overflow-x:auto;flex:1}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:1rem;border-bottom:1px solid var(--border);color:var(--text-secondary);font-weight:600;font-size:.875rem;white-space:nowrap}.table td{padding:1rem;border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:.875rem}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg-secondary)}.clickable-row{cursor:pointer;transition:var(--transition)}.clickable-row:hover td{background:#f1f5f9!important}.actions-cell{background:transparent;text-align:right;white-space:nowrap;display:flex;justify-content:flex-end;gap:.5rem}.btn-icon{width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.btn-icon:hover{background:var(--bg-secondary);color:var(--primary)}.btn-icon.danger:hover{background:#ef44441a;color:var(--error)}.font-medium{font-weight:500}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:var(--text-secondary)}.loading-state,.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:300px;color:var(--text-secondary)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.full-width{grid-column:1 / -1}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.form-group input,.form-group select,.form-group textarea{width:100%}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed;border-color:var(--border)}.form-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem;padding-top:1.5rem;border-top:1px solid var(--border-light)}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.btn-link{background:none;border:none;color:var(--primary);text-decoration:underline;cursor:pointer;font-weight:500;padding:0;font-size:.875rem}.btn-link:hover{color:var(--primary-dark)}.text-danger{color:var(--error);font-weight:600}.text-success{color:var(--success);font-weight:600}.text-center{text-align:center}.py-4{padding-top:1rem;padding-bottom:1rem}.active-loans-list{min-height:200px}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.form-grid{grid-template-columns:1fr}}.tabbed-form{display:flex;flex-direction:column;gap:1.5rem}.form-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:.25rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.form-tab{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:transparent;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .2s ease;text-align:left;position:relative;overflow:hidden}.form-tab:hover{background:#fff;box-shadow:0 2px 4px #0000000d}.form-tab.active{background:#fff;border-color:#6366f1;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.tab-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:#fff;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.tab-content{display:flex;flex-direction:column;overflow:hidden}.tab-title{font-size:.9rem;font-weight:600;color:#475569}.form-tab.active .tab-title{color:#1e293b}.tab-desc{font-size:.75rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tab-content-wrapper{min-height:400px;position:relative;padding:0 .5rem}.tab-panel{animation:fadeIn .3s ease-in-out}.form-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.form-actions-tabbed{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;border-top:1px solid #e2e8f0;margin-top:1rem}.tab-navigation{display:flex;gap:1rem}.main-actions{display:flex;gap:1rem;margin-left:auto}@media(max-width:640px){.form-tabs{grid-template-columns:1fr;gap:.5rem}.form-grid-2col{grid-template-columns:1fr}.tab-desc{display:none}}.books-page-container{max-width:1400px;margin:0 auto;padding:1.5rem;animation:fadeIn .4s ease-out;background:#f8fafc;min-height:100vh}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.books-title-section{margin-bottom:2rem}.books-title-section h1{font-size:1.75rem;font-weight:800;color:#0f172a;letter-spacing:-.02em;margin-bottom:.25rem}.books-title-section p{color:#64748b;font-size:.9rem}.books-action-card{background:#fff;border-radius:16px;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;box-shadow:0 1px 3px #00000005,0 4px 12px #00000008;border:1px solid #f1f5f9;margin-bottom:1.5rem}.books-stats-box{display:flex;align-items:center;gap:.75rem;padding-right:1.5rem;border-right:1px solid #f1f5f9;color:#475569;font-size:.85rem;white-space:nowrap}.books-stats-box strong{color:#6366f1;font-size:1.1rem;font-weight:800}.books-search-container{flex:1;position:relative;max-width:500px}.books-search-field{width:100%;padding:.65rem 1rem .65rem 2.75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;transition:all .2s}.books-search-field:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f114}.books-search-icon-fixed{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:#94a3b8}.books-button-group{display:flex;align-items:center;gap:.5rem}.btn-modern{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid transparent}.btn-modern-primary{background:#6366f1;color:#fff;box-shadow:0 2px 4px #6366f133}.btn-modern-primary:hover{background:#4f46e5;transform:translateY(-1px)}.btn-modern-secondary{background:#fff;border-color:#e2e8f0;color:#475569}.btn-modern-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.btn-modern-icon{padding:.6rem}.books-table-wrapper{background:#fff;border-radius:16px;border:1px solid #f1f5f9;box-shadow:0 4px 20px -5px #00000008;overflow:hidden}.modern-table-simple{width:100%;border-collapse:collapse}.modern-table-simple th{background:#fbfcfd;padding:.875rem 1.25rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;border-bottom:1px solid #f1f5f9}.modern-table-simple td{padding:1rem 1.25rem;border-bottom:1px solid #f8fafc;color:#334155;font-size:.875rem;vertical-align:middle}.simple-row{transition:background .2s;cursor:pointer}.simple-row:hover{background:#f9fafb}.identity-cell{display:flex;align-items:center;gap:1rem}.cover-mini{width:38px;height:52px;border-radius:6px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;font-weight:800;color:#94a3b8;font-size:1.1rem;box-shadow:0 2px 4px #0000000d;flex-shrink:0}.title-line{font-weight:600;color:#1e293b;display:block;font-size:.9rem}.category-line{font-size:.75rem;color:#94a3b8}.location-text{display:flex;flex-direction:column;gap:.15rem}.location-item{display:flex;align-items:center;gap:.35rem;color:#64748b;font-size:.75rem;font-weight:500}.location-item svg{color:#cbd5e1}.barcode-text{font-family:JetBrains Mono,Monaco,monospace;font-size:.7rem;color:#94a3b8;background:#f1f5f9;padding:.2rem .4rem;border-radius:4px}.badge-clean{padding:.35rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600}.badge-clean-success{background:#f0fdf4;color:#166534}.badge-clean-warning{background:#fffbeb;color:#92400e}.badge-clean-danger{background:#fef2f2;color:#991b1b}.badge-clean-primary{background:#eef2ff;color:#3730a3}.action-btns-mini{display:flex;justify-content:flex-end;gap:.25rem}.btn-mini-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:all .2s;border:none;background:transparent;cursor:pointer}.btn-mini-icon:hover{background:#f1f5f9;color:#6366f1}.btn-mini-icon.del:hover{background:#fef2f2;color:#ef4444}.books-view-tabs{display:flex;gap:.5rem;margin-bottom:1rem;padding:.25rem;background:#f1f5f9;border-radius:12px;width:fit-content}.view-tab{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:10px;font-size:.85rem;font-weight:600;color:#64748b;border:none;background:transparent;cursor:pointer;transition:all .2s}.view-tab:hover{color:#334155}.view-tab.active{background:#fff;color:#6366f1;box-shadow:0 2px 4px #0000000d}.books-filter-bar{background:#fff;border-radius:16px;padding:1.25rem;border:1px solid #f1f5f9;box-shadow:0 1px 3px #00000005;margin-bottom:1.5rem}.filter-group{margin-bottom:1.25rem}.filter-group label{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.filter-badges-container{position:relative;width:100%}.filter-badges{display:flex;flex-wrap:nowrap!important;gap:.5rem;overflow-x:auto;padding-bottom:.8rem;scrollbar-width:none;-ms-overflow-style:none}.filter-badges::-webkit-scrollbar{display:none}.filter-badges-container:after{content:"";position:absolute;right:0;top:0;bottom:0;width:60px;background:linear-gradient(to right,transparent,white);pointer-events:none;z-index:10}.filter-badge{padding:.45rem 1.25rem;border-radius:20px;font-size:.8rem;font-weight:500;background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.filter-badge:hover{background:#f1f5f9;border-color:#cbd5e1}.filter-badge.active{background:#6366f1;border-color:#6366f1;color:#fff}.filter-row-bottom{display:flex;align-items:center;gap:1.5rem;padding-top:1.25rem;border-top:1px solid #f8fafc}.filter-select-group{display:flex;align-items:center;gap:.75rem}.filter-select-group label{font-size:.85rem;font-weight:600;color:#475569;white-space:nowrap;display:flex;align-items:center;gap:.4rem}.minimal-select{padding:.4rem .75rem;border-radius:8px;border:1px solid #e2e8f0;background:#f8fafc;font-size:.85rem;color:#334155;outline:none;transition:all .2s}.minimal-select:focus{border-color:#6366f1;background:#fff}.btn-clear-filters{margin-left:auto;font-size:.8rem;font-weight:600;color:#ef4444;background:#fef2f2;border:1px solid #fee2e2;padding:.4rem .75rem;border-radius:8px;cursor:pointer;transition:all .2s}.btn-clear-filters:hover{background:#fee2e2}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1.5rem}.inventory-card{background:#fff;border-radius:16px;border:1px solid #f1f5f9;padding:1.25rem;transition:all .3s;cursor:pointer;position:relative;display:flex;flex-direction:column;gap:1rem}.inventory-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px -5px #0000000d;border-color:#6366f1}.inv-card-header{display:flex;justify-content:space-between;align-items:center}.inv-barcode{font-family:monospace;font-size:.7rem;background:#f1f5f9;padding:.2rem .5rem;border-radius:4px;color:#94a3b8}.inv-status-dot{width:10px;height:10px;border-radius:50%}.inv-status-dot.badge-clean-success{background:#22c55e}.inv-status-dot.badge-clean-warning{background:#f59e0b}.inv-status-dot.badge-clean-danger{background:#ef4444}.inv-status-dot.badge-clean-primary{background:#6366f1}.inv-card-body{display:flex;gap:1rem}.inv-cover{width:60px;height:84px;border-radius:8px;overflow:hidden;background:#f8fafc;flex-shrink:0;box-shadow:0 4px 10px #0000000d}.inv-cover img{width:100%;height:100%;object-fit:cover}.inv-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#cbd5e1}.inv-info h4{font-size:.95rem;font-weight:700;color:#0f172a;margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.inv-author{font-size:.8rem;color:#64748b;margin-bottom:.5rem}.inv-meta{display:flex;flex-wrap:wrap;gap:.4rem}.inv-genre{font-size:.7rem;font-weight:600;padding:.15rem .5rem;background:#eef2ff;color:#6366f1;border-radius:4px}.inv-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid #f8fafc}.inv-location{display:flex;gap:.5rem}.inv-loc-tag{display:flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:600;color:#475569;padding:.25rem .5rem;background:#f1f5f9;border-radius:6px}.inv-edit-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border:1px solid #e2e8f0;color:#94a3b8;cursor:pointer;transition:all .2s}.inv-edit-btn:hover{background:#6366f1;color:#fff;border-color:#6366f1}.members-view-tabs{display:flex;gap:1rem;margin-bottom:1.5rem;border-bottom:1px solid #e2e8f0;padding-bottom:2px}.view-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;background:none;color:#64748b;font-weight:600;cursor:pointer;position:relative;transition:all .2s}.view-tab:hover{color:#4338ca;background:#f8fafc;border-radius:8px 8px 0 0}.view-tab.active{color:#4338ca}.view-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#4338ca}.members-filter-bar{background:#fff;padding:1.25rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.filter-row-top{display:flex;gap:1rem;align-items:center}.filter-row-bottom{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.filter-select-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:150px}.filter-select-group label{font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.4rem}.minimal-select{padding:.6rem .75rem;border-radius:8px;border:1px solid #e2e8f0;background-color:#f8fafc;color:#1e293b;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;outline:none}.minimal-select:focus{border-color:#6366f1;background-color:#fff;box-shadow:0 0 0 3px #6366f11a}.btn-clear-filters{padding:.6rem 1rem;background:#fee2e2;color:#ef4444;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;height:38px}.btn-clear-filters:hover{background:#fecaca;transform:translateY(-1px)}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1rem}.class-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #f1f5f9;display:flex;flex-direction:column;gap:1rem;transition:transform .2s}.class-card:hover{transform:translateY(-4px)}.class-card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px dashed #e2e8f0}.class-info h3{font-size:1.25rem;font-weight:800;color:#1e293b;margin:0}.class-info span{font-size:.85rem;color:#64748b;font-weight:500}.class-stats-pill{background:#f1f5f9;padding:.4rem .8rem;border-radius:20px;font-size:.75rem;font-weight:700;color:#475569}.class-members-list{display:flex;flex-direction:column;gap:.75rem}.mini-member-card{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:10px;background:#f8fafc;border:1px solid transparent;transition:all .2s}.mini-member-card:hover{background:#fff;border-color:#e2e8f0;box-shadow:0 2px 4px #0000000d}.mini-avatar{width:36px;height:36px;border-radius:50%;background:#e0e7ff;color:#4338ca;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.mini-info{flex:1;overflow:hidden}.mini-name{font-size:.85rem;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-meta{font-size:.7rem;color:#64748b}.status-indicator{padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:800;text-transform:uppercase}.status-reading{background:#dcfce7;color:#166534}.status-overdue{background:#fee2e2;color:#991b1b;animation:pulse-red 2s infinite}.status-none{background:#f1f5f9;color:#475569}@keyframes pulse-red{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.row-overdue{background-color:#fff1f2!important}.row-overdue:hover{background-color:#ffe4e6!important}.import-modal-overlay{position:fixed;inset:0;background-color:#0f172abf;display:flex;align-items:flex-start;justify-content:center;z-index:9999;animation:modalFadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto;padding:2rem 1rem}.import-modal-content{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #0006;width:90%;max-width:800px;display:flex;flex-direction:column;overflow:hidden;font-family:Inter,system-ui,-apple-system,sans-serif;margin:auto;position:relative;max-height:none}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.import-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb;background-color:#fff}.import-modal-title h2{font-size:1.25rem;font-weight:700;color:#111827;margin:0}.import-modal-title p{font-size:.875rem;color:#6b7280;margin:.25rem 0 0}.close-btn{background:transparent;border:none;cursor:pointer;color:#9ca3af;padding:.5rem;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-btn:hover{background-color:#f3f4f6;color:#111827}.import-modal-body{padding:2rem;overflow-y:auto;flex:1;background-color:#fff}.step-card{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;display:flex;gap:1.25rem;align-items:flex-start;margin-bottom:1.5rem;transition:transform .2s,box-shadow .2s}.step-card:hover{box-shadow:0 4px 6px -1px #0000000d}.step-icon-box{background-color:#fff;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:10px;box-shadow:0 1px 3px #0000001a;color:#4f46e5;flex-shrink:0}.step-content{flex:1}.step-title{font-weight:600;color:#1e293b;margin-bottom:.5rem;font-size:1rem}.step-desc{font-size:.875rem;color:#64748b;margin-bottom:1.25rem;line-height:1.5}.action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;border:none;transition:all .2s;text-decoration:none}.btn-indigo{background-color:#4f46e5;color:#fff;box-shadow:0 1px 2px #0000000d}.btn-indigo:hover{background-color:#4338ca;transform:translateY(-1px)}.btn-dark{background-color:#1e293b;color:#fff;padding:.75rem 2rem}.btn-dark:hover{background-color:#0f172a}.upload-area{border:2px dashed #cbd5e1;border-radius:16px;padding:3.5rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background-color:#f8fafc;display:flex;flex-direction:column;align-items:center}.upload-area:hover{border-color:#6366f1;background-color:#eef2ff;transform:scale(1.01)}.upload-icon{color:#94a3b8;margin-bottom:1.5rem;transition:color .3s}.upload-area:hover .upload-icon{color:#6366f1}.upload-text-main{font-weight:600;color:#334155;margin-bottom:.5rem;font-size:1.1rem}.upload-text-sub{font-size:.875rem;color:#64748b;margin-bottom:1.5rem}.file-info-bar{display:flex;justify-content:space-between;align-items:center;background-color:#f1f5f9;padding:1rem 1.5rem;border-radius:10px;margin-bottom:1.5rem;border:1px solid #e2e8f0}.file-details{display:flex;align-items:center;gap:1rem}.file-name{font-weight:600;color:#334155}.file-meta{font-size:.8rem;color:#64748b}.remove-file-btn{color:#ef4444;font-size:.875rem;background:#fff;border:1px solid #fecaca;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.remove-file-btn:hover{background-color:#fef2f2;border-color:#ef4444}.checkbox-wrapper{display:flex;gap:1rem;padding:1.25rem;background-color:#fffbeb;border:1px solid #fde68a;border-radius:10px;margin-bottom:1.5rem;cursor:pointer;transition:border-color .2s}.checkbox-wrapper:hover{border-color:#d97706}.checkbox-content h4{margin:0;font-weight:700;color:#92400e;font-size:.95rem}.checkbox-content p{margin:.25rem 0 0;font-size:.85rem;color:#b45309;line-height:1.4}.custom-checkbox{width:20px;height:20px;margin-top:2px;accent-color:#d97706;cursor:pointer}.preview-table-container{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;box-shadow:0 1px 2px #0000000d}.preview-table-header{background-color:#f8fafc;padding:.75rem 1.25rem;border-bottom:1px solid #e2e8f0;font-weight:600;font-size:.875rem;color:#475569;display:flex;justify-content:space-between}.preview-table{width:100%;border-collapse:collapse;font-size:.875rem}.preview-table th{background-color:#f8fafc;text-align:left;padding:1rem 1.25rem;color:#64748b;font-weight:600;border-bottom:1px solid #e2e8f0}.preview-table td{padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9;color:#334155}.preview-table tr:last-child td{border-bottom:none}.font-mono{font-family:JetBrains Mono,Menlo,Courier New,monospace;font-size:.8rem;background:#f1f5f9;padding:2px 6px;border-radius:4px;color:#475569}.more-rows{padding:.75rem;background-color:#f8fafc;text-align:center;font-size:.8rem;color:#64748b;border-top:1px solid #e2e8f0}.import-modal-footer{padding:1.25rem 2rem;border-top:1px solid #e5e7eb;background-color:#f9fafb;display:flex;justify-content:flex-end;gap:1rem;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.btn-cancel{background:#fff;border:1px solid #cbd5e1;color:#475569}.btn-cancel:hover{background-color:#f1f5f9;border-color:#94a3b8}.btn-primary-action{background:#4f46e5;color:#fff}.btn-primary-action:hover{background-color:#4338ca}.btn-disabled{opacity:.6;cursor:not-allowed;background-color:#94a3b8}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.spin-anim{animation:spin 1s linear infinite}.return-modal-content{background:#fff;width:100%;max-width:550px;border-radius:24px;overflow:hidden;box-shadow:0 25px 50px -12px #0006;display:flex;flex-direction:column;margin:auto;position:relative;border:1px solid rgba(255,255,255,.1)}.modal-header-premium{padding:1.5rem 2rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;background:#f8fafc}.header-title{display:flex;align-items:center;gap:1rem}.header-title h3{margin:0;font-size:1.25rem;font-weight:800;color:#1e293b}.header-title p{margin:0;font-size:.9rem;color:#64748b;font-weight:500}.modal-body-scrollable{padding:2rem;overflow-y:auto;flex:1}.form-section{margin-bottom:2rem}.form-section:last-child{margin-bottom:0}.section-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;color:#475569;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.025em}.status-toggle-group{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.toggle-item{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;border-radius:16px;border:2px solid #e2e8f0;background:#fff;cursor:pointer;font-weight:700;color:#64748b;transition:all .2s}.toggle-item:hover{border-color:#cbd5e1;background:#f8fafc}.toggle-item.active{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.toggle-item.active-warning{border-color:#f59e0b;background:#fff7ed;color:#b45309}.suspicious-alert{background:#fff1f2;border-left:5px solid #e11d48;padding:1.25rem;border-radius:12px;display:flex;gap:1rem;margin-bottom:2rem;color:#9f1239;animation:pulse-border 2s infinite}@keyframes pulse-border{0%{border-left-color:#e11d48}50%{border-left-color:#fb7185}to{border-left-color:#e11d48}}.suspicious-alert strong{display:block;font-size:1rem;margin-bottom:.25rem}.suspicious-alert p{font-size:.85rem;margin:0;line-height:1.5}.star-rating{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.star-active{color:#f59e0b;cursor:pointer;transition:transform .1s}.star-inactive{color:#e2e8f0;cursor:pointer}.star-active:hover{transform:scale(1.2)}.rating-text{margin-left:1rem;font-weight:700;color:#f59e0b;font-size:1.1rem}.damage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}.damage-btn{padding:.75rem;border-radius:12px;border:1px solid #e2e8f0;background:#fff;font-size:.85rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.damage-btn:hover{border-color:#cbd5e1;background:#f8fafc}.damage-btn.active{background:#1e293b;color:#fff;border-color:#1e293b}.modal-textarea{width:100%;height:100px;padding:1rem;border-radius:16px;border:1px solid #e2e8f0;background:#f8fafc;resize:none;font-family:inherit;font-size:.95rem}.modal-textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 4px #3b82f61a}.modal-footer-premium{padding:1.5rem 2rem;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:1rem;background:#f8fafc}.close-btn-round{width:36px;height:36px;border-radius:50%;border:none;background:#fff;display:flex;align-items:center;justify-content:center;color:#94a3b8;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000000d}.close-btn-round:hover{background:#fee2e2;color:#ef4444}.transactions-layout{display:flex;flex-direction:column;gap:2rem}.action-panel{display:flex;flex-direction:column;gap:1rem}.tabs{display:flex;background:#f1f5f9;padding:.5rem;border-radius:18px;gap:.5rem;border:1px solid #e2e8f0}.tab-btn{flex:1;padding:.875rem 1.25rem;border:none;background:transparent;border-radius:14px;color:var(--text-secondary);font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.75rem}.tab-btn svg{transition:transform .3s}.tab-btn.active{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;box-shadow:0 4px 12px #4f46e540;transform:scale(1.02)}.tab-btn.active svg{transform:scale(1.1)}.tab-btn:hover:not(.active){background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}.tab-content.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem;min-height:400px}.loan-form{display:flex;flex-direction:column;gap:1.5rem}.selection-card h4{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:var(--text-primary);font-size:1rem;font-weight:600}.search-wrapper{position:relative}.search-icon-input{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.input.with-icon{padding-left:2.75rem}.input-spinner{position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;margin-top:.5rem;max-height:300px;overflow-y:auto}.search-result-item{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);cursor:pointer;transition:var(--transition);display:flex;flex-direction:column}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-secondary)}.search-result-item.disabled{opacity:.6;cursor:not-allowed;background:var(--bg-light)}.selected-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg-light);border:1px solid var(--primary-light);border-radius:var(--radius-md)}.selected-item-container{display:flex;flex-direction:column;gap:.5rem}.damage-warning-box{background:#fff1f2;border:1px solid #fecdd3;border-radius:10px;overflow:hidden;animation:slideDown .3s ease-out}.warning-header{background:#f43f5e;color:#fff;padding:.4rem .75rem;display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:.75rem}.warning-content{padding:.75rem;font-size:.85rem;color:#9f1239}.warning-content p{margin:0 0 .2rem}@keyframes slideDown{0%{transform:translateY(-5px);opacity:0}to{transform:translateY(0);opacity:1}}.item-info{display:flex;flex-direction:column}.action-area{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:1rem}.date-selection{display:flex;align-items:center;gap:1rem}.date-selection label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--text-secondary)}.buttons{display:flex;gap:1rem;margin-top:.5rem}.buttons button{flex:1}.error-message{padding:.75rem;background:#fef2f2;border:1px solid #FECACA;color:#991b1b;border-radius:var(--radius-md);font-size:.875rem;display:flex;align-items:center;gap:.5rem}.return-form{display:flex;flex-direction:column;gap:2rem}.transaction-preview{background:var(--bg-light);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;text-align:center}.book-card-mini,.member-card-mini{background:#fff;padding:1rem;border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center}.member-card-mini{text-align:left}.arrow-down{margin:1rem;color:var(--text-tertiary)}.full-width{width:100%}@media(max-width:1024px){.transactions-layout{grid-template-columns:1fr}.action-panel{order:1}.history-panel{order:2}}.sidebar{width:280px;height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100;box-shadow:4px 0 10px #0000001a}.sidebar-header{padding:2rem 1.5rem}.sidebar-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}.logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #4f46e54d}.logo-text{display:flex;flex-direction:column}.logo-text h2{font-size:1.4rem;font-weight:900;color:#fff;margin:0;line-height:.9;letter-spacing:-.03em;text-transform:uppercase}.logo-text span{font-size:.65rem;color:#ffffff73;font-weight:700;text-transform:uppercase;letter-spacing:.2em;margin-top:.2rem}.sidebar-quick-action{padding:0 1.25rem 1.5rem}.vip-action-btn{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:16px;color:#fff;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 15px -3px #4f46e566;border:1px solid rgba(255,255,255,.1)}.vip-action-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 20px 25px -5px #4f46e580;border-color:#ffffff4d}.vip-action-btn .btn-icon{width:40px;height:40px;background:#fff3;border-radius:10px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.vip-action-btn .btn-label{display:flex;flex-direction:column}.vip-action-btn .btn-label strong{font-size:1rem;line-height:1.2}.vip-action-btn .btn-label span{font-size:.75rem;opacity:.8}.sidebar-nav{flex:1;padding:0 1rem 1.5rem;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto}.nav-section-label{padding:1rem 1.25rem .5rem;font-size:.65rem;font-weight:700;color:#ffffff4d;letter-spacing:.1em}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;border-radius:12px;color:var(--sidebar-text);text-decoration:none;font-weight:500;font-size:.875rem;transition:all .2s}.nav-item:hover{color:#fff;background:#ffffff0d}.nav-item.active{background:var(--sidebar-active-bg);color:#fff}.nav-item svg{transition:transform .2s}.nav-item:hover svg{transform:translate(3px)}.sidebar-promo{padding:1.5rem}.promo-card{background:#ffffff08;padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.promo-icon{font-size:1.25rem;margin-bottom:.5rem}.promo-card p{font-size:.75rem;color:var(--sidebar-text);margin:0;line-height:1.4}@media(max-width:1024px){.sidebar{width:240px}}.layout{display:flex;min-height:100vh;background:#f1f5f9}.app-wrapper{flex:1;margin-left:280px;display:flex;flex-direction:column;min-height:100vh;transition:var(--transition)}.main-header{height:80px;background:#fff;padding:0 2.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:90;box-shadow:0 1px 3px #0000000d}.school-branding h1{font-size:1.35rem;font-weight:700;color:#1e293b;margin:0;letter-spacing:.05em;text-transform:uppercase;line-height:1.2}.school-branding p{font-size:.8rem;color:#94a3b8;margin-top:2px;font-weight:500}.school-branding p span{color:var(--primary);font-weight:600}.header-right{display:flex;align-items:center;gap:2rem}.header-actions{display:flex;align-items:center;gap:.75rem}.header-btn{width:44px;height:44px;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative;text-decoration:none}.header-btn.has-notif{color:var(--primary);border-color:var(--primary-light)}.notif-count-badge{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;padding:0 4px;border-radius:10px;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 4px #ef44444d}.notification-wrapper{position:relative}.notif-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:320px;background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border:1px solid #f1f5f9;z-index:100;overflow:hidden;animation:slideUp .2s ease-out}.notif-dropdown-header{padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;font-weight:700;color:var(--text-primary)}.unread-dot-label{font-size:.75rem;background:#4f46e51a;color:var(--primary);padding:2px 8px;border-radius:20px}.notif-list{max-height:360px;overflow-y:auto}.notif-item{display:flex;gap:1rem;padding:1rem 1.25rem;cursor:pointer;transition:all .2s;border-bottom:1px solid #f8fafc}.notif-item:hover{background:#f8fafc}.notif-icon-circle{width:36px;height:36px;border-radius:10px;background:#f8fafc;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-content{flex:1;min-width:0}.notif-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 2px}.notif-desc{font-size:.8125rem;color:var(--text-tertiary);margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.notif-empty{padding:3rem 1.5rem;text-align:center;color:var(--text-tertiary)}.notif-empty svg{margin-bottom:.75rem;opacity:.3}.notif-all-btn{display:block;padding:.875rem;text-align:center;background:#f8fafc;color:var(--primary);font-size:.8125rem;font-weight:600;text-decoration:none;transition:all .2s}.notif-all-btn:hover{background:var(--primary);color:#fff}.dropdown-overlay{position:fixed;inset:0;z-index:95}.user-profile-wrapper{position:relative}.profile-trigger{display:flex;align-items:center;gap:1rem;background:none;border:none;padding:.5rem;border-radius:12px;cursor:pointer;transition:all .2s}.profile-trigger:hover{background:#f8fafc}.avatar-circle{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;box-shadow:0 4px 12px #4f46e533}.user-meta{text-align:left}.user-name-text{display:block;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.user-role-text{display:block;font-size:.75rem;color:var(--text-tertiary)}.profile-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:240px;background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border:1px solid #f1f5f9;padding:.75rem;z-index:100;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:.75rem}.full-name{font-weight:700;color:var(--text-primary);margin:0}.user-email{font-size:.75rem;color:var(--text-tertiary);margin:0}.dropdown-divider{height:1px;background:#f1f5f9;margin:.5rem 0}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:10px;color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s;width:100%;border:none;background:none;cursor:pointer}.dropdown-item:hover{background:#f8fafc;color:var(--primary)}.dropdown-item.logout:hover{background:#fef2f2;color:#ef4444}.profile-overlay{position:fixed;inset:0;z-index:95}.main-content{flex:1;padding:2.5rem;overflow-x:hidden;background:#fff}.content-inner{max-width:1400px;margin:0 auto;width:100%}.main-footer{background:#fff;padding:1.5rem 2.5rem;border-top:1px solid #f1f5f9}.footer-content{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;font-size:.8125rem;color:var(--text-tertiary)}.footer-right p strong{color:var(--primary)}@media(max-width:1024px){.app-wrapper{margin-left:240px}.main-header{padding:0 1.5rem}.main-content{padding:1.5rem}.main-footer{padding:1rem 1.5rem}.user-meta{display:none}}.settings-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}.settings-sidebar{padding:0;overflow:hidden;position:sticky;top:2rem}.settings-nav{display:flex;flex-direction:column}.settings-nav-item{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:transparent;border:none;border-left:3px solid transparent;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--text-secondary);transition:all .2s;text-align:left;width:100%}.settings-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.settings-nav-item.active{background:#6366f114;color:var(--primary);border-left-color:var(--primary)}.settings-content{min-height:500px}.section-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:flex-end}.section-header h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:.25rem}.form-row{display:flex;gap:1.5rem;margin-bottom:1.5rem}.form-row .form-group{flex:1}.form-group.full{flex:100%}.form-footer{display:flex;justify-content:flex-end;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-light)}.rules-grid{display:grid;gap:1.5rem}.rule-card{display:flex;gap:1.5rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);align-items:flex-start}.rule-card.warning{background:#fffbeb;border-color:#fcd34d}.rule-icon{padding:.75rem;background:#fff;border-radius:50%;color:var(--primary);box-shadow:var(--shadow-sm)}.rule-content{flex:1}.rule-content label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.rule-content .input{max-width:150px;margin-bottom:.5rem}.help-text{font-size:.85rem;color:var(--text-secondary);margin:0}.license-card{background:linear-gradient(135deg,#f8fafc,#eef2ff);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;max-width:600px;margin:0 auto}.license-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.license-title h3{font-size:1.5rem;margin-bottom:.5rem}.license-details{display:flex;flex-direction:column;gap:1rem}.detail-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(0,0,0,.05)}.detail-item:last-child{border-bottom:none}.detail-item .label{color:var(--text-secondary);font-weight:500}.detail-item .value{color:var(--text-primary);font-weight:700}@media(max-width:900px){.settings-layout{grid-template-columns:1fr}.settings-sidebar{position:static;margin-bottom:1.5rem}.settings-nav{flex-direction:row;overflow-x:auto;padding:.5rem}.settings-nav-item{border-left:none;border-bottom:3px solid transparent;white-space:nowrap;width:auto}.settings-nav-item.active{border-left-color:transparent;border-bottom-color:var(--primary)}.form-row{flex-direction:column;gap:1rem}}.preview-modal{max-width:1000px!important;width:95%;max-height:85vh;display:flex;flex-direction:column;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 25px 50px -12px #00000040;border-radius:20px;overflow:hidden}.preview-modal .modal-header{background:linear-gradient(135deg,#1e293b,#334155);color:#fff;padding:1.5rem 2rem;border-bottom:none}.preview-modal .modal-header h2{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.025em}.preview-modal .close-btn{color:#fffc;font-size:2rem;transition:all .2s}.preview-modal .close-btn:hover{color:#fff;transform:rotate(90deg)}.preview-modal .modal-body{overflow-y:auto;padding:2rem;background:#f8fafc}.table-responsive{width:100%;overflow-x:auto;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a}.preview-table{width:100%;border-collapse:collapse;background:#fff;font-size:.95rem}.preview-table th{background-color:#f1f5f9;padding:1rem;text-align:left;font-weight:600;color:#475569;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;border-bottom:2px solid #e2e8f0;position:sticky;top:0;z-index:10}.preview-table td{padding:1rem;border-bottom:1px solid #f1f5f9;color:#334155}.preview-table tr:hover{background-color:#f8fafc}.clickable-row:hover{background-color:#eff6ff!important;color:#2563eb}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.summary-item{background:#fff;padding:1.5rem;border-radius:16px;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:.5rem;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 3px #0000001a}.summary-item:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a}.summary-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:1.5rem;font-weight:700;color:#1e293b;word-break:break-word}.preview-modal .modal-footer{padding:1.5rem 2rem;background:#fff;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:1rem}.preview-modal .btn-secondary{background:#f1f5f9;color:#475569;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;border:1px solid #e2e8f0;cursor:pointer;transition:all .2s}.preview-modal .btn-secondary:hover{background:#e2e8f0;color:#1e293b}.preview-modal .btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;border:none;cursor:pointer;box-shadow:0 4px 6px -1px #2563eb33;transition:all .2s;display:flex;align-items:center;gap:.5rem}.preview-modal .btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 15px -3px #2563eb4d;filter:brightness(1.1)}.no-data{text-align:center;padding:3rem;color:#64748b;font-style:italic}.page-header{margin-bottom:2rem}.page-header h1{font-size:2.25rem;font-weight:800;color:#1e293b;letter-spacing:-.025em;margin-bottom:.5rem}.text-secondary{color:#64748b}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}@media(max-width:1024px){.grid-2,.grid-3{grid-template-columns:1fr}}.card{background:#fff;border-radius:20px;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000005}.card-header{padding:1.5rem 2rem;border-bottom:1px solid #f1f5f9;background:#fcfcfc}.card-header h3{display:flex;align-items:center;gap:.75rem;font-size:1.1rem;font-weight:700;color:#334155;margin:0}.flex-row{display:flex;gap:1rem;align-items:center}.flex-center{display:flex;align-items:center;justify-content:center}.space-between{display:flex;align-items:center;justify-content:space-between}.w-100{width:100%}.flex-1{flex:1}.button-group-vertical{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem 2rem}.report-group{background:#f8fafc;padding:1.5rem;border-radius:16px;border:1px solid #e2e8f0}.report-group-title{font-size:.85rem;font-weight:700;color:#64748b;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e2e8f0;padding-bottom:.75rem}.form-group{padding:0 2rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:#475569;margin-bottom:.5rem}.input{width:100%;padding:.75rem 1rem;border-radius:12px;border:1px solid #e2e8f0;background:#fff;font-size:.95rem;transition:all .2s}.input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}.btn{border:none;padding:.875rem 1.25rem;border-radius:12px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;font-family:inherit;gap:.5rem}.btn:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-info{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-secondary{background:#fff;color:#334155;border:1px solid #e2e8f0}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f172a4d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000}.loading-content{background:#fff;padding:2.5rem 4rem;border-radius:24px;box-shadow:0 25px 50px -12px #00000040;text-align:center;border:1px solid rgba(255,255,255,.2)}.recharts-default-tooltip{border-radius:12px!important;border:none!important;box-shadow:0 10px 15px -3px #0000001a!important}.preview-modal-overlay{position:fixed;inset:0;background:#000000d9;z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preview-modal{background:#fff;width:95vw;height:95vh;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.preview-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;background:#f8fafc;border-radius:12px 12px 0 0}.preview-modal-title{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.preview-modal-info{font-size:.875rem;color:#64748b;margin-top:.25rem}.preview-close-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:6px;color:#64748b;transition:all .2s;display:flex;align-items:center;justify-content:center}.preview-close-btn:hover{background:#e2e8f0;color:#1e293b}.preview-modal-body{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:1.5rem;gap:1rem}.preview-pdf-container{flex:1;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#f1f5f9;display:flex;align-items:center;justify-content:center;position:relative}.preview-pdf-iframe{width:100%;height:100%;border:none}.preview-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#64748b}.preview-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.preview-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8fafc;border-radius:0 0 12px 12px}.preview-actions{display:flex;gap:.75rem}.preview-btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;border:none}.preview-btn-secondary{background:#fff;color:#64748b;border:1px solid #cbd5e1}.preview-btn-secondary:hover{background:#f8fafc;border-color:#94a3b8}.preview-btn-primary{background:#3b82f6;color:#fff}.preview-btn-primary:hover{background:#2563eb}.preview-btn-success{background:#10b981;color:#fff}.preview-btn-success:hover{background:#059669}.preview-btn:disabled{opacity:.5;cursor:not-allowed}.preview-btn:disabled:hover{background:inherit}@media(max-width:768px){.preview-modal{width:100vw;height:100vh;border-radius:0}.preview-modal-footer{flex-direction:column;gap:.75rem}.preview-actions{width:100%;flex-direction:column}.preview-btn{width:100%;justify-content:center}}.printing-container{padding:2rem;max-width:1400px;margin:0 auto}.printing-header{margin-bottom:2rem}.printing-header h1{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.printing-header p{color:#64748b;font-size:1rem}.tabs-header{display:flex;gap:.5rem;background:#f1f5f9;padding:.4rem;border-radius:12px;margin-bottom:2rem;width:fit-content}.tab-btn{padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;color:#64748b;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.tab-btn:hover{color:#1e293b;background:#ffffff80}.tab-btn.active{color:#3b82f6;background:#fff;box-shadow:0 1px 3px #0000001a}.printing-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:start}@media(max-width:1200px){.printing-layout{grid-template-columns:1fr}}.book-selector,.print-settings{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:1.5rem;box-shadow:0 4px 6px -1px #0000000d}.selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.action-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem;font-size:.8rem;font-weight:600;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:all .2s}.action-btn.delete{background:#fef2f2;color:#ef4444}.action-btn.delete:hover:not(:disabled){background:#fee2e2;color:#dc2626}.action-btn.select{background:#eff6ff;color:#3b82f6}.action-btn.select:hover{background:#dbeafe;color:#2563eb}.action-btn:disabled{opacity:.5;cursor:not-allowed}.search-bar{display:flex;gap:.5rem;margin-bottom:1rem}.search-input{flex:1;padding:.6rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;outline:none}.search-bar button{padding:.6rem 1.25rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.search-bar button:hover{background:#2563eb;box-shadow:0 4px 6px -1px #2563eb33}.search-input:focus{border-color:#3b82f6;background:#fff;box-shadow:0 0 0 4px #3b82f61a}.book-list{max-height:550px;overflow-y:auto;border:1px solid #f1f5f9;border-radius:12px}.book-item{display:flex;align-items:center;gap:1rem;padding:.8rem 1rem;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .2s}.book-item:last-child{border-bottom:none}.book-item:hover{background:#f8fafc}.book-item.selected{background:#eff6ff}.book-info{display:flex;flex-direction:column}.book-title{font-size:.95rem;font-weight:600;color:#1e293b}.book-meta{font-size:.8rem;color:#64748b}.settings-group{margin-bottom:2rem}.settings-group h3{font-size:1rem;font-weight:700;margin-bottom:1rem;color:#334155}.checkbox-group{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;background:#f8fafc;padding:1.25rem;border-radius:12px}.checkbox-label{display:flex;align-items:center;gap:.6rem;font-size:.85rem;font-weight:500;color:#475569;cursor:pointer}.checkbox-label input{width:18px;height:18px;accent-color:#3b82f6}.custom-input{width:100%;margin-top:.3rem;padding:.5rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;background:#fff}.custom-input:focus{border-color:#3b82f6;outline:none}.input-label-sm{font-size:10px;text-transform:uppercase;color:#94a3b8;font-weight:600}.label-preview-box{margin-top:2rem;padding:1.5rem;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px}.preview-label{background:#fff;padding:1rem;border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d;border-radius:4px;min-height:120px;display:flex;flex-direction:column;justify-content:center;align-items:center}.btn-primary-gradient{background:linear-gradient(to right,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:700;transition:transform .2s,box-shadow .2s}.btn-primary-gradient:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.btn-primary-gradient:disabled{opacity:.6;cursor:not-allowed}.preset-btn{padding:.75rem;font-size:.8rem;font-weight:600;border-radius:8px;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;cursor:pointer;transition:all .2s;text-align:center}.preset-btn:hover{background:#f1f5f9;color:#1e293b}.preset-btn.active{background:#3b82f6;color:#fff;border-color:#2563eb;box-shadow:0 2px 4px #3b82f633}.grid{display:grid!important}.grid-cols-2{grid-template-columns:repeat(2,1fr)!important}.grid-cols-3{grid-template-columns:repeat(3,1fr)!important}.gap-2{gap:.5rem!important}.gap-3{gap:.75rem!important}.gap-4{gap:1rem!important}.flex{display:flex!important}.flex-col{flex-direction:column!important}.justify-between{justify-content:space-between!important}.justify-center{justify-content:center!important}.items-center{align-items:center!important}.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:.75rem!important}.mb-4{margin-bottom:1rem!important}.mt-1{margin-top:.25rem!important}.mt-2{margin-top:.5rem!important}.ml-4{margin-left:1rem!important}.ml-6{margin-left:1.5rem!important}.p-2{padding:.5rem!important}.p-4{padding:1rem!important}.p-8{padding:2rem!important}.p-12{padding:3rem!important}.py-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-4{padding-top:1rem!important;padding-bottom:1rem!important}.w-full{width:100%!important}.block{display:block!important}.font-semibold{font-weight:600!important}.font-bold{font-weight:700!important}.font-medium{font-weight:500!important}.text-sm{font-size:.875rem!important}.text-xs{font-size:.75rem!important}.text-lg{font-size:1.125rem!important}.text-xl{font-size:1.25rem!important}.text-gray-400{color:#94a3b8!important}.text-gray-500{color:#64748b!important}.text-gray-600{color:#475569!important}.text-gray-700{color:#374151!important}.text-gray-800{color:#1e293b!important}.text-blue-500{color:#3b82f6!important}.text-blue-600{color:#2563eb!important}.text-red-500{color:#ef4444!important}.border-b{border-bottom:1px solid #e2e8f0!important}.border-t{border-top:1px solid #e2e8f0!important}.pb-2{padding-bottom:.5rem!important}.rounded-xl{border-radius:.75rem!important}.rounded-lg{border-radius:.5rem!important}.rounded-full{border-radius:9999px!important}.bg-gray-100{background-color:#f3f4f6!important}.bg-gray-200{background-color:#e5e7eb!important}.bg-blue-50{background-color:#eff6ff!important}.bg-gray-50{background-color:#f9fafb!important}.hover\:bg-gray-200:hover{background-color:#e5e7eb!important}.hover\:underline:hover{text-decoration:underline!important}.cursor-pointer{cursor:pointer!important}.uppercase{text-transform:uppercase!important}.tracking-wider{letter-spacing:.05em!important}.border-dashed{border-style:dashed!important}.border{border:1px solid #e2e8f0!important}.member-detail-container{padding:20px;min-height:100vh;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.member-detail-header{display:flex;align-items:center;gap:15px;margin-bottom:30px}.back-btn{border:none;background:#fff;cursor:pointer;padding:10px;border-radius:50%;box-shadow:0 2px 5px #0000000d;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#495057}.back-btn:hover{background:#e9ecef;transform:translate(-3px)}.detail-grid{display:grid;grid-template-columns:350px 1fr;gap:30px}.profile-card{background:#fff;border-radius:16px;padding:30px;box-shadow:0 10px 30px #0000000a;position:sticky;top:20px;text-align:center;border:1px solid #f1f3f5}.avatar-container{margin-bottom:20px;position:relative;display:inline-block}.avatar-large{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;color:#fff;overflow:hidden;margin:0 auto;box-shadow:0 5px 15px #0000001a}.avatar-img{width:100%;height:100%;object-fit:cover}.member-name{font-size:1.5rem;font-weight:700;color:#212529;margin-bottom:5px}.member-meta{font-size:1rem;color:#868e96;font-weight:500}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border-radius:30px;font-size:.9rem;font-weight:600;margin-top:15px}.status-active{background:#d3f9d8;color:#2b8a3e}.status-passive{background:#ffe3e3;color:#c92a2a}.info-list{margin-top:30px;text-align:left}.info-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f8f9fa;font-size:.95rem;color:#495057}.info-label{color:#868e96;font-size:.9rem}.info-value{font-weight:600;color:#212529}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px}.metric-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 4px 15px #00000008;border-left-width:4px;border-left-style:solid;display:flex;justify-content:space-between;align-items:flex-start;transition:transform .2s}.metric-card:hover{transform:translateY(-3px)}.metric-content{flex:1}.metric-label{font-size:.85rem;color:#868e96;margin-bottom:5px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:1.6rem;font-weight:800;color:#212529;margin-bottom:5px}.metric-sub{font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:4px}.metric-icon-box{width:45px;height:45px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-left:15px}.color-blue{border-color:#4c6ef5}.bg-blue-light{background:#edf2ff;color:#4c6ef5}.text-blue{color:#4c6ef5}.color-green{border-color:#40c057}.bg-green-light{background:#ebfbee;color:#40c057}.text-green{color:#40c057}.color-yellow{border-color:#fcc419}.bg-yellow-light{background:#fff9db;color:#fcc419}.text-yellow{color:#fab005}.color-red{border-color:#fa5252}.bg-red-light{background:#fff5f5;color:#fa5252}.text-red{color:#fa5252}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px}.chart-card{background:#fff;padding:25px;border-radius:16px;box-shadow:0 4px 20px #00000008;border:1px solid #f1f3f5}.chart-title{font-size:1.1rem;font-weight:700;color:#343a40;margin-bottom:20px;display:flex;align-items:center;gap:10px}.timeline-card{background:#fff;padding:30px;border-radius:16px;box-shadow:0 4px 20px #00000008;border:1px solid #f1f3f5}.timeline{position:relative;padding-left:20px;border-left:2px solid #e9ecef;margin-top:10px;margin-left:10px}.timeline-item{position:relative;padding-left:25px;margin-bottom:30px}.timeline-item:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:-29px;top:5px;width:16px;height:16px;border-radius:50%;border:3px solid white;box-shadow:0 2px 5px #00000026}.timeline-content{display:flex;justify-content:space-between;align-items:flex-start}.timeline-title{font-weight:700;font-size:1rem;color:#343a40;margin:0 0 5px}.timeline-desc{font-size:.9rem;color:#868e96;margin:0}.timeline-date{font-size:.8rem;color:#adb5bd;background:#f8f9fa;padding:4px 8px;border-radius:6px;font-family:monospace;white-space:nowrap}@media(max-width:1100px){.charts-grid{grid-template-columns:1fr}}@media(max-width:900px){.detail-grid{grid-template-columns:1fr}.profile-card{position:static;margin-bottom:20px}}.register-card{max-width:900px!important}.register-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.full-width{grid-column:span 2}@media(max-width:768px){.register-grid{grid-template-columns:1fr}.full-width{grid-column:span 1}}.section-title{font-size:1rem;font-weight:600;color:#475569;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e2e8f0;grid-column:span 2;margin-top:1rem}.section-title:first-of-type{margin-top:0}.radio-group{display:flex;gap:2rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.radio-option{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;color:#334155}.radio-option input[type=radio]{width:20px;height:20px;accent-color:#4f46e5}.success-container{text-align:center;padding:2rem}.success-icon{color:#16a34a;width:80px;height:80px;margin-bottom:1.5rem}.success-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:1rem}.success-text{color:#64748b;margin-bottom:2rem;line-height:1.6}.login-link{color:#4f46e5;text-decoration:none;font-weight:600;margin-top:1rem;display:inline-block}.login-link:hover{text-decoration:underline}.notification-management-container{padding:24px;background-color:#f8f9fa;min-height:100vh}.page-header{display:flex;align-items:center;margin-bottom:24px;color:#2c3e50;font-size:24px;font-weight:600}.page-header svg{margin-right:12px;color:#3498db}.tabs-container{display:flex;border-bottom:1px solid #e0e0e0;margin-bottom:0;background:transparent;padding:0 8px}.tab-button{padding:12px 20px;font-weight:500;color:#7f8c8d;background:none;border:none;cursor:pointer;transition:all .3s;border-bottom:3px solid transparent;display:flex;align-items:center;font-size:14px;margin-right:4px}.tab-button svg{margin-right:8px}.tab-button:hover{color:#3498db;background-color:#3498db0d;border-radius:4px 4px 0 0}.tab-button.active{color:#3498db;border-bottom-color:#3498db}.notif-badge{background-color:#e74c3c;color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;margin-left:8px;font-weight:700}.content-area{background:#fff;border-radius:0 8px 8px;box-shadow:0 2px 10px #00000008;padding:24px;border:1px solid #e0e0e0}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:500;color:#34495e;font-size:14px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;border:1px solid #dce0e4;border-radius:6px;font-size:14px;transition:border-color .2s;outline:none;box-sizing:border-box}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-textarea{resize:vertical;min-height:120px;font-family:inherit}.grid-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:768px){.grid-row{grid-template-columns:1fr}}.checkbox-wrapper{display:flex;align-items:center;margin-bottom:8px;cursor:pointer}.checkbox-input{width:18px;height:18px;margin-right:10px;accent-color:#3498db;cursor:pointer}.checkbox-label{font-size:14px;color:#2c3e50;cursor:pointer}.school-selection{border:1px solid #dce0e4;border-radius:6px;padding:16px;background-color:#f9fafb;max-height:250px;overflow-y:auto;margin-top:10px}.school-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.form-actions{display:flex;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid #f0f0f0}.btn-primary{background-color:#3498db;color:#fff;border:none;padding:12px 28px;border-radius:6px;font-weight:500;cursor:pointer;display:flex;align-items:center;transition:background-color .2s;font-size:15px}.btn-primary:hover{background-color:#2980b9}.btn-primary svg{margin-right:8px}.btn-primary:disabled{opacity:.7;cursor:not-allowed;background-color:#95a5a6}.table-container{overflow-x:auto;border:1px solid #e0e0e0;border-radius:6px}.data-table{width:100%;border-collapse:collapse;white-space:nowrap}.data-table th{text-align:left;padding:14px 16px;background-color:#f8f9fa;color:#7f8c8d;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #ecf0f1}.data-table td{padding:16px;border-bottom:1px solid #ecf0f1;font-size:14px;color:#2c3e50;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:#fbfbfb}.data-table tr.unread{background-color:#f0f7ff}.data-table tr.unread td{font-weight:500;color:#2c3e50}.empty-state{padding:60px 20px;text-align:center;color:#95a5a6;font-size:15px}.loading-state{padding:40px;text-align:center;color:#3498db}.status-badge{padding:5px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;display:inline-block}.text-info{color:#3498db}.bg-info{background-color:#e8f6fc;color:#2980b9}.text-success{color:#27ae60}.bg-success{background-color:#eafaf1;color:#219150}.text-warning{color:#e67e22}.bg-warning{background-color:#fef5e7;color:#d35400}.text-danger{color:#e74c3c}.bg-danger{background-color:#fdedec;color:#c0392b}.bg-gray{background-color:#f2f3f4;color:#7f8c8d}.type-cell{display:flex;align-items:center}.type-cell svg{margin-right:8px}.message-preview{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#7f8c8d;font-size:13px;font-weight:400}.btn-icon{background:none;border:none;cursor:pointer;color:#bdc3c7;transition:all .2s;padding:6px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{color:#3498db;background-color:#ebf5fb}.btn-icon.read{color:#dce0e4;cursor:default}.unread-dot{width:8px;height:8px;background-color:#3498db;border-radius:50%;display:inline-block}.notifications-page{padding:24px;background-color:#f8f9fa;min-height:100vh}.page-title{display:flex;align-items:center;margin-bottom:24px;font-size:24px;font-weight:600;color:#2c3e50}.page-title svg{margin-right:12px;color:#f39c12}.notifications-list{background:#fff;border-radius:8px;box-shadow:0 2px 10px #00000008;border:1px solid #e0e0e0;max-width:900px;margin:0 auto}.notification-item{padding:20px;border-bottom:1px solid #f0f0f0;display:flex;align-items:flex-start;transition:background-color .2s;position:relative}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:#fbfbfb}.notification-item.unread{background-color:#f0f7ff;border-left:3px solid #3498db}.notif-icon-box{margin-right:16px;padding:10px;border-radius:50%;background-color:#f5f5f5;display:flex;align-items:center;justify-content:center;min-width:44px;height:44px}.notif-content{flex:1}.notif-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.notif-title{font-weight:600;color:#2c3e50;font-size:16px}.notif-time{font-size:12px;color:#95a5a6;white-space:nowrap;margin-left:10px}.notif-body{color:#555;font-size:14px;line-height:1.5;margin-bottom:12px}.notif-footer{display:flex;align-items:center;font-size:12px;color:#7f8c8d;justify-content:space-between}.notif-meta{display:flex;align-items:center}.notif-badge{padding:3px 8px;border-radius:4px;font-weight:600;margin-right:10px;font-size:11px;text-transform:uppercase}.sender-info{font-style:italic;font-size:12px;color:#95a5a6}.mark-read-btn{background:none;border:none;color:#3498db;cursor:pointer;font-weight:500;padding:4px 8px;border-radius:4px;display:flex;align-items:center;transition:background-color .2s}.mark-read-btn:hover{background-color:#3498db1a}.mark-read-btn svg{margin-right:4px}.empty-state{text-align:center;padding:60px;color:#95a5a6;font-size:16px}.loading-state{text-align:center;padding:40px;color:#bdc3c7}.spin{animation:spin 1s linear infinite}.badge-urgent{background-color:#ffebee;color:#c62828}.badge-normal{background-color:#e3f2fd;color:#1565c0}.badge-warning{background-color:#fff3e0;color:#ef6c00}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-container{padding:2rem;max-width:1200px;margin:0 auto}.profile-grid{display:grid;grid-template-columns:350px 1fr;gap:2rem}.profile-main-card{background:#fff;border-radius:24px;padding:2.5rem 2rem;text-align:center;box-shadow:0 10px 25px -5px #0000000d;border:1px solid #e2e8f0;height:fit-content}.avatar-wrapper{position:relative;width:140px;height:140px;margin:0 auto 1.5rem}.profile-avatar{width:100%;height:100%;border-radius:50%;object-fit:cover;border:5px solid white;box-shadow:0 8px 16px #0000001a;background:#f1f5f9;display:flex;align-items:center;justify-content:center}.level-badge{position:absolute;bottom:5px;right:5px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;border:3px solid white;box-shadow:0 4px 6px #0000001a}.profile-name{font-size:1.5rem;font-weight:800;color:#1e293b;margin-bottom:.25rem}.profile-school{color:#64748b;font-size:.9rem;margin-bottom:1.5rem;display:block}.point-stats-compact{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #f1f5f9}.stat-box{text-align:center}.stat-value{display:block;font-size:1.5rem;font-weight:800;color:#3b82f6}.stat-label{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.profile-details{display:flex;flex-direction:column;gap:2rem}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.stat-card{background:#fff;padding:1.5rem;border-radius:20px;display:flex;align-items:center;gap:1.25rem;border:1px solid #f1f5f9;transition:transform .2s}.stat-card:hover{transform:translateY(-5px)}.stat-icon{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center}.icon-blue{background:#eff6ff;color:#3b82f6}.icon-green{background:#ecfdf5;color:#10b981}.icon-orange{background:#fff7ed;color:#f59e0b}.stat-info h4{margin:0;font-size:.85rem;color:#64748b;font-weight:600}.stat-info p{margin:0;font-size:1.5rem;font-weight:800;color:#1e293b}.badges-section{background:#fff;padding:2rem;border-radius:24px;border:1px solid #e2e8f0}.section-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:#1e293b;margin-bottom:2rem}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1.5rem}.badge-item{text-align:center;padding:1rem;border-radius:16px;transition:all .2s;cursor:pointer}.badge-item:hover{background:#f8fafc}.badge-icon-vault{width:64px;height:64px;background:#f1f5f9;border-radius:50%;margin:0 auto .75rem;display:flex;align-items:center;justify-content:center;color:#94a3b8;position:relative}.badge-item.active .badge-icon-vault{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706;box-shadow:0 4px 12px #d9770633}.badge-name{font-size:.85rem;font-weight:700;color:#475569;display:block}.badge-item:not(.active) .badge-name{color:#94a3b8}.activity-card{background:#fff;padding:2rem;border-radius:24px;border:1px solid #e2e8f0}@media(max-width:991px){.profile-grid{grid-template-columns:1fr}.profile-main-card{max-width:400px;margin:0 auto}}@media(max-width:640px){.stats-row{grid-template-columns:1fr}}
