:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;font-family:Arial,Helvetica,sans-serifcv}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.mobile-menu-toggle{display:none;position:fixed;top:16px;left:16px;z-index:1001;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;transition:all .2s ease;box-shadow:0 4px 16px #4f46e573;-webkit-tap-highlight-color:transparent}.mobile-menu-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:4px;transition:all .3s ease}.sidebar-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998;animation:fadeIn .2s ease}.user-sidebar{width:280px;height:100vh;background:linear-gradient(145deg,#4f46e5,#7c3aed,#c026d3);color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:999;transition:transform .3s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:4px 0 40px #4f46e559}.sidebar-gradient{position:absolute;top:-100px;right:-100px;width:280px;height:280px;background:radial-gradient(circle,rgba(255,255,255,.12) 0%,transparent 70%);border-radius:50%;pointer-events:none;animation:sidebarPulse 8s ease-in-out infinite}.user-sidebar:after{content:"";position:absolute;bottom:-80px;left:-80px;width:220px;height:220px;background:radial-gradient(circle,rgba(251,191,36,.15) 0%,transparent 70%);border-radius:50%;pointer-events:none;animation:sidebarPulse 11s ease-in-out infinite reverse}.sidebar-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10;-webkit-tap-highlight-color:transparent}.user-info{display:flex;align-items:center;gap:14px}.user-avatar-wrapper{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#fff3!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.35);box-shadow:0 4px 12px #00000026;flex-shrink:0}.user-avatar-wrapper:before{display:none}.user-logo-avatar{background:#fff!important;padding:4px;overflow:hidden}.user-logo-avatar img{width:100%;height:100%;object-fit:contain;border-radius:10px}.user-avatar{width:auto;height:auto;background:none!important;border-radius:0;font-size:1.4rem;font-weight:700;color:#fff!important;box-shadow:none}.user-details{display:flex;flex-direction:column;overflow:hidden}.user-greeting{font-size:.7rem;color:#fff9;text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px}.user-name{font-size:1rem;font-weight:700;color:#fff;line-height:1.3;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.68rem;color:#ffffffa6;background:#ffffff26;border:1px solid rgba(255,255,255,.2);padding:2px 8px;border-radius:20px;display:inline-block;width:fit-content;font-weight:500}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto;position:relative;z-index:2;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.nav-section{margin-bottom:1rem}.nav-section-title{font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:#ffffff73;padding:0 1.25rem;margin-bottom:.5rem;font-weight:600}.nav-item{width:100%;padding:.8rem 1rem;background:transparent;border:none;color:#fffc;text-align:left;font-size:.95rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:12px;border-radius:12px;position:relative;font-weight:500;-webkit-tap-highlight-color:transparent}.nav-item:hover{background:#ffffff1f;color:#fff;transform:translate(3px)}.nav-item.active{background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-weight:600;border:1px solid rgba(255,255,255,.25);box-shadow:0 4px 12px #0000001a}.nav-icon-wrapper{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.15);transition:all .2s ease;flex-shrink:0}.nav-item:hover .nav-icon-wrapper{background:#fff3;transform:scale(1.08)}.nav-item.active .nav-icon-wrapper{background:#ffffff40}.nav-label{flex:1}.active-indicator{width:7px;height:7px;background:#fbbf24;border-radius:50%;box-shadow:0 0 8px #fbbf2499;position:absolute;right:12px}.footer-content{display:flex;flex-direction:column;gap:.75rem}.logout-btn{width:100%;padding:.75rem 1rem;background:#ef44442e;border:1.5px solid rgba(252,165,165,.55);color:#fff;font-size:.95rem;cursor:pointer;border-radius:12px;transition:all .2s ease;display:flex;align-items:center;gap:12px;font-weight:700;-webkit-tap-highlight-color:transparent;letter-spacing:.01em}.logout-btn:hover{background:#ef444459;border-color:#fca5a5;transform:translateY(-1px);box-shadow:0 4px 14px #ef44444d}.logout-btn:active{transform:scale(.98)}.logout-icon-wrapper{width:32px;height:32px;background:#fca5a533;border:1px solid rgba(252,165,165,.35);border-radius:8px;display:flex;align-items:center;justify-content:center}.logout-hint{margin-left:auto;font-size:1rem;opacity:.8;color:#fca5a5;transition:opacity .2s}.logout-btn:hover .logout-hint{opacity:1}.app-version{text-align:center;font-size:.65rem;color:#ffffff4d;padding:.25rem}@keyframes slideInRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@media(max-width:768px){.mobile-menu-toggle{display:flex}.user-sidebar{transform:translate(-100%);box-shadow:none}.user-sidebar.open{transform:translate(0);box-shadow:4px 0 30px #4f46e566}.sidebar-header{padding:1.25rem 3rem 1rem 1rem}.sidebar-close{display:flex}.user-avatar-wrapper{width:46px;height:46px}.user-avatar{font-size:1.2rem}.user-name{font-size:.95rem}.nav-item{padding:.7rem 1rem}.nav-icon-wrapper{width:30px;height:30px;font-size:.95rem}.logout-hint{display:none}}@media(max-width:480px){.mobile-menu-toggle{top:12px;left:12px;width:40px;height:40px;border-radius:10px}.user-sidebar{width:260px}.sidebar-header{padding:1rem 2.5rem .875rem .875rem}.sidebar-close{top:12px;right:12px;width:28px;height:28px}.user-avatar-wrapper{width:42px;height:42px;border-radius:12px}.user-name{font-size:.9rem}.user-greeting{font-size:.65rem}.nav-item{padding:.6rem .875rem;font-size:.9rem}.nav-icon-wrapper{width:28px;height:28px;border-radius:8px}.sidebar-footer{padding:.875rem}.logout-btn{padding:.6rem .875rem;font-size:.9rem}.logout-icon-wrapper{width:28px;height:28px;border-radius:7px}.app-version{font-size:.6rem}}@media(min-width:769px)and (max-width:1024px){.user-sidebar{width:240px}.sidebar-header{padding:1.5rem 1rem}.sidebar-close{display:none}}@media(min-width:1025px){.sidebar-close{display:none}}@media(max-height:600px)and (orientation:landscape){.user-sidebar{overflow-y:auto}.sidebar-header{padding:.875rem 2.5rem .875rem .875rem}.user-avatar-wrapper{width:38px;height:38px}.user-name{font-size:.85rem}.sidebar-nav{padding:.5rem 0}.nav-item{padding:.4rem .875rem}.sidebar-footer{padding:.5rem .875rem}}.nav-item:focus-visible,.logout-btn:focus-visible,.mobile-menu-toggle:focus-visible,.sidebar-close:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:2px}@media(prefers-reduced-motion:reduce){.user-sidebar,.nav-item,.logout-btn,.mobile-menu-toggle,.sidebar-overlay,.sidebar-close,.sidebar-gradient,.user-sidebar:after{transition:none!important;animation:none!important}}@media print{.user-sidebar,.mobile-menu-toggle,.sidebar-overlay{display:none}}.reg-page{padding:2rem;max-width:900px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;background:#f5f4ff}.reg-header{margin-bottom:1.5rem}.reg-back-btn{display:inline-flex;align-items:center;gap:6px;margin-bottom:.75rem;padding:.45rem 1rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.82rem;font-weight:600;color:#4f46e5;cursor:pointer;transition:all .2s}.reg-back-btn:hover{background:#f5f3ff;border-color:#c4b5fd}.reg-back-action-btn{background:#fff!important;color:#6b7280!important;border:1.5px solid #e5e7eb!important;box-shadow:none!important}.reg-back-action-btn:hover:not(:disabled){background:#f9fafb!important;transform:none!important;box-shadow:none!important}.reg-title{font-size:1.75rem;font-weight:800;color:#111827;letter-spacing:-.02em;margin:0 0 .25rem}.reg-subtitle{font-size:.9rem;color:#9ca3af;margin:0}.reg-message{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;border-radius:14px;margin-bottom:1.25rem;font-size:.9rem;font-weight:500;animation:slideIn .3s ease}.reg-message.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.reg-message.error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.reg-msg-icon{width:22px;height:22px;border-radius:50%;background:currentColor;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.reg-message.success .reg-msg-icon{background:#16a34a}.reg-message.error .reg-msg-icon{background:#dc2626}.reg-msg-close{margin-left:auto;background:none;border:none;cursor:pointer;font-size:1.2rem;color:inherit;opacity:.5;padding:0;line-height:1;transition:opacity .2s}.reg-msg-close:hover{opacity:1}.reg-card{background:#fff;border-radius:28px;box-shadow:0 4px 6px -1px #4f46e50f,0 20px 60px -8px #4f46e524;overflow:hidden;position:relative}.reg-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3,#f59e0b);background-size:200% 100%;animation:gradientShift 4s linear infinite}.reg-form{padding:2.5rem 2.5rem 2rem}.reg-section{margin-bottom:2rem}.reg-section-header{display:inline-flex;align-items:center;gap:.55rem;font-size:.72rem;font-weight:700;letter-spacing:.1em;color:#fff;padding:.45rem 1rem;border-radius:100px;margin-bottom:1.25rem}.owner-header{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.animal-header{background:linear-gradient(135deg,#7c3aed,#c026d3)}.doctor-header{background:linear-gradient(135deg,#0891b2,#0e7490)}.reg-section-dot{width:6px;height:6px;border-radius:50%;background:#ffffffbf;flex-shrink:0}.owner-layout{display:grid;grid-template-columns:1fr 148px;gap:1.5rem;align-items:start}.owner-fields{display:flex;flex-direction:column;gap:1rem}.reg-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.reg-field{display:flex;flex-direction:column;gap:.4rem}.reg-field.full{grid-column:1 / -1}.reg-label{font-size:.82rem;font-weight:600;color:#374151;letter-spacing:.01em}.req{color:#ef4444;font-size:.88rem}.reg-input{width:100%;padding:.8rem 1rem;font-size:.93rem;color:#111827;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:12px;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;-webkit-appearance:none;appearance:none;box-sizing:border-box}.reg-input::placeholder{color:#d1d5db}.reg-input:focus{border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1a}.reg-input:disabled{opacity:.6;cursor:not-allowed}.reg-textarea{width:100%;padding:.8rem 1rem;font-size:.93rem;color:#111827;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:12px;outline:none;resize:vertical;font-family:inherit;line-height:1.5;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.reg-textarea::placeholder{color:#d1d5db}.reg-textarea:focus{border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1a}.reg-textarea:disabled{opacity:.6;cursor:not-allowed}.reg-hint{font-size:.75rem;color:#9ca3af;margin-top:.1rem}.reg-radio-group{display:flex;gap:1.75rem;padding:.8rem 1rem;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:12px;align-items:center}.reg-radio{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.93rem;color:#374151;font-weight:500}.reg-radio input[type=radio]{width:16px;height:16px;cursor:pointer;accent-color:#7c3aed}.photo-panel{display:flex;flex-direction:column;gap:.4rem}.photo-upload{position:relative;border:2px dashed #d1d5db;border-radius:16px;cursor:pointer;background:#f9fafb;aspect-ratio:3 / 4;overflow:hidden;transition:border-color .2s,background .2s}.photo-upload:hover{border-color:#7c3aed;background:#faf5ff}.photo-file-input{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:2}.photo-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;color:#9ca3af;font-size:.78rem;text-align:center;padding:.5rem;pointer-events:none;z-index:1}.photo-icon{font-size:1.8rem}.photo-hint{font-size:.68rem;color:#d1d5db}.photo-preview-box{position:absolute;inset:0}.photo-preview-box img{width:100%;height:100%;object-fit:cover}.photo-remove{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;background:#dc2626e0;color:#fff;border:none;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;line-height:1;transition:background .2s}.photo-remove:hover:not(:disabled){background:#dc2626}.photo-remove:disabled{opacity:.5;cursor:not-allowed}.photo-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff59}.photo-progress-fill{height:100%;background:#7c3aed;transition:width .3s ease}.reg-input.field-error,.reg-textarea.field-error{border-color:#ef4444;background:#fff5f5;box-shadow:0 0 0 3px #ef44441a}.reg-radio-group.field-error{border-color:#ef4444;background:#fff5f5}.photo-upload.field-error{border-color:#ef4444}.field-error-text{font-size:.76rem;color:#dc2626;font-weight:500;margin-top:.1rem;display:block}.reg-actions{display:flex;gap:.875rem;margin-top:2rem;padding-top:1.5rem;border-top:1.5px solid #f3f4f6;justify-content:flex-start}.reg-btn{padding:.65rem 2rem;min-width:120px;font-size:.95rem;font-weight:700;border:none;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;letter-spacing:.01em}.reg-btn:disabled{opacity:.65;cursor:not-allowed}.reg-btn:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);transform:translate(-100%);transition:transform .5s ease}.reg-btn:hover:not(:disabled):after{transform:translate(100%)}.submit-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed,#c026d3);color:#fff;box-shadow:0 4px 20px #7c3aed4d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed6b}.share-btn{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;box-shadow:0 4px 20px #f9731640}.share-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #f9731659}.print-btn{background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff;box-shadow:0 4px 20px #0891b240}.print-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #0891b259}.reg-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.reg-modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .25s ease}.reg-success-modal{background:#fff;border-radius:28px;max-width:420px;width:100%;box-shadow:0 25px 60px #0003;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1) both;overflow:hidden;position:relative}.reg-success-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3)}.success-modal-header{padding:2rem 2rem 1.25rem;text-align:center;position:relative}.success-check{width:70px;height:70px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:2.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 10px 30px #7c3aed59}.success-modal-header h2{font-size:1.4rem;font-weight:800;color:#111827;margin:0;letter-spacing:-.02em}.success-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:#9ca3af;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s}.success-close:hover{color:#374151;background:#f3f4f6}.success-modal-body{padding:0 2rem 1.5rem;text-align:center}.success-modal-body>p{color:#6b7280;font-size:.95rem;margin:0 0 1.25rem}.tag-display{background:#f5f3ff;border:2px dashed #7c3aed;border-radius:16px;padding:1.25rem;margin-bottom:.75rem}.tag-label{display:block;font-size:.72rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.4rem}.tag-value{display:block;font-size:2.5rem;font-weight:800;color:#4f46e5;font-family:monospace;letter-spacing:2px}.tag-note{font-size:.8rem;color:#9ca3af;margin:0}.success-modal-pdf{padding:1.25rem 2rem;border-top:1px solid #f3f4f6}.pdf-section-label{font-size:.75rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .875rem;text-align:center}.pdf-action-btns{display:flex;gap:.625rem;justify-content:center;flex-wrap:wrap}.pdf-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:.6rem 1.1rem;border:none;border-radius:10px;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s;flex:1;min-width:100px}.pdf-download{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;box-shadow:0 3px 10px #4f46e540}.pdf-download:hover:not(:disabled){opacity:.9;box-shadow:0 5px 14px #4f46e559;transform:translateY(-1px)}.pdf-share{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;box-shadow:0 3px 10px #f9731640}.pdf-share:hover:not(:disabled){opacity:.9;box-shadow:0 5px 14px #f9731659;transform:translateY(-1px)}.pdf-print{background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff;box-shadow:0 3px 10px #0891b240}.pdf-print:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.pdf-action-btn:disabled{opacity:.6;cursor:not-allowed}.success-modal-footer{padding:0 2rem 2rem;text-align:center}.success-ok-btn{padding:.875rem 3rem;background:linear-gradient(135deg,#4f46e5,#7c3aed,#c026d3);color:#fff;border:none;border-radius:100px;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px #7c3aed4d;letter-spacing:.01em}.success-ok-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed6b}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.reg-page{padding:1rem}.reg-form{padding:1.5rem 1.25rem 1.25rem}.owner-layout{grid-template-columns:1fr}.photo-panel{order:-1}.photo-upload{aspect-ratio:16 / 9;max-height:180px}.reg-row{grid-template-columns:1fr}.reg-actions{flex-direction:row}.reg-btn{min-width:100px}.tag-value{font-size:2rem}}@media(max-width:480px){.reg-card{border-radius:20px}.reg-title{font-size:1.4rem}.reg-form{padding:1.25rem 1rem 1rem}.success-modal-header h2{font-size:1.2rem}.tag-value{font-size:1.75rem}}.rec-page{min-height:100vh;background:#f5f4ff;padding:1.5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.rec-message{position:fixed;top:20px;right:20px;z-index:2000;display:flex;align-items:center;gap:10px;padding:.875rem 1.25rem;border-radius:14px;font-size:.9rem;font-weight:500;box-shadow:0 8px 30px #0000001f;animation:recSlideIn .25s ease;max-width:360px}.rec-message.success{background:#ecfdf5;color:#065f46;border-left:4px solid #10b981}.rec-message.error{background:#fef2f2;color:#991b1b;border-left:4px solid #ef4444}.rec-msg-icon{font-weight:700;font-size:1rem}.rec-msg-close{margin-left:auto;background:none;border:none;font-size:1.1rem;cursor:pointer;color:inherit;opacity:.6;line-height:1;padding:0}.rec-msg-close:hover{opacity:1}.rec-message-modal{position:static;box-shadow:none;animation:none;margin:0 1.5rem;border-radius:10px}@keyframes recSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.rec-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;gap:1rem;flex-wrap:wrap}.rec-page-title{font-size:1.6rem;font-weight:800;color:#1e1b4b;margin:0 0 4px;letter-spacing:-.02em}.rec-page-subtitle{font-size:.875rem;color:#6b7280;margin:0}.rec-add-animal-btn{display:flex;align-items:center;gap:7px;padding:.65rem 1.25rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px #4f46e540;white-space:nowrap}.rec-add-animal-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 18px #4f46e559}.rec-refresh-btn{display:flex;align-items:center;gap:7px;padding:.6rem 1.1rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.9rem;font-weight:600;color:#4f46e5;cursor:pointer;transition:all .2s;white-space:nowrap}.rec-refresh-btn:hover:not(:disabled){background:#f5f3ff;border-color:#c4b5fd}.rec-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.rec-filter-bar{background:#fff;border-radius:16px;padding:1rem 1.25rem;margin-bottom:1.25rem;box-shadow:0 2px 12px #4f46e512;display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.rec-search-wrap{position:relative;flex:1;min-width:220px}.rec-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:1.1rem;color:#9ca3af;pointer-events:none;line-height:1}.rec-search-input{width:100%;padding:.65rem 2.5rem .65rem 2.4rem;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.9rem;background:#f9fafb;color:#111827;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.rec-search-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.rec-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.1rem;color:#9ca3af;cursor:pointer;line-height:1;padding:0}.rec-search-clear:hover{color:#4b5563}.rec-date-filters{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.rec-date-field{display:flex;flex-direction:column;gap:4px}.rec-date-field label{font-size:.72rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.rec-date-input{padding:.6rem .75rem;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.85rem;background:#f9fafb;color:#111827;transition:border-color .2s,box-shadow .2s}.rec-date-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.rec-clear-btn{padding:.6rem 1rem;background:#fef2f2;border:1.5px solid #fecaca;border-radius:10px;font-size:.85rem;font-weight:600;color:#ef4444;cursor:pointer;transition:all .2s;white-space:nowrap}.rec-clear-btn:hover{background:#fee2e2;border-color:#f87171}.rec-card{background:#fff;border-radius:20px;box-shadow:0 4px 24px #4f46e514;overflow:hidden}.rec-card:before{content:"";display:block;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3,#f59e0b);background-size:300% 100%;animation:recGradient 6s linear infinite}@keyframes recGradient{0%{background-position:0% 50%}to{background-position:300% 50%}}.rec-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;color:#6b7280}.rec-spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top-color:#7c3aed;border-radius:50%;animation:recSpin .7s linear infinite}.rec-spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:recSpin .7s linear infinite;vertical-align:middle;margin-right:6px}@keyframes recSpin{to{transform:rotate(360deg)}}.rec-table-wrap{overflow-x:auto}.rec-table{width:100%;border-collapse:collapse;font-size:.9rem}.rec-table thead tr{background:#f9fafb;border-bottom:2px solid #f3f4f6}.rec-table th{padding:.9rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6b7280;white-space:nowrap}.rec-table td{padding:.85rem 1rem;color:#374151;border-bottom:1px solid #f3f4f6;vertical-align:middle}.rec-row{cursor:pointer;transition:background .15s}.rec-row:hover{background:#faf9ff}.rec-row:hover td{color:#1e1b4b}.rec-new-badge{display:inline-block;margin-left:8px;padding:1px 7px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:.65rem;font-weight:700;border-radius:20px;vertical-align:middle;letter-spacing:.4px;text-transform:uppercase}.rec-tag-pill{display:inline-block;padding:3px 10px;background:#ede9fe;color:#5b21b6;font-size:.8rem;font-weight:700;border-radius:20px;font-family:monospace;letter-spacing:.3px}.rec-edit-row-btn{padding:.4rem 1rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.rec-edit-row-btn:hover{opacity:.85;transform:translateY(-1px);box-shadow:0 4px 12px #4f46e540}.rec-row-actions{display:flex;gap:5px;align-items:center;flex-wrap:nowrap}.rec-action-btn{padding:.35rem .75rem;border:none;border-radius:7px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.rec-action-edit{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.rec-action-edit:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 3px 10px #4f46e54d}.rec-action-discharge{background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff}.rec-action-discharge:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 3px 10px #0891b24d}.rec-action-pdf{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.rec-action-pdf:hover:not(:disabled){opacity:.88;transform:translateY(-1px);box-shadow:0 3px 10px #f59e0b4d}.rec-action-pdf:disabled{opacity:.6;cursor:not-allowed}.rec-pdf-cell-wrap{position:relative}.rec-pdf-cell-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 30px #0000001f;z-index:500;min-width:145px;overflow:hidden;animation:recSlideIn .15s ease}.rec-pdf-cell-dropdown button{display:block;width:100%;padding:.65rem 1rem;background:none;border:none;text-align:left;font-size:.82rem;font-weight:500;color:#374151;cursor:pointer;transition:background .15s}.rec-pdf-cell-dropdown button:hover{background:#f5f3ff;color:#4f46e5}.rec-modal-lg{max-width:760px;max-height:88vh}.rec-empty td{padding:4rem 1rem}.rec-empty-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:#9ca3af;font-size:1.5rem}.rec-empty-content p{font-size:.95rem;margin:0;color:#6b7280}.rec-pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-top:1px solid #f3f4f6;flex-wrap:wrap;gap:.75rem}.rec-pagination-info{font-size:.85rem;color:#6b7280}.rec-pagination-btns{display:flex;gap:4px}.rec-page-btn{width:34px;height:34px;border:1.5px solid #e5e7eb;border-radius:8px;background:#fff;font-size:.85rem;font-weight:600;color:#374151;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.rec-page-btn:hover:not(:disabled){border-color:#7c3aed;color:#7c3aed;background:#f5f3ff}.rec-page-btn.active{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border-color:transparent;box-shadow:0 3px 10px #4f46e54d}.rec-page-btn:disabled{opacity:.4;cursor:not-allowed}.rec-overlay{position:fixed;inset:0;background:#0f0c288c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;display:flex;align-items:center;justify-content:center;padding:1rem;animation:recFadeIn .2s ease}@keyframes recFadeIn{0%{opacity:0}to{opacity:1}}.rec-modal{background:#fff;border-radius:24px;width:100%;max-width:680px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 80px #0f0c284d;animation:recSlideUp .25s ease}@keyframes recSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.rec-modal:before{content:"";display:block;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3,#f59e0b);background-size:300% 100%;animation:recGradient 5s linear infinite;flex-shrink:0}.rec-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #f3f4f6;flex-shrink:0;background:#fafafa;gap:.75rem}.rec-modal-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.rec-modal-tag{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:.78rem;font-weight:700;border-radius:20px;font-family:monospace;white-space:nowrap}.rec-modal-animal{font-size:.95rem;font-weight:600;color:#1e1b4b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rec-modal-close{width:32px;height:32px;border-radius:8px;background:#f3f4f6;border:none;font-size:1.1rem;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.rec-modal-close:hover{background:#fee2e2;color:#ef4444}.rec-modal-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;scrollbar-width:thin;scrollbar-color:#e5e7eb transparent}.rec-modal-body::-webkit-scrollbar{width:4px}.rec-modal-body::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:4px}.rec-detail-section{border:1px solid #f3f4f6;border-radius:16px;overflow:hidden}.rec-section-bar{display:flex;align-items:center;gap:10px;padding:.75rem 1rem;font-size:.75rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#fff}.edit-bar{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.discharge-bar{background:linear-gradient(135deg,#0891b2,#0e7490)}.rec-section-dot{width:7px;height:7px;background:#ffffffb3;border-radius:50%;flex-shrink:0}.rec-section-action-btn{margin-left:auto;padding:3px 12px;background:#fff3;border:1px solid rgba(255,255,255,.35);border-radius:6px;color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .2s}.rec-section-action-btn:hover{background:#ffffff4d}.rec-discharge-count{margin-left:auto;background:#ffffff40;border-radius:20px;padding:1px 8px;font-size:.7rem;font-weight:700}.rec-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:.25rem 0}.rec-detail-item{display:flex;flex-direction:column;gap:3px;padding:.65rem 1rem;border-bottom:1px solid #f9fafb}.rec-detail-item.full{grid-column:1 / -1}.rec-detail-label{font-size:.7rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.rec-detail-item span:not(.rec-detail-label){font-size:.9rem;color:#1f2937;font-weight:500}.rec-animal-photo{max-width:160px;border-radius:10px;margin-top:4px;object-fit:cover;border:2px solid #e5e7eb}.rec-edit-form{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.rec-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.rec-form-field{display:flex;flex-direction:column;gap:5px}.rec-form-field.full{grid-column:1 / -1}.rec-form-field label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.4px}.rec-form-field .req{color:#ef4444}.rec-form-input,.rec-form-textarea,.rec-form-select{padding:.6rem .875rem;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.875rem;background:#f9fafb;color:#111827;transition:border-color .2s,box-shadow .2s;font-family:inherit;width:100%;box-sizing:border-box}.rec-form-input:focus,.rec-form-textarea:focus,.rec-form-select:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.rec-form-textarea{resize:vertical}.rec-radio-group{display:flex;gap:1rem;padding:.5rem 0}.rec-radio{display:flex;align-items:center;gap:6px;font-size:.875rem;color:#374151;cursor:pointer;font-weight:500}.rec-radio input[type=radio]{accent-color:#7c3aed;width:16px;height:16px}.rec-edit-actions{display:flex;gap:.75rem;padding-top:.5rem}.rec-save-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:.65rem 1.5rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s}.rec-save-btn:hover:not(:disabled){opacity:.9;box-shadow:0 4px 14px #4f46e559;transform:translateY(-1px)}.rec-save-btn:disabled{opacity:.6;cursor:not-allowed}.rec-cancel-btn{padding:.65rem 1.25rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.9rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s}.rec-cancel-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:#374151}.rec-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.rec-discharge-list{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.75rem}.rec-discharge-entry{background:#f9fafb;border:1px solid #f3f4f6;border-radius:12px;padding:.875rem 1rem}.rec-discharge-header{display:flex;align-items:center;gap:10px;margin-bottom:.5rem;flex-wrap:wrap}.rec-status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.status-reopen{background:#ede9fe;color:#5b21b6}.status-recover{background:#dcfce7;color:#166534}.status-release{background:#dbeafe;color:#1d4ed8}.status-death{background:#fee2e2;color:#991b1b}.rec-discharge-datetime{font-size:.78rem;color:#9ca3af;margin-left:auto}.rec-discharge-desc{font-size:.875rem;color:#374151;margin:0 0 .5rem;line-height:1.5}.rec-discharge-photo{max-width:140px;border-radius:8px;border:1px solid #e5e7eb;margin-top:4px;display:block}.rec-discharge-by{display:block;font-size:.72rem;color:#9ca3af;margin-top:4px}.rec-add-discharge-btn{width:calc(100% - 2rem);margin:.75rem 1rem;padding:.75rem;background:linear-gradient(135deg,#0891b214,#0e749014);border:1.5px dashed #0891b2;border-radius:10px;color:#0891b2;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;text-align:center}.rec-add-discharge-btn:hover{background:linear-gradient(135deg,#0891b224,#0e749024);border-style:solid}.rec-discharge-form{padding:1rem;border-top:1px solid #f3f4f6;display:flex;flex-direction:column;gap:.5rem}.rec-discharge-form-header{font-size:.8rem;font-weight:700;color:#0891b2;text-transform:uppercase;letter-spacing:.6px;padding-bottom:.5rem;border-bottom:1px solid #e0f2fe;margin-bottom:.25rem}.rec-discharge-form-actions{display:flex;gap:.75rem;padding-top:.25rem}.rec-photo-upload-area{position:relative;border:1.5px dashed #d1d5db;border-radius:10px;overflow:hidden;min-height:56px;background:#f9fafb;cursor:pointer;transition:border-color .2s}.rec-photo-upload-area:hover{border-color:#7c3aed}.rec-photo-input{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:2;width:100%;height:100%}.rec-photo-hint{display:flex;align-items:center;justify-content:center;height:56px;font-size:.85rem;color:#9ca3af;pointer-events:none}.rec-photo-preview{position:relative;display:inline-block}.rec-photo-preview img{max-width:120px;max-height:90px;border-radius:8px;object-fit:cover;margin:6px;display:block}.rec-photo-remove{position:absolute;top:2px;right:2px;width:22px;height:22px;background:#0009;color:#fff;border:none;border-radius:50%;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;line-height:1}.rec-modal-footer{padding:.875rem 1.5rem;border-top:1px solid #f3f4f6;background:#fafafa;flex-shrink:0}.rec-pdf-wrap{position:relative;display:inline-block}.rec-pdf-btn{display:flex;align-items:center;gap:7px;padding:.65rem 1.25rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s}.rec-pdf-btn:hover:not(:disabled){opacity:.9;box-shadow:0 4px 14px #f59e0b66;transform:translateY(-1px)}.rec-pdf-btn:disabled{opacity:.6;cursor:not-allowed}.rec-pdf-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 30px #0000001f;overflow:hidden;z-index:100;min-width:160px;animation:recSlideIn .15s ease}.rec-pdf-dropdown button{display:block;width:100%;padding:.7rem 1rem;background:none;border:none;text-align:left;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:background .15s}.rec-pdf-dropdown button:hover{background:#f5f3ff;color:#4f46e5}@media(max-width:768px){.rec-page{padding:1rem}.rec-page-title{font-size:1.3rem}.rec-filter-bar{flex-direction:column}.rec-search-wrap{min-width:auto}.rec-date-filters{width:100%}.rec-date-field{flex:1}.rec-table thead{display:none}.rec-table,.rec-table tbody,.rec-table tr,.rec-table td{display:block;width:100%}.rec-table tr{padding:.875rem 1rem;border-bottom:1px solid #f3f4f6}.rec-table td{padding:3px 0;border:none;display:flex;align-items:center;gap:8px;font-size:.875rem}.rec-table td:before{content:attr(data-label);font-size:.7rem;font-weight:700;color:#9ca3af;text-transform:uppercase;width:80px;flex-shrink:0}.rec-modal{border-radius:18px}.rec-modal-body{padding:1rem}.rec-modal-header{padding:.875rem 1rem}.rec-modal-footer{padding:.75rem 1rem}.rec-details-grid{grid-template-columns:1fr}.rec-detail-item.full{grid-column:1}.rec-form-row{grid-template-columns:1fr}.rec-form-field.full{grid-column:1}.rec-pagination{flex-direction:column;align-items:flex-start}}@media(max-width:480px){.rec-page-header{flex-direction:column}.rec-refresh-btn{width:100%;justify-content:center}.rec-modal{max-height:95vh;border-radius:14px}.rec-edit-actions,.rec-discharge-form-actions{flex-direction:column}.rec-save-btn,.rec-cancel-btn{width:100%;justify-content:center}}.rec-edit-row-btn:focus-visible,.rec-save-btn:focus-visible,.rec-cancel-btn:focus-visible,.rec-modal-close:focus-visible,.rec-pdf-btn:focus-visible,.rec-refresh-btn:focus-visible{outline:2px solid #7c3aed;outline-offset:2px}@media(prefers-reduced-motion:reduce){.rec-card:before,.rec-modal:before{animation:none!important}.rec-modal,.rec-message{animation:none!important}.rec-spinner,.rec-spinner-sm{animation:none!important;border-top-color:#7c3aed}}@media print{.rec-page-header,.rec-filter-bar,.rec-overlay{display:none}}.user-page{display:flex;min-height:100vh;background:#f5f4ff}.user-content{flex:1;margin-left:280px;min-height:100vh;padding:0;transition:margin-left .3s ease}.page-container{height:100%;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100%;background:linear-gradient(145deg,#4f46e5,#7c3aed,#c026d3)}.user-loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.3);border-top:3px solid #ffffff;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.user-loading-text{color:#fff;font-size:1rem;font-weight:500;margin:0}@media(max-width:768px){.user-content{margin-left:0}}.sidebar{position:fixed;left:0;top:0;height:100vh;width:280px;background:linear-gradient(145deg,#4f46e5,#7c3aed,#c026d3);color:#fff;display:flex;flex-direction:column;z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:4px 0 40px #4f46e559}.sidebar:before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.12) 0%,transparent 70%);border-radius:50%;animation:sidebarPulse 8s ease-in-out infinite;pointer-events:none}.sidebar:after{content:"";position:absolute;bottom:-80px;left:-80px;width:240px;height:240px;background:radial-gradient(circle,rgba(251,191,36,.15) 0%,transparent 70%);border-radius:50%;animation:sidebarPulse 11s ease-in-out infinite reverse;pointer-events:none}@keyframes sidebarPulse{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.08) translateY(-16px)}}.mobile-menu-toggle{display:none;position:fixed;top:16px;left:16px;z-index:1001;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 16px #4f46e573;transition:all .2s ease;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.mobile-menu-toggle.hidden{display:none}.mobile-menu-toggle:active{transform:scale(.95)}.toggle-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;transition:opacity .2s ease;pointer-events:none}.sidebar-overlay.active{opacity:1;pointer-events:auto}.sidebar-header{padding:1.75rem 1.25rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.12);position:relative;z-index:2}.admin-info-container{display:flex;align-items:center;gap:12px}.admin-avatar{width:48px;height:48px;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.35);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #00000026}.admin-logo-avatar{background:#fff;padding:4px;overflow:hidden}.admin-logo-avatar img{width:100%;height:100%;object-fit:contain;border-radius:10px}.admin-details{display:flex;flex-direction:column;overflow:hidden;flex:1;min-width:0}.admin-name{font-size:1rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;line-height:1.3;margin-bottom:2px}.admin-panel-label{font-size:.7rem;color:#fff9;text-transform:uppercase;letter-spacing:.8px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10}.sidebar-close:active{background:#ffffff40}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto;overflow-x:hidden;position:relative;z-index:2;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.sidebar-menu{list-style:none;padding:0;margin:0}.sidebar-menu li{margin:2px 8px}.sidebar-item{width:100%;padding:.8rem 1rem;background:transparent;border:none;color:#fffc;text-align:left;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease;border-radius:12px;display:flex;align-items:center;gap:12px;position:relative;-webkit-tap-highlight-color:transparent}.sidebar-item:hover{background:#ffffff1f;color:#fff;transform:translate(3px)}.sidebar-item:active{background:#ffffff2e;transform:scale(.98)}.sidebar-item.active{background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-weight:600;border:1px solid rgba(255,255,255,.25);box-shadow:0 4px 12px #0000001a}.active-dot{position:absolute;right:12px;width:7px;height:7px;background:#fbbf24;border-radius:50%;box-shadow:0 0 8px #fbbf2499}.sidebar-icon{font-size:1.2rem;min-width:24px;color:#ffffffd9;flex-shrink:0}.sidebar-label{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-submenu{list-style:none;padding:0;margin:0}.sidebar-subitem{padding-left:2rem!important;font-size:.9rem!important}.sidebar-arrow{margin-left:auto;font-size:.8rem;color:#fff9}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.12);position:relative;z-index:2}.sidebar-logout{width:100%;padding:.8rem 1rem;background:#ef44442e;color:#fff;border:1.5px solid rgba(252,165,165,.55);border-radius:12px;cursor:pointer;font-size:.95rem;font-weight:700;transition:all .2s ease;display:flex;align-items:center;gap:12px;-webkit-tap-highlight-color:transparent;letter-spacing:.01em}.sidebar-logout:hover{background:#ef444459;border-color:#fca5a5;transform:translateY(-1px);box-shadow:0 4px 14px #ef44444d}.sidebar-logout:active{transform:scale(.98)}.sidebar-logout .sidebar-icon{color:#fca5a5}.logout-hint{margin-left:auto;opacity:.8;font-size:1rem;color:#fca5a5}.sidebar-version{margin-top:8px;text-align:center;font-size:.65rem;color:#ffffff4d;letter-spacing:.5px}@media(max-width:768px){.sidebar{transform:translate(-100%);width:280px;box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:4px 0 30px #4f46e566}.mobile-menu-toggle{display:flex}.sidebar-overlay{display:block}.sidebar-header{padding:1.25rem 3rem 1.25rem 1rem}.admin-avatar{width:44px;height:44px;font-size:1.2rem}.admin-name{font-size:.95rem}.admin-panel-label{font-size:.65rem}.sidebar-item{padding:.7rem 1rem;margin:1px 6px;font-size:.9rem;border-radius:10px}.sidebar-footer{padding:.875rem}.sidebar-logout{padding:.7rem 1rem;font-size:.9rem}.logout-hint{display:none}.active-dot{width:6px;height:6px;right:10px}}@media(max-width:480px){.mobile-menu-toggle{top:12px;left:12px;width:40px;height:40px;border-radius:10px;font-size:1.3rem}.sidebar{width:260px}.sidebar-header{padding:1rem 2.5rem 1rem .875rem}.sidebar-close{top:12px;right:12px;width:28px;height:28px}.admin-avatar{width:40px;height:40px;border-radius:10px}.admin-name{font-size:.9rem}.admin-panel-label{font-size:.6rem}.sidebar-item{padding:.65rem .875rem;gap:10px}.sidebar-footer{padding:.75rem}.sidebar-logout{padding:.65rem .875rem}}@media(min-width:769px)and (max-width:1024px){.sidebar{width:260px}.sidebar-header{padding:1.5rem 1.25rem}.admin-avatar{width:48px;height:48px}.sidebar-item{padding:.8rem 1.25rem}}@media(min-width:1025px){.sidebar{transform:translate(0)}}@media(min-width:1400px){.sidebar{width:300px}.sidebar-header{padding:2rem 1.5rem}.admin-avatar{width:56px;height:56px;font-size:1.5rem;border-radius:16px}.admin-name{font-size:1.05rem}.sidebar-item{padding:.875rem 1.5rem;font-size:1rem}.sidebar-footer{padding:1.25rem}.sidebar-logout{padding:.875rem 1.25rem;font-size:1rem}}@media(max-height:600px)and (orientation:landscape){.sidebar{overflow-y:auto}.sidebar-header{padding:.875rem 2.5rem .875rem .875rem}.admin-avatar{width:36px;height:36px;font-size:1rem;border-radius:8px}.admin-name{font-size:.85rem}.admin-panel-label{font-size:.55rem}.sidebar-nav{padding:.5rem 0}.sidebar-item{padding:.5rem .875rem;margin:1px 6px}.sidebar-footer,.sidebar-logout{padding:.5rem .875rem}}.sidebar-item:focus-visible,.sidebar-logout:focus-visible,.mobile-menu-toggle:focus-visible,.sidebar-close:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:2px}@media(prefers-reduced-motion:reduce){.sidebar,.sidebar-item,.sidebar-logout,.mobile-menu-toggle,.sidebar-overlay,.sidebar-close{transition:none!important;animation:none!important}}@media print{.sidebar,.mobile-menu-toggle,.sidebar-overlay{display:none}}.create-user-container{min-height:100vh;background:#f5f4ff;padding:1.5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.success-toast{position:fixed;top:20px;right:20px;z-index:2000;display:flex;align-items:center;gap:10px;padding:.875rem 1.25rem;background:#ecfdf5;color:#065f46;border-left:4px solid #10b981;border-radius:14px;font-size:.9rem;font-weight:500;box-shadow:0 8px 30px #0000001f;animation:cuSlideIn .25s ease;max-width:360px}@keyframes cuSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;flex-wrap:wrap;gap:1rem}.page-title{font-size:1.6rem;font-weight:800;color:#1e1b4b;margin:0 0 4px;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}.title-icon{font-size:1.4rem}.page-subtitle{font-size:.875rem;color:#6b7280;margin:0}.header-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.refresh-btn{display:flex;align-items:center;gap:7px;padding:.6rem 1.1rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.875rem;font-weight:600;color:#4f46e5;cursor:pointer;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#f5f3ff;border-color:#c4b5fd}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.create-btn{display:flex;align-items:center;gap:7px;padding:.65rem 1.25rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px #4f46e540}.create-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 18px #4f46e559}.btn-icon{font-size:.95rem}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}.stat-card{background:#fff;border-radius:16px;padding:1.1rem 1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 12px #4f46e512;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 4px 20px #4f46e51f}.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-icon.total-users{background:#ede9fe}.stat-icon.admin-users{background:#fef3c7}.stat-icon.staff-users{background:#dbeafe}.stat-content{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:.75rem;color:#9ca3af;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.stat-value{font-size:1.6rem;font-weight:800;color:#1e1b4b;line-height:1}.error-banner{display:flex;align-items:flex-start;gap:12px;padding:1rem 1.25rem;background:#fef2f2;border:1px solid #fecaca;border-radius:14px;margin-bottom:1.25rem}.banner-icon{font-size:1.2rem}.banner-content{flex:1;font-size:.875rem;color:#991b1b}.banner-content strong{display:block;margin-bottom:2px}.banner-content p{margin:0}.banner-btn{padding:.4rem .875rem;background:#fff;border:1px solid #fca5a5;border-radius:8px;font-size:.8rem;font-weight:600;color:#ef4444;cursor:pointer;flex-shrink:0;transition:background .2s}.banner-btn:hover{background:#fee2e2}.users-grid-container{background:#fff;border-radius:20px;box-shadow:0 4px 24px #4f46e514;overflow:hidden}.users-grid-container:before{content:"";display:block;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3,#f59e0b);background-size:300% 100%;animation:cuGradient 6s linear infinite}@keyframes cuGradient{0%{background-position:0% 50%}to{background-position:300% 50%}}.loading-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;color:#6b7280}.loading-spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top-color:#7c3aed;border-radius:50%;animation:cuSpin .7s linear infinite}@keyframes cuSpin{to{transform:rotate(360deg)}}.users-table{width:100%;border-collapse:collapse;font-size:.9rem}.users-table thead tr{background:#f9fafb;border-bottom:2px solid #f3f4f6}.users-table th{padding:.9rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6b7280;white-space:nowrap}.users-table td{padding:.85rem 1rem;color:#374151;border-bottom:1px solid #f3f4f6;vertical-align:middle}.table-row{transition:background .15s}.table-row:hover{background:#faf9ff}.user-cell{display:flex;align-items:center;gap:10px}.user-avatar-small{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.mobile-number{font-family:monospace;font-size:.875rem;color:#4b5563}.role-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.role-admin{background:#fef3c7;color:#92400e}.role-staff{background:#dbeafe;color:#1d4ed8}.action-buttons{display:flex;gap:6px;align-items:center}.action-btn{width:32px;height:32px;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .2s}.action-btn.edit{background:#ede9fe;color:#5b21b6}.action-btn.edit:hover{background:#ddd6fe;transform:scale(1.1)}.action-btn.delete{background:#fee2e2;color:#991b1b}.action-btn.delete:hover{background:#fecaca;transform:scale(1.1)}.users-card-grid{padding:1rem;display:flex;flex-direction:column;gap:.875rem}.user-card{background:#f9fafb;border:1px solid #f3f4f6;border-radius:16px;overflow:hidden}.card-header{display:flex;align-items:center;gap:12px;padding:1rem 1rem .75rem}.user-avatar{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:.95rem;font-weight:700;color:#1e1b4b;margin:0 0 4px}.card-body{padding:0 1rem .75rem;display:flex;flex-direction:column;gap:6px}.info-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.info-label{color:#9ca3af;font-weight:500}.info-value{color:#374151;font-weight:600}.card-actions{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid #f3f4f6}.card-btn{flex:1;padding:.5rem;border:none;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}.card-btn.edit{background:#ede9fe;color:#5b21b6}.card-btn.edit:hover{background:#ddd6fe}.card-btn.delete{background:#fee2e2;color:#991b1b}.card-btn.delete:hover{background:#fecaca}.no-results{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 2rem;color:#9ca3af;text-align:center}.no-results-icon{font-size:3rem}.no-results h3{font-size:1.1rem;font-weight:700;color:#374151;margin:0}.no-results p{font-size:.875rem;margin:0;color:#6b7280}.clear-search-btn{padding:.5rem 1.25rem;background:#f5f3ff;border:1.5px solid #c4b5fd;border-radius:8px;font-size:.875rem;font-weight:600;color:#4f46e5;cursor:pointer;transition:all .2s}.clear-search-btn:hover{background:#ede9fe}.table-footer{padding:.875rem 1.25rem;border-top:1px solid #f3f4f6;background:#fafafa}.records-info{font-size:.85rem;color:#6b7280;display:flex;align-items:center;gap:6px}.info-icon{font-size:.9rem}.modal-overlay{position:fixed;inset:0;background:#0f0c288c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;display:flex;align-items:center;justify-content:center;padding:1rem;animation:cuFadeIn .2s ease}@keyframes cuFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:24px;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:0 25px 80px #0f0c284d;animation:cuSlideUp .25s ease;scrollbar-width:thin;scrollbar-color:#e5e7eb transparent}.modal-content::-webkit-scrollbar{width:4px}.modal-content::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:4px}@keyframes cuSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content:before{content:"";display:block;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3,#f59e0b);background-size:300% 100%;animation:cuGradient 5s linear infinite}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem 1rem;border-bottom:1px solid #f3f4f6;gap:.75rem}.modal-header h2{font-size:1.15rem;font-weight:800;color:#1e1b4b;margin:0;display:flex;align-items:center;gap:8px}.modal-icon{font-size:1.1rem}.modal-close{width:32px;height:32px;border-radius:8px;background:#f3f4f6;border:none;font-size:1.1rem;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.modal-close:hover{background:#fee2e2;color:#ef4444}.create-form{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-section{display:flex;flex-direction:column;gap:.875rem}.form-section h3{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:#6b7280;margin:0;display:flex;align-items:center;gap:7px}.section-icon{font-size:.95rem}.role-display{display:flex;align-items:center;gap:12px;padding:.75rem 1rem;background:#f5f3ff;border:1.5px solid #e0e7ff;border-radius:12px}.role-icon{font-size:1.2rem}.role-details{display:flex;flex-direction:column;gap:1px}.role-label{font-size:.7rem;color:#9ca3af;font-weight:600;text-transform:uppercase}.role-value{font-size:.9rem;font-weight:700;color:#4f46e5}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.4px}.required{color:#ef4444}.form-input{padding:.65rem .875rem;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.875rem;background:#f9fafb;color:#111827;transition:border-color .2s,box-shadow .2s;font-family:inherit;width:100%;box-sizing:border-box}.form-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.form-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input:disabled{opacity:.6;cursor:not-allowed}.password-wrapper{position:relative}.password-wrapper .form-input{padding-right:2.5rem}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:.95rem;cursor:pointer;color:#9ca3af;padding:0;line-height:1;transition:color .2s}.password-toggle:hover{color:#4b5563}.password-requirements{display:flex;flex-direction:column;gap:6px;padding:.75rem;background:#f9fafb;border-radius:10px;border:1px solid #f3f4f6}.requirement{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#9ca3af;transition:color .2s}.requirement.valid{color:#059669}.req-icon{font-size:.85rem}.error-message{display:flex;align-items:center;gap:8px;padding:.6rem .875rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;font-size:.82rem;color:#ef4444;font-weight:500}.error-icon{font-size:.9rem}.form-actions{display:flex;gap:.75rem;padding-top:.25rem}.submit-btn{display:flex;align-items:center;justify-content:center;gap:7px;flex:1;padding:.75rem 1.25rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s}.submit-btn:hover:not(:disabled){opacity:.9;box-shadow:0 4px 14px #4f46e559;transform:translateY(-1px)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.reset-btn{padding:.75rem 1.25rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.875rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s}.reset-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:#374151}.reset-btn:disabled{opacity:.6;cursor:not-allowed}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:cuSpin .7s linear infinite;vertical-align:middle}.user-info-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f5f3ff;border:1.5px solid #e0e7ff;border-radius:14px}.user-avatar-large{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;flex-shrink:0}.user-details{min-width:0}.user-fullname{font-size:.95rem;font-weight:700;color:#1e1b4b;margin:0 0 4px}.user-meta{display:flex;gap:.875rem;align-items:center;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:5px;font-size:.82rem;color:#6b7280}.meta-icon{font-size:.9rem}.role-badge-small{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase}.fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 8px 24px #4f46e573;display:flex;align-items:center;justify-content:center;z-index:100;transition:all .2s;-webkit-tap-highlight-color:transparent}.fab:active{transform:scale(.95)}.fab-icon{line-height:1}.search-container{position:relative;margin-bottom:1.25rem}.search-input{width:100%;padding:.65rem 1rem .65rem 2.5rem;border:1.5px solid #e5e7eb;border-radius:10px;font-size:.9rem;background:#fff;color:#111827;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.search-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}@media(max-width:768px){.create-user-container{padding:1rem}.page-title{font-size:1.3rem}.stats-grid{grid-template-columns:1fr 1fr 1fr;gap:.75rem}.stat-card{padding:.875rem 1rem}.stat-value{font-size:1.3rem}.form-grid{grid-template-columns:1fr}.modal-content{border-radius:18px}.create-form{padding:1rem}.modal-header{padding:1rem 1rem .875rem}}@media(max-width:480px){.stats-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.stat-card{padding:.75rem;flex-direction:column;gap:.5rem;align-items:flex-start}.stat-icon{width:36px;height:36px;font-size:1rem}.page-header{flex-direction:column}.header-actions{width:100%}.create-btn{flex:1;justify-content:center}.form-actions{flex-direction:column}.submit-btn,.reset-btn{width:100%}.modal-content{max-height:95vh;border-radius:14px}}.submit-btn:focus-visible,.reset-btn:focus-visible,.create-btn:focus-visible,.refresh-btn:focus-visible,.modal-close:focus-visible,.action-btn:focus-visible,.card-btn:focus-visible,.fab:focus-visible{outline:2px solid #7c3aed;outline-offset:2px}@media(prefers-reduced-motion:reduce){.users-grid-container:before,.modal-content:before{animation:none!important}.loading-spinner,.spinner,.success-toast,.modal-content,.modal-overlay{animation:none!important}}@media print{.page-header,.modal-overlay,.fab{display:none}}.cp-container{min-height:100vh;background:#f5f4ff;padding:1.5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.cp-header{width:100%;max-width:520px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.cp-header-left{display:flex;align-items:center;gap:12px}.cp-icon-large{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#4f46e5,#7c3aed);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #4f46e54d;flex-shrink:0}.cp-icon-emoji{font-size:1.4rem}.cp-title-wrapper{display:flex;flex-direction:column;gap:2px}.cp-title-large{font-size:1.5rem;font-weight:800;color:#1e1b4b;margin:0;letter-spacing:-.02em}.cp-subtitle-large{font-size:.875rem;color:#6b7280;margin:0}.cp-user-card{display:flex;align-items:center;gap:10px;padding:.6rem 1rem .6rem .6rem;background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;box-shadow:0 2px 8px #0000000a}.cp-user-card.admin{border-color:#c4b5fd}.cp-user-card.staff{border-color:#bfdbfe}.cp-user-avatar-large{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}.cp-user-info{display:flex;flex-direction:column;gap:3px}.cp-user-name-large{font-size:.875rem;font-weight:700;color:#1e1b4b}.cp-user-meta{display:flex;align-items:center;gap:8px}.cp-role-badge-large{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.68rem;font-weight:700;text-transform:uppercase}.cp-role-badge-large.admin{background:#fef3c7;color:#92400e}.cp-role-badge-large.staff{background:#dbeafe;color:#1d4ed8}.cp-user-id{font-size:.68rem;color:#9ca3af;font-family:monospace}.cp-card-large{width:100%;max-width:520px;background:#fff;border-radius:24px;box-shadow:0 4px 24px #4f46e514;overflow:hidden}.cp-card-large:before{content:"";display:block;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3,#f59e0b);background-size:300% 100%;animation:cpGradient 6s linear infinite}@keyframes cpGradient{0%{background-position:0% 50%}to{background-position:300% 50%}}.cp-message-large{display:flex;align-items:center;gap:10px;padding:.875rem 1.5rem;font-size:.875rem;font-weight:500;border-bottom:1px solid #f3f4f6}.cp-message-large.success{background:#ecfdf5;color:#065f46}.cp-message-large.error{background:#fef2f2;color:#991b1b}.cp-message-icon-large{font-size:1rem}.cp-message-text-large{flex:1}.cp-form-large{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.cp-field-large{display:flex;flex-direction:column;gap:6px}.cp-label-large{display:flex;align-items:center;gap:7px;font-size:.78rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.cp-label-icon{font-size:.9rem}.cp-required{color:#ef4444}.cp-input-wrapper-large{position:relative}.cp-input-large{width:100%;padding:.7rem 2.8rem .7rem .875rem;border:1.5px solid #e5e7eb;border-radius:12px;font-size:.9rem;background:#f9fafb;color:#111827;transition:border-color .2s,box-shadow .2s;font-family:inherit;box-sizing:border-box}.cp-input-large:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.cp-input-large.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.cp-input-large:disabled{opacity:.6;cursor:not-allowed}.cp-toggle-large{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1rem;cursor:pointer;color:#9ca3af;padding:0;line-height:1;transition:color .2s}.cp-toggle-large:hover{color:#4b5563}.cp-field-hint{display:flex;align-items:center;gap:6px;font-size:.78rem;color:#9ca3af}.hint-icon{font-size:.85rem}.cp-strength-large{display:flex;align-items:center;gap:10px;margin-top:4px}.cp-strength-bar-large{flex:1;height:5px;background:#f3f4f6;border-radius:20px;overflow:hidden}.cp-strength-fill-large{height:100%;border-radius:20px;transition:width .3s ease,background-color .3s ease}.cp-strength-text-large{font-size:.75rem;font-weight:700;min-width:40px;text-align:right}.cp-match-large{font-size:.78rem;font-weight:600;margin-top:2px}.cp-match-large .valid{color:#059669}.cp-match-large .invalid{color:#ef4444}.cp-requirements-large{background:#f9fafb;border:1px solid #f3f4f6;border-radius:12px;padding:.875rem 1rem}.cp-req-title{font-size:.72rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.6rem}.cp-req-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.cp-req-item{display:flex;align-items:center;gap:7px;font-size:.8rem;color:#9ca3af;transition:color .2s}.cp-req-item.valid{color:#059669}.cp-req-icon{font-size:.8rem}.cp-actions-large{display:flex;gap:.75rem;padding-top:.25rem}.cp-btn-large{display:flex;align-items:center;justify-content:center;gap:7px;padding:.75rem 1.25rem;border-radius:12px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}.cp-btn-primary{flex:1;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;box-shadow:0 4px 14px #4f46e540}.cp-btn-primary:hover:not(:disabled){opacity:.9;box-shadow:0 6px 18px #4f46e559;transform:translateY(-1px)}.cp-btn-primary:disabled{opacity:.6;cursor:not-allowed}.cp-btn-secondary{background:#fff;border:1.5px solid #e5e7eb;color:#6b7280}.cp-btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:#374151}.cp-btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-icon{font-size:.9rem}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:cpSpin .7s linear infinite;vertical-align:middle}@keyframes cpSpin{to{transform:rotate(360deg)}}@media(max-width:600px){.cp-container{padding:1rem}.cp-title-large{font-size:1.25rem}.cp-header{flex-direction:column;align-items:flex-start}.cp-card-large{border-radius:18px}.cp-form-large{padding:1rem}.cp-req-grid{grid-template-columns:1fr}.cp-actions-large{flex-direction:column}.cp-btn-large{width:100%}}.cp-btn-large:focus-visible,.cp-toggle-large:focus-visible,.cp-input-large:focus-visible{outline:2px solid #7c3aed;outline-offset:2px}@media(prefers-reduced-motion:reduce){.cp-card-large:before{animation:none!important}.spinner{animation:none!important}.cp-btn-large{transition:none!important}}.admin-page{display:flex;min-height:100vh;background:#f5f4ff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;position:relative}.admin-content{flex:1;padding:2rem;margin-left:280px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);min-height:100vh;display:flex;flex-direction:column}.page-content{flex:1;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100%;background:linear-gradient(145deg,#4f46e5,#7c3aed,#c026d3)}.loading-spinner{width:52px;height:52px;border:3px solid rgba(255,255,255,.25);border-top:3px solid #fff;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.loading-text{color:#fff;font-size:1.05rem;font-weight:500}@media(max-width:1024px){.admin-content{margin-left:260px;padding:1.5rem}}@media(max-width:768px){.admin-content{margin-left:0;padding:4.5rem 1rem 1rem}}@media(max-width:480px){.admin-content{padding:4rem .75rem .75rem}}@media print{.admin-page{background:#fff}.admin-content{margin-left:0!important;padding:1cm!important}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.login-page{display:flex;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.brand-panel{flex:1;background:linear-gradient(145deg,#4f46e5,#7c3aed 45%,#c026d3);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2.5rem;position:relative;overflow:hidden}.brand-shapes{position:absolute;inset:0;pointer-events:none}.shape{position:absolute;border-radius:50%;opacity:.12}.shape-1{width:420px;height:420px;top:-140px;right:-140px;background:radial-gradient(circle,#fff 0%,transparent 70%);animation:pulse 8s ease-in-out infinite}.shape-2{width:300px;height:300px;bottom:-100px;left:-100px;background:radial-gradient(circle,#fbbf24 0%,transparent 70%);animation:pulse 11s ease-in-out infinite reverse}.shape-3{width:180px;height:180px;top:50%;left:15%;background:radial-gradient(circle,#34d399 0%,transparent 70%);animation:pulse 6s ease-in-out infinite;opacity:.18}@keyframes pulse{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.08) translateY(-20px)}}.brand-content{position:relative;z-index:2;text-align:center;color:#fff;max-width:380px}.brand-logo{font-size:5rem;line-height:1;margin-bottom:1.5rem;filter:drop-shadow(0 8px 24px rgba(0,0,0,.25));animation:bounce 3s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.brand-name{font-size:2rem;font-weight:800;line-height:1.2;margin-bottom:.75rem;letter-spacing:-.02em;text-shadow:0 2px 16px rgba(0,0,0,.2)}.brand-tagline{font-size:1rem;color:#ffffffbf;margin-bottom:2.5rem;letter-spacing:.02em}.brand-features{display:flex;flex-direction:column;gap:1rem;text-align:left}.brand-feature{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:#ffffffe6;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:.75rem 1rem;transition:background .3s}.brand-feature:hover{background:#ffffff2e}.feature-check{font-size:1rem;color:#fbbf24;flex-shrink:0}.brand-footer{position:relative;z-index:2;margin-top:3rem;font-size:.78rem;color:#ffffff73}.form-panel{flex:1;display:flex;align-items:center;justify-content:center;background:#f5f4ff;padding:2rem;min-height:100vh}.login-card{width:100%;max-width:440px;background:#fff;padding:2.75rem 2.5rem 2rem;box-shadow:0 4px 6px -1px #4f46e50f,0 20px 60px -8px #4f46e52e;animation:cardIn .5s cubic-bezier(.34,1.56,.64,1) both;border-top:4px solid transparent;border-image:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3) 1;border-radius:28px;position:relative;overflow:hidden}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#c026d3,#f59e0b);background-size:200% 100%;animation:gradientShift 4s linear infinite}@keyframes gradientShift{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes cardIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-brand{display:none;align-items:center;gap:.75rem;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid #ede9fe}.mobile-logo{font-size:2.2rem}.mobile-name{font-size:1rem;font-weight:700;color:#4f46e5;line-height:1.2}.mobile-tagline{font-size:.75rem;color:#9ca3af;margin-top:2px}.card-header{margin-bottom:2rem}.card-title{font-size:1.75rem;font-weight:800;color:#111827;letter-spacing:-.03em;margin-bottom:.35rem}.card-subtitle{font-size:.9rem;color:#9ca3af}.login-form{display:flex;flex-direction:column;gap:1.25rem}.field{display:flex;flex-direction:column;gap:.4rem}.field-label{font-size:.85rem;font-weight:600;color:#374151;letter-spacing:.01em}.field-input-wrap{position:relative;display:flex;align-items:center}.field-prefix{position:absolute;left:1rem;font-size:.95rem;font-weight:600;color:#6b7280;pointer-events:none;z-index:1}.field-input{width:100%;padding:.875rem 1rem;font-size:.95rem;color:#111827;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:14px;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;-webkit-appearance:none;appearance:none}.field-input.has-prefix{padding-left:3.25rem}.field-input::placeholder{color:#d1d5db}.field-input:focus{border-color:#7c3aed;background:#fff;box-shadow:0 0 0 3px #7c3aed1f}.field-input.field-error{border-color:#f87171;background:#fff5f5}.field-input:disabled{opacity:.6;cursor:not-allowed}.eye-btn{position:absolute;right:.875rem;background:none;border:none;cursor:pointer;font-size:1.1rem;color:#9ca3af;padding:.25rem;line-height:1;transition:color .2s;display:flex;align-items:center}.eye-btn:hover{color:#7c3aed}.options-row{display:flex;align-items:center;justify-content:space-between;margin-top:-.25rem}.remember-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none}.remember-check{width:16px;height:16px;cursor:pointer;accent-color:#7c3aed}.error-box{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;font-size:.875rem;color:#dc2626;animation:shake .4s ease}.error-icon{font-size:1rem;flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.submit-btn{width:100%;padding:.95rem 1rem;font-size:1rem;font-weight:700;letter-spacing:.02em;color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed,#c026d3);background-size:200% 200%;border:none;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.25rem;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s,background-position .4s;box-shadow:0 4px 20px #7c3aed59}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #7c3aed73;background-position:right center}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.65;cursor:not-allowed}.btn-arrow{font-size:1.1rem;transition:transform .25s}.submit-btn:hover:not(:disabled) .btn-arrow{transform:translate(4px)}.submit-btn:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);transform:translate(-100%);transition:transform .6s ease}.submit-btn:hover:after{transform:translate(100%)}.btn-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.card-footer{margin-top:1.75rem;text-align:center;font-size:.75rem;color:#d1d5db}@media(max-width:900px){.brand-panel{display:none}.form-panel{background:linear-gradient(145deg,#4f46e5,#7c3aed,#c026d3);padding:1.5rem;align-items:center}.login-card{max-width:420px;padding:2rem 1.75rem 1.5rem;border-radius:24px}.mobile-brand{display:flex}}@media(max-width:480px){.form-panel{padding:1rem}.login-card{padding:1.75rem 1.25rem 1.25rem;border-radius:20px}.card-title{font-size:1.4rem}}#root{width:100%;min-height:100vh}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
