:root{--color-primary: #dc2626;--color-primary-hover: #b91c1c;--color-primary-light: #fee2e2;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-white: #ffffff;--color-green-100: #dcfce7;--color-green-800: #166534;--color-yellow-100: #fef3c7;--color-yellow-800: #92400e;--color-red-100: #fee2e2;--color-red-800: #991b1b;--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);--radius: .5rem;--radius-lg: .75rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-gray-50);color:var(--color-gray-900);line-height:1.5}#app{min-height:100vh}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}.btn-primary{background-color:var(--color-primary);color:var(--color-white);padding:.5rem 1rem;border-radius:var(--radius);font-weight:500;border:none;cursor:pointer;transition:background-color .2s;font-size:1rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-gray-800);padding:.5rem 1rem;border-radius:var(--radius);font-weight:500;border:none;cursor:pointer;transition:background-color .2s;font-size:1rem}.btn-secondary:hover{background-color:var(--color-gray-300)}.card{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1.5rem;transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-lg)}.badge{display:inline-flex;align-items:center;padding:.125rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-green{background-color:var(--color-green-100);color:var(--color-green-800)}.badge-yellow{background-color:var(--color-yellow-100);color:var(--color-yellow-800)}.badge-red{background-color:var(--color-red-100);color:var(--color-red-800)}.badge-gray{background-color:var(--color-gray-100);color:var(--color-gray-800)}input[type=text],input[type=password],select{width:100%;padding:.875rem 1rem .875rem 3rem;border:1px solid var(--color-gray-300);border-radius:var(--radius);font-size:1rem;transition:border-color .2s,box-shadow .2s}input[type=text]:focus,input[type=password]:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #dc26261a}input:disabled,select:disabled{background-color:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed}label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:.5rem}.grid{display:grid;gap:1rem}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media(min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1280px){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-y-2>*+*{margin-top:.5rem}.space-y-4>*+*{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-900{color:var(--color-gray-900)}.text-white{color:var(--color-white)}.text-primary{color:var(--color-primary)}.bg-white{background-color:var(--color-white)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-black{background-color:#000}.bg-primary{background-color:var(--color-primary)}.bg-primary-light{background-color:var(--color-primary-light)}.bg-red-50{background-color:#fef2f2}.bg-green-50{background-color:#f0fdf4}.border{border-width:1px}.border-gray-200{border-color:var(--color-gray-200)}.border-red-200{border-color:#fecaca}.rounded{border-radius:var(--radius)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:9999px}.overflow-hidden{overflow:hidden}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.cursor-pointer{cursor:pointer}.relative{position:relative}.absolute{position:absolute}.inset-0{inset:0}.top-2{top:.5rem}.right-2{right:.5rem}.top-4{top:1rem}.right-4{right:1rem}.bottom-4{bottom:1rem}.left-0{left:0}.right-0{right:0}.hidden{display:none}.inline-block{display:inline-block}.animate-spin{animation:spin 1s linear infinite}.transition-colors{transition:color .2s,background-color .2s,border-color .2s}.transition-shadow{transition:box-shadow .2s}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.object-cover{object-fit:cover}header{background-color:var(--color-white);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--color-gray-200)}header .container{display:flex;align-items:center;justify-content:space-between;height:4rem}header nav{display:none}@media(min-width:768px){header nav{display:flex;gap:1rem}}header nav a{padding:.5rem .75rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;color:var(--color-gray-700);text-decoration:none;transition:background-color .2s}header nav a:hover{background-color:var(--color-gray-100)}header nav a.active{background-color:var(--color-primary-light);color:var(--color-primary)}@media(min-width:640px){.sm\:block{display:block}.sm\:hidden{display:none}}@media(min-width:768px){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.login-container{min-height:100vh;background-color:#8b1a1a;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.login-card{background-color:#f5e6d3;border-radius:1.5rem;padding:3rem 2.5rem;max-width:500px;width:100%;box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003}.logo-container{display:flex;justify-content:center;margin-bottom:2rem}.logo-placeholder{width:80px;height:80px;background-color:var(--color-primary);border-radius:1rem;display:flex;align-items:center;justify-content:center}.login-header{text-align:center;margin-bottom:2.5rem}.login-title{font-size:2.5rem;font-weight:700;color:var(--color-gray-800);margin-bottom:.5rem;letter-spacing:-.025em}.login-subtitle{font-size:1rem;color:var(--color-gray-600);font-weight:400}.login-form{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1.5rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-label{font-size:.875rem;font-weight:500;color:var(--color-gray-700)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;width:1.25rem;height:1.25rem;color:var(--color-gray-400);pointer-events:none}.input-field{width:100%;padding:.875rem 1rem .875rem 3rem;background-color:#e8e8e8;border:none;border-radius:.75rem;font-size:1rem;color:var(--color-gray-800);transition:background-color .2s,box-shadow .2s}.input-field-password{padding-right:3rem}.input-field::placeholder{color:var(--color-gray-500)}.input-field:focus{outline:none;background-color:#e0e0e0;box-shadow:0 0 0 3px #dc26261a}.input-field:disabled{opacity:.6;cursor:not-allowed}.password-toggle{position:absolute;right:1rem;background:none;border:none;cursor:pointer;color:var(--color-gray-400);padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s;z-index:1}.password-toggle:hover{color:var(--color-gray-600)}.login-button{width:100%;padding:1rem;background-color:#d1d1d1;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;color:var(--color-gray-800);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:background-color .2s,transform .1s;margin-top:.5rem}.login-button-active{background-color:var(--color-primary)!important;color:var(--color-white)!important}.login-button:hover:not(:disabled){background-color:var(--color-primary);color:var(--color-white);transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-button-icon{width:1.25rem;height:1.25rem}.status-indicator-wrapper{display:flex;justify-content:center;width:100%;margin-bottom:1rem}.status-indicator{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#c8e6c9;border-radius:1rem;font-size:.875rem;color:var(--color-gray-800);width:fit-content}.status-icon{width:1rem;height:1rem;color:var(--color-green-800)}.login-error{background-color:#ffebee;border:1px solid #ffcdd2;color:#c62828;padding:.875rem 1rem;border-radius:.75rem;font-size:.875rem;margin-bottom:1.5rem;text-align:center}.login-copyright{text-align:center;font-size:.75rem;color:var(--color-gray-500);margin-top:1rem}@media(max-width:640px){.login-card{padding:2rem 1.5rem}.login-title{font-size:2rem}.login-subtitle{font-size:.875rem}}.app-layout{min-height:100vh;background-color:#f5f7fa;display:flex;flex-direction:column}.app-header{background-color:var(--color-white);border-bottom:1px solid var(--color-gray-200);box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:70px}.header-left{display:flex;align-items:center}.header-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit}.logo-icon{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;width:40px;height:40px;background-color:var(--color-primary);padding:4px;border-radius:.5rem}.logo-square{background-color:var(--color-white);border-radius:2px}.header-title{display:flex;flex-direction:column}.header-title-main{font-size:1.25rem;font-weight:700;color:var(--color-gray-900);line-height:1.2}.header-title-sub{font-size:.75rem;color:#10b981;font-weight:500}@media(max-width:768px){.header-title-sub{display:none}}.header-nav{display:flex;gap:.5rem;margin-left:2rem}.nav-item{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;color:var(--color-gray-700);text-decoration:none;transition:all .2s;background-color:transparent}.nav-item:hover{background-color:var(--color-gray-100);color:var(--color-gray-900)}.nav-item-active{background-color:#e3f2fd;color:#1976d2}.nav-icon{width:1.25rem;height:1.25rem}.header-right{display:flex;align-items:center;gap:1.5rem}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#f0fdf4;border-radius:1rem;font-size:.875rem;color:var(--color-gray-700)}.status-wifi-icon{width:1.25rem;height:1.25rem;display:none}.status-online-icon{color:#10b981}.status-offline-icon{color:#ef4444}.status-text{display:inline}.status-dot{width:8px;height:8px;border-radius:50%}.status-online{background-color:#10b981}.status-offline{background-color:#ef4444}@media(max-width:768px){.status-badge{padding:.5rem;background-color:transparent}.status-wifi-icon{display:block}.status-text{display:none}}.user-menu-desktop{display:flex;align-items:center;gap:1rem}.user-menu-mobile{display:none;position:relative}.user-info{text-align:right;display:none}.user-name{font-size:.875rem;font-weight:500;color:var(--color-gray-900);line-height:1.2}.user-role{font-size:.75rem;color:var(--color-gray-500)}.menu-dots-button{background:none;border:none;color:var(--color-gray-600);cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.menu-dots-button:hover{background-color:var(--color-gray-100);color:var(--color-gray-900)}.menu-overlay{position:fixed;inset:0;background-color:#0000001a;z-index:998}.menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background-color:var(--color-white);border-radius:.75rem;box-shadow:0 10px 25px #00000026;min-width:200px;z-index:999;overflow:hidden}.menu-user-info{padding:1rem;border-bottom:1px solid var(--color-gray-200)}.menu-user-name{font-size:.875rem;font-weight:500;color:var(--color-gray-900);margin-bottom:.25rem}.menu-user-role{font-size:.75rem;color:var(--color-gray-500)}.menu-divider{height:1px;background-color:var(--color-gray-200)}.menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:none;border:none;text-align:left;color:var(--color-gray-700);font-size:.875rem;cursor:pointer;transition:background-color .2s}.menu-item:hover{background-color:var(--color-gray-50)}.menu-item-icon{width:1.25rem;height:1.25rem;color:var(--color-gray-500)}.app-main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:2rem 1.5rem}.user-geography-info{display:flex;align-items:center;gap:.5rem;margin-right:1rem;padding-right:1rem;border-right:1px solid var(--color-gray-200)}.geography-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background-color:var(--color-gray-100);border-radius:1rem;font-size:.75rem;color:var(--color-gray-700);white-space:nowrap}.geography-icon{width:.875rem;height:.875rem;flex-shrink:0}@media(min-width:768px){.user-info{display:block}.user-menu-mobile{display:none!important}}@media(max-width:1024px){.user-geography-info{display:none}}@media(max-width:767px){.user-menu-desktop{display:none}.user-menu-mobile{display:block}}.scan-module{width:100%}.module-header{margin-bottom:2rem}.module-header-content{display:flex;justify-content:space-between;align-items:flex-start}.module-title{font-size:2rem;font-weight:700;color:var(--color-gray-900);margin-bottom:.5rem}.module-subtitle{font-size:1rem;color:var(--color-gray-600)}.scanner-section{margin-bottom:2rem}.scan-content{display:flex;flex-direction:column;gap:2rem}.scan-action{display:flex;justify-content:center;padding:3rem 0}.scan-button{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background-color:var(--color-primary);color:var(--color-white);border:none;border-radius:.75rem;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #dc26264d}.scan-button:hover{background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 6px 12px -1px #dc262666}.scan-button:active{transform:translateY(0)}.scan-button-icon{width:1.5rem;height:1.5rem}.scan-assets-section{width:100%;max-width:1400px;margin:0 auto}.scan-assets-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-gray-200)}.scan-assets-title{font-size:1.5rem;font-weight:600;color:var(--color-gray-900);margin:0}.scan-assets-count{font-size:.875rem;color:var(--color-gray-600);background-color:var(--color-gray-100);padding:.25rem .75rem;border-radius:1rem}.scan-assets-loading,.scan-assets-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--color-gray-500)}.scan-assets-loading p,.scan-assets-empty p{margin-top:1rem;font-size:.9375rem}.scan-assets-empty-icon{width:4rem;height:4rem;color:var(--color-gray-400)}.scan-assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;padding:1rem 0}@media(max-width:768px){.scan-assets-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}}.recent-scans{width:100%;max-width:800px;margin:0 auto}.recent-scans-title{font-size:1.25rem;font-weight:600;color:var(--color-gray-900);margin-bottom:1rem}.recent-scans-list{display:flex;flex-direction:column;gap:.75rem}.recent-scan-item{width:100%;background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:.75rem;padding:1rem 1.25rem;text-align:left;cursor:pointer;transition:all .2s}.recent-scan-item:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #dc26261a;transform:translateY(-1px)}.recent-scan-content{display:flex;align-items:center;justify-content:space-between}.recent-scan-info{flex:1}.recent-scan-name{font-size:1rem;font-weight:500;color:var(--color-gray-900);margin-bottom:.25rem}.recent-scan-tag{font-size:.875rem;color:var(--color-gray-600)}.recent-scan-arrow{width:1.25rem;height:1.25rem;color:var(--color-gray-400)}.error-alert{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background-color:#fef2f2;border:1px solid #FECACA;border-radius:.75rem;color:#991b1b;margin-bottom:1.5rem}.error-icon{width:1.25rem;height:1.25rem;flex-shrink:0}.asset-detail-section{width:100%}.asset-detail-actions{display:flex;justify-content:center;margin-top:1.5rem;gap:1rem}@media(max-width:768px){.header-content{padding:0 1rem;height:60px}.header-nav{margin-left:1rem;gap:.25rem}.nav-item{padding:.5rem .75rem;font-size:.8125rem}.nav-item span{display:none}.module-title{font-size:1.5rem}.module-subtitle{font-size:.875rem}.scan-button{padding:.875rem 1.5rem;font-size:1rem}}.scanner-container{position:relative;background-color:#000;border-radius:.75rem;overflow:hidden;width:100%;aspect-ratio:4 / 3;max-height:600px;display:flex;align-items:center;justify-content:center;margin:0 auto}.scanner-view{width:100%;height:100%;position:relative;margin:0;padding:0}@media(max-width:768px){.scanner-container{aspect-ratio:3 / 4;max-height:70vh}}#qr-reader{width:100%!important;height:100%!important;position:relative!important;margin:0!important;padding:0!important}#qr-reader__dashboard{display:none!important}#qr-reader__camera{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important;margin:0!important;padding:0!important}#qr-reader__scan_region{width:100%!important;height:100%!important;position:absolute!important;top:0!important;left:0!important;margin:0!important;padding:0!important}#qr-reader__camera_selection,#qr-reader__file_scan_button,#qr-reader__status_span{display:none!important}.scanner-overlay{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center;z-index:5}.scanner-guide{position:relative;width:16rem;height:16rem;max-width:70%;max-height:70%;aspect-ratio:1 / 1}.scanner-corner{position:absolute;width:2.5rem;height:2.5rem}.scanner-corner-tl{top:0;left:0;border-top:4px solid var(--color-primary);border-left:4px solid var(--color-primary);border-top-left-radius:.75rem}.scanner-corner-tr{top:0;right:0;border-top:4px solid var(--color-primary);border-right:4px solid var(--color-primary);border-top-right-radius:.75rem}.scanner-corner-bl{bottom:0;left:0;border-bottom:4px solid var(--color-primary);border-left:4px solid var(--color-primary);border-bottom-left-radius:.75rem}.scanner-corner-br{bottom:0;right:0;border-bottom:4px solid var(--color-primary);border-right:4px solid var(--color-primary);border-bottom-right-radius:.75rem}.camera-switch-button{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background-color:#000000b3;border:none;color:var(--color-white);width:3.5rem;height:3.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000004d}.camera-switch-button:hover:not(:disabled){background-color:#000c;transform:scale(1.1)}.camera-switch-button:active:not(:disabled){transform:scale(.95)}.camera-switch-button:disabled{opacity:.5;cursor:not-allowed}.camera-switch-icon{width:1.5rem;height:1.5rem}.scanner-close-button{position:absolute;top:1rem;right:1rem;background-color:#0009;border:none;color:var(--color-white);width:2.5rem;height:2.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.scanner-close-button:hover{background-color:#000c;transform:scale(1.1)}.scanner-close-icon{width:1.5rem;height:1.5rem}.scanner-status{position:absolute;bottom:5rem;left:0;right:0;text-align:center;pointer-events:none;z-index:10}.scanner-status-text{display:inline-block;background-color:#0009;color:var(--color-white);padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.scanner-camera-indicator{position:absolute;top:1rem;left:1rem;z-index:10;pointer-events:none}.scanner-camera-badge{display:inline-flex;align-items:center;gap:.5rem;background-color:#000000b3;color:var(--color-white);padding:.5rem .875rem;border-radius:1.5rem;font-size:.875rem;font-weight:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000004d}.scanner-camera-badge-icon{width:1.125rem;height:1.125rem;flex-shrink:0}.scanner-camera-text{white-space:nowrap}.scanner-error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background-color:#000;color:var(--color-white);min-height:400px;border-radius:.75rem}.scanner-error-icon{width:4rem;height:4rem;margin:0 auto 1rem;color:var(--color-primary)}.scanner-error-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.scanner-error-text{color:var(--color-gray-400);margin-bottom:1rem;text-align:center}.scanner-error-message{color:var(--color-primary);margin-bottom:1rem;text-align:center}.sidebar-overlay{position:fixed;inset:0;background-color:#00000080;z-index:998;animation:fadeIn .2s ease-in-out}.access-sidebar{position:fixed;top:0;right:0;width:100%;max-width:400px;height:100vh;background-color:var(--color-white);box-shadow:-2px 0 8px #0000001a;z-index:999;display:flex;flex-direction:column;animation:slideInRight .3s ease-out;overflow:hidden}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-gray-200);background-color:var(--color-gray-50)}.sidebar-title{font-size:1.25rem;font-weight:600;color:var(--color-gray-900);margin:0}.sidebar-close-button{background:none;border:none;color:var(--color-gray-600);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:all .2s}.sidebar-close-button:hover{background-color:var(--color-gray-200);color:var(--color-gray-900)}.sidebar-close-button svg{width:1.25rem;height:1.25rem}.sidebar-content{flex:1;overflow-y:auto;padding:1rem}.sidebar-loading,.sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--color-gray-500)}.sidebar-loading p,.sidebar-empty p{margin-top:1rem;font-size:.875rem}.loading-spinner{width:2rem;height:2rem;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-empty-icon{width:3rem;height:3rem;color:var(--color-gray-400)}.sidebar-tree{display:flex;flex-direction:column;gap:.25rem}.sidebar-tree-item{display:flex;flex-direction:column}.sidebar-tree-item-nested{margin-left:1.5rem;border-left:2px solid var(--color-gray-200);padding-left:.75rem}.sidebar-tree-item-nested-2{margin-left:1.5rem;border-left:2px solid var(--color-gray-100);padding-left:.75rem}.sidebar-tree-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;border-radius:var(--radius);transition:all .2s;color:var(--color-gray-700);font-size:.9375rem;width:100%}.sidebar-tree-header:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-gray-900)}.sidebar-tree-header:disabled{cursor:default;opacity:.6}.sidebar-tree-header-leaf{cursor:default}.sidebar-tree-header-leaf:hover{background-color:transparent}.sidebar-tree-icon{width:1rem;height:1rem;flex-shrink:0;transition:transform .2s;color:var(--color-gray-500)}.sidebar-tree-icon.expanded{transform:rotate(90deg)}.sidebar-tree-icon-placeholder{width:1rem;height:1rem;flex-shrink:0;color:var(--color-gray-400)}.sidebar-tree-type{font-size:.75rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.025em;margin-right:.375rem}.sidebar-tree-label{flex:1;font-weight:500;color:var(--color-gray-900);display:flex;align-items:center}.sidebar-tree-count{font-size:.75rem;color:var(--color-gray-500);background-color:var(--color-gray-200);padding:.125rem .5rem;border-radius:.75rem;font-weight:500}.sidebar-tree-children{display:flex;flex-direction:column;margin-top:.25rem;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-.5rem)}to{opacity:1;transform:translateY(0)}}.nav-item-button{background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit}.nav-item-button:hover{background-color:var(--color-gray-100)}.sidebar-assets-section{border-top:1px solid var(--color-gray-200);background-color:var(--color-gray-50);max-height:50vh;display:flex;flex-direction:column}.sidebar-assets-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-gray-200);background-color:var(--color-white)}.sidebar-assets-title{font-size:1rem;font-weight:600;color:var(--color-gray-900);margin:0}.sidebar-assets-close{background:none;border:none;color:var(--color-gray-600);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:all .2s}.sidebar-assets-close:hover{background-color:var(--color-gray-200);color:var(--color-gray-900)}.sidebar-assets-close svg{width:1rem;height:1rem}.sidebar-assets-content{flex:1;overflow-y:auto;padding:1rem}.sidebar-assets-loading,.sidebar-assets-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;color:var(--color-gray-500)}.sidebar-assets-loading p,.sidebar-assets-empty p{margin-top:.75rem;font-size:.875rem}.sidebar-assets-empty-icon{width:2.5rem;height:2.5rem;color:var(--color-gray-400)}.sidebar-assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.sidebar-assets-grid .card{margin:0;min-height:auto}.asset-card{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:0;transition:box-shadow .2s;overflow:hidden}.asset-card:hover{box-shadow:var(--shadow-lg)}.asset-card-content{display:flex;flex-direction:column}.asset-card-thumbnail{position:relative;width:100%;background-color:var(--color-gray-200);border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow:hidden;height:10rem;margin-bottom:.75rem}.asset-card-image{width:100%;height:100%;object-fit:cover}.asset-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-gray-400)}.asset-card-placeholder-icon{width:3rem;height:3rem}.asset-card-badge{position:absolute;top:.5rem;right:.5rem}.asset-card-info{flex:1;padding:0 .75rem .75rem}.asset-card-title{font-size:.9375rem;font-weight:600;color:var(--color-gray-900);margin:0 0 .5rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.asset-card-tag{font-size:.8125rem;color:var(--color-gray-600);margin:0 0 .375rem}.asset-card-details{font-size:.75rem;color:var(--color-gray-500);margin:0}.sidebar-tree-header-selected{background-color:var(--color-primary-light)!important;color:var(--color-primary)!important}.sidebar-tree-header-selected .sidebar-tree-label{color:var(--color-primary);font-weight:600}.sidebar-asset-detail-overlay{position:fixed;inset:0;background-color:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-in-out}.sidebar-asset-detail{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.sidebar-asset-detail-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-gray-200)}.sidebar-asset-detail-title{font-size:1.125rem;font-weight:600;color:var(--color-gray-900);margin:0}.sidebar-asset-detail-close{background:none;border:none;color:var(--color-gray-600);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:all .2s}.sidebar-asset-detail-close:hover{background-color:var(--color-gray-200);color:var(--color-gray-900)}.sidebar-asset-detail-close svg{width:1.25rem;height:1.25rem}.sidebar-asset-detail-content{flex:1;overflow-y:auto;padding:1.5rem}@media(max-width:640px){.access-sidebar{max-width:100%;width:100%}.sidebar-assets-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.sidebar-asset-detail{max-width:100%;max-height:100vh;border-radius:0}}.back-button-compact{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.3125rem .625rem;font-size:.75rem;line-height:1;font-weight:600;color:var(--color-white);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border:none;border-radius:9999px;box-shadow:0 2px 8px #dc262633;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;margin-bottom:.625rem}.back-button-compact:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,#991b1b 100%);box-shadow:0 3px 10px #dc26264d;transform:translateY(-1px)}.back-button-compact:active{transform:translateY(0);box-shadow:0 2px 6px #dc262633}.scan-another-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.625rem 1rem;font-size:.875rem;font-weight:600;color:var(--color-white);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border:none;border-radius:var(--radius);box-shadow:0 2px 8px #dc262633;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;margin-top:.625rem}.scan-another-button:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,#991b1b 100%);box-shadow:0 3px 12px #dc26264d;transform:translateY(-1px)}.scan-another-button:active{transform:translateY(0);box-shadow:0 2px 6px #dc262633}.scan-another-icon{width:1rem;height:1rem;min-width:1rem;min-height:1rem;max-width:1rem;max-height:1rem;stroke-width:2;flex-shrink:0}.pagination-controls{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--color-gray-200)}.pagination-info{font-size:.875rem;color:var(--color-gray-600);text-align:center}.pagination-buttons{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.pagination-button{min-width:2.5rem;height:2.5rem;padding:0 .75rem;font-size:.875rem;font-weight:500;color:var(--color-gray-700);background-color:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.pagination-button:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400);color:var(--color-gray-900)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-button-active{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);font-weight:600}.pagination-button-active:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.pagination-button-nav{padding:0 .5rem}.pagination-icon{width:1rem;height:1rem}.pagination-ellipsis{padding:0 .5rem;color:var(--color-gray-500);font-size:.875rem;-webkit-user-select:none;user-select:none}.pagination-load-more{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;color:var(--color-primary);background-color:var(--color-white);border:2px solid var(--color-primary);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;margin-top:.5rem}.pagination-load-more:hover{background-color:var(--color-primary);color:var(--color-white);transform:translateY(-1px);box-shadow:0 4px 8px #dc262633}.pagination-load-more:active{transform:translateY(0)}.pagination-load-more-icon{width:1rem;height:1rem;transition:transform .2s ease}.pagination-load-more:hover .pagination-load-more-icon{transform:translateY(2px)}@media(max-width:768px){.pagination-controls{gap:.75rem;margin-top:1.5rem;padding-top:1.5rem}.pagination-button{min-width:2.25rem;height:2.25rem;padding:0 .5rem;font-size:.8125rem}.pagination-info{font-size:.8125rem}.pagination-load-more{padding:.5625rem 1.25rem;font-size:.8125rem}}
