@import"https://fonts.googleapis.com/css2?family=Patrick+Hand&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#ffffffde;background-color:transparent;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;padding:0;min-width:320px;min-height:100vh;background:transparent}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:transparent}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--riso-pink: #f780a1;--riso-blue: #00a9a5;--riso-yellow: #f8c74f;--riso-red: #f05a28;--riso-bg: #fdfaef;--riso-dark: #31263e}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background-color:var(--riso-bg);font-family:Patrick Hand,cursive;position:relative;overflow:hidden}.login-page:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.1;animation:grain 8s steps(10) infinite;pointer-events:none}@keyframes grain{0%,to{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translateY(15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}.riso-shape{position:absolute;mix-blend-mode:multiply;opacity:.8}.shape-1{width:300px;height:300px;background:var(--riso-pink);border-radius:50%;top:10%;left:15%}.shape-2{width:200px;height:400px;background:var(--riso-blue);bottom:5%;right:10%;transform:rotate(45deg)}.shape-3{width:250px;height:250px;background:var(--riso-yellow);top:25%;right:20%}.shape-4{width:150px;height:150px;background:var(--riso-red);bottom:20%;left:5%;border-top-left-radius:100%}.login-container{background:var(--riso-bg);padding:40px;border:4px solid var(--riso-dark);width:100%;max-width:400px;text-align:center;position:relative;z-index:2;box-shadow:10px 10px 0 var(--riso-blue)}.login-header{margin-bottom:30px}.login-header h1{font-size:3.5rem;font-weight:900;margin:0;color:var(--riso-dark);text-transform:uppercase;letter-spacing:2px;text-shadow:3px 3px 0 var(--riso-pink),-3px -3px 0 var(--riso-yellow);font-family:Patrick Hand,cursive}.login-form{margin-bottom:0}.form-group{margin-bottom:20px}.password-input{width:100%;padding:16px 20px;font-size:1.2rem;border:4px solid var(--riso-dark);background:#fff;color:var(--riso-dark);outline:none;box-sizing:border-box;font-family:Patrick Hand,cursive;font-weight:900;text-align:center}.password-input:focus{background:var(--riso-yellow);border-color:var(--riso-red)}.password-input::placeholder{color:var(--riso-dark);opacity:.6;font-weight:900;text-transform:uppercase}.error-message{background:var(--riso-pink);color:var(--riso-dark);padding:12px 16px;margin-bottom:20px;font-size:1rem;border:4px solid var(--riso-dark);font-weight:900;text-transform:uppercase}.login-button{width:100%;padding:16px 20px;font-size:1.5rem;font-weight:900;color:var(--riso-bg);background:var(--riso-red);border:4px solid var(--riso-dark);cursor:pointer;box-sizing:border-box;font-family:Patrick Hand,cursive;text-transform:uppercase;transition:all .2s ease-in-out}.login-button:hover:not(:disabled){background:var(--riso-yellow);color:var(--riso-dark);transform:translate(4px,4px);box-shadow:-4px -4px 0 var(--riso-red)}.login-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.login-container{padding:30px 20px;margin:0 10px}.login-header h1{font-size:2rem}.password-input,.login-button{padding:14px 16px;font-size:15px}}.image-upload-container{max-width:800px;margin:0 auto;padding:20px}.upload-area{border:2px dashed #ccc;border-radius:10px;padding:40px;text-align:center;cursor:pointer;transition:all .3s ease;background-color:#fafafa;min-height:200px;display:flex;align-items:center;justify-content:center}.upload-area:hover{border-color:#007bff;background-color:#f0f8ff}.upload-area.dragging{border-color:#007bff;background-color:#e3f2fd;transform:scale(1.02)}.upload-area.uploading{border-color:#28a745;background-color:#f0fff0;cursor:not-allowed}.upload-prompt{display:flex;flex-direction:column;align-items:center;gap:10px}.upload-icon{font-size:48px;margin-bottom:10px}.upload-prompt h3{margin:0;color:#333;font-weight:600}.upload-prompt p{margin:0;color:#666;font-size:14px}.upload-status{display:flex;flex-direction:column;align-items:center;gap:15px}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.uploaded-images{margin-top:30px}.uploaded-images h4{margin-bottom:15px;color:#333;font-weight:600}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px}.uploaded-image{background:#fff;border-radius:8px;padding:10px;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease}.uploaded-image:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.uploaded-image img{width:100%;height:120px;object-fit:cover;border-radius:4px;margin-bottom:8px}.uploaded-image p{margin:0;font-size:12px;color:#666;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}@media (max-width: 768px){.image-upload-container{padding:15px}.upload-area{padding:30px 20px;min-height:150px}.upload-icon{font-size:36px}.image-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.uploaded-image img{height:100px}}.admin-page{min-height:100vh;background:transparent;padding-bottom:40px}.admin-header{padding:30px 20px 20px;text-align:center;color:#fff}.admin-nav{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto 20px}.logout-button{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:5px}.logout-button:hover{background:#c82333;transform:translateY(-1px)}.back-link{color:#ffffffe6;text-decoration:none;font-weight:500;transition:all .2s ease;padding:8px 16px;border-radius:20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-link:hover{color:#fff;background:#fff3;transform:translate(-2px)}.admin-header h1{font-size:2.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3);margin:0}.admin-description{font-size:1.1rem;color:#ffffffe6;max-width:600px;margin:0 auto;line-height:1.5}.admin-main{background:#fff;margin:0 auto 20px;max-width:1400px;width:calc(100% - 40px);border-radius:20px;box-shadow:0 10px 30px #0003;overflow:hidden}.upload-section{padding:0;border-bottom:1px solid #e9ecef}.section-header-collapsible{background:#f8f9fa;padding:24px 40px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease}.section-title-clickable{display:flex;align-items:center;gap:8px;cursor:pointer;transition:background-color .2s ease;border-radius:6px;padding:8px;margin:-8px;-webkit-user-select:none;user-select:none}.section-title-clickable:hover{background:#0000000d}.section-title-clickable h2,.section-title-clickable h3{margin:0;color:#495057;font-weight:600;font-size:1.3rem;background:none;padding:0;border:none}.collapse-icon{font-size:.9rem;color:#6c757d;transition:color .2s ease;font-weight:700}.section-title-clickable:hover .collapse-icon{color:#495057}.section-content{transition:all .3s ease}.existing-images-section{padding:0}.ocr-section{padding:0;border-bottom:1px solid #e9ecef}.ocr-controls{display:flex;align-items:center;gap:15px}.ollama-status{font-size:.9rem;font-weight:500;padding:4px 8px;border-radius:4px}.ollama-status.success{color:#28a745;background:#28a7451a}.ollama-status.error{color:#dc3545;background:#dc35451a}.ocr-button{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.ocr-button:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.ocr-button:disabled{background:#6c757d;cursor:not-allowed;transform:none}.ocr-button.clear-button{background:#dc3545;margin-left:10px}.ocr-button.clear-button:hover:not(:disabled){background:#c82333}.ocr-button.stop-button{background:#fd7e14;margin-left:5px}.ocr-button.stop-button:hover:not(:disabled){background:#e8650e}.ocr-status{padding:20px 40px;background:#f8f9fa}.ocr-progress{margin-bottom:15px}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.9rem;color:#495057;text-align:center}.ocr-stats-mini{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}.mini-stat{font-size:.85rem;font-weight:500;padding:4px 8px;border-radius:4px}.mini-stat.success{color:#28a745;background:#28a7451a}.mini-stat.error{color:#dc3545;background:#dc35451a}.mini-stat.pending{color:#ffc107;background:#ffc1071a}.mini-stat.info{color:#6c757d;background:#6c757d1a;font-size:.75rem}.refresh-button{background:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:5px}.refresh-button:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.loading-state{display:flex;flex-direction:column;align-items:center;padding:60px 30px;color:#6c757d}.loading-state .spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px;padding:40px;max-width:none}.gallery-item{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;cursor:pointer}.gallery-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.image-container{position:relative;width:100%;height:150px;overflow:hidden}.image-container img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-item:hover .image-container img{transform:scale(1.05)}.image-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.gallery-item:hover .image-overlay{opacity:1}.view-details{color:#fff;font-weight:500;font-size:.9rem}.image-info{padding:15px}.image-name{margin:0;font-size:.85rem;color:#495057;font-weight:500;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.empty-state{text-align:center;padding:60px 30px;color:#6c757d}.empty-icon{font-size:4rem;margin-bottom:20px}.empty-state h3{margin-bottom:10px;color:#495057}.admin-stats{padding:0;border-bottom:1px solid #e9ecef}.admin-stats .section-content{background:#f8f9fa;padding:40px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;max-width:800px;margin:0 auto}.stat-item{background:#fff;padding:20px;border-radius:12px;text-align:center;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease}.stat-item:hover{transform:translateY(-2px)}.stat-number{display:block;font-size:2rem;font-weight:700;color:#007bff;margin-bottom:5px}.stat-label{display:block;font-size:.9rem;color:#6c757d;font-weight:500}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:#fff;border-radius:16px;max-width:1200px;max-height:90vh;width:100%;overflow:hidden;box-shadow:0 20px 40px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.modal-header h2{margin:0;color:#495057;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;color:#6c757d;cursor:pointer;padding:5px;border-radius:4px;transition:all .2s ease}.close-button:hover{background:#e9ecef;color:#495057}.modal-body{display:grid;grid-template-columns:1fr 350px;max-height:70vh;min-height:500px;overflow:hidden}.modal-image{padding:30px;display:flex;align-items:center;justify-content:center;background:#f8f9fa}.modal-image img{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 4px 12px #0000001a}.modal-metadata{padding:30px;background:#fff;border-left:1px solid #e9ecef;overflow-y:auto;max-height:100%}.modal-metadata h3{margin-top:0;margin-bottom:20px;color:#495057;font-weight:600}.metadata-grid{display:flex;flex-direction:column;gap:15px;margin-bottom:25px}.metadata-item{display:flex;flex-direction:column;gap:5px}.metadata-label{font-size:.85rem;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.metadata-value{color:#495057;font-weight:500;word-break:break-all}.metadata-value.url{font-family:monospace;font-size:.85rem;background:#f8f9fa;padding:8px;border-radius:4px}.metadata-actions{display:flex;gap:10px}.ocr-results{margin-top:25px;padding-top:20px;border-top:1px solid #e9ecef}.ocr-results h3{margin-top:0;margin-bottom:15px;color:#495057;font-weight:600}.ocr-content{display:flex;flex-direction:column;gap:12px}.ocr-status-badge{font-size:.85rem;font-weight:500;padding:6px 12px;border-radius:6px;align-self:flex-start}.ocr-status-badge.success{color:#28a745;background:#28a7451a;border:1px solid rgba(40,167,69,.2)}.ocr-status-badge.error{color:#dc3545;background:#dc35451a;border:1px solid rgba(220,53,69,.2)}.ocr-status-badge.pending{color:#ffc107;background:#ffc1071a;border:1px solid rgba(255,193,7,.2)}.ocr-text{background:#f8f9fa;padding:12px;border-radius:6px;border-left:3px solid #28a745;font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;color:#495057;white-space:pre-wrap;word-wrap:break-word;max-height:200px;overflow-y:auto}.ocr-error{background:#fff5f5;padding:12px;border-radius:6px;border-left:3px solid #dc3545;color:#721c24;font-size:.9rem}.ocr-meta{color:#6c757d;font-size:.8rem;line-height:1.4}.embeddings-info{display:flex;flex-direction:column;gap:10px;margin:12px 0}.embedding-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f8f9fa;border-radius:4px;border-left:3px solid #007bff}.error-detail{color:#dc3545;font-size:.8rem;font-style:italic}.action-button{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#007bff;color:#fff;text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:all .2s ease}.action-button:hover{background:#0056b3;transform:translateY(-1px);color:#fff}.exif-results{margin-top:25px}.exif-results h3{margin-bottom:20px;color:#495057;font-weight:600}.exif-content{background:#f8f9fa;border-radius:8px;padding:20px}.exif-grid{display:flex;flex-direction:column;gap:20px}.exif-section{background:#fff;border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a}.exif-section h4{margin:0 0 12px;font-size:.9rem;font-weight:600;color:#495057;border-bottom:1px solid #e9ecef;padding-bottom:8px}.exif-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f1f3f4}.exif-item:last-child{border-bottom:none}.exif-label{font-size:.85rem;color:#6c757d;font-weight:500;min-width:100px}.exif-value{color:#495057;font-weight:500;text-align:right;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.85rem}@media (min-width: 1200px){.admin-main{width:calc(100% - 80px)}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:32px;padding:50px}.gallery-item{transition:all .3s ease}.image-container{height:200px}.admin-stats .section-content{padding:50px 40px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:32px;max-width:1000px}.stat-item{padding:24px}}@media (min-width: 1600px){.admin-main{max-width:1600px}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:40px;padding:60px}.image-container{height:240px}}@media (max-width: 768px){.admin-nav{flex-direction:column;gap:15px;align-items:flex-start}.admin-header h1{font-size:2rem;align-self:center}.admin-main{margin:0 10px 10px;border-radius:15px}.section-header-collapsible{padding:20px 24px;flex-direction:column;gap:15px;align-items:flex-start}.section-title-clickable{width:100%;justify-content:space-between;margin:0;padding:0}.ocr-controls{flex-wrap:wrap;gap:10px;width:100%;justify-content:flex-start}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;padding:20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:15px}.modal-body{grid-template-columns:1fr;max-height:80vh}.modal-metadata{border-left:none;border-top:1px solid #e9ecef}}@media (max-width: 480px){.admin-header{padding:20px 15px 15px}.admin-header h1{font-size:1.8rem}.image-gallery{grid-template-columns:repeat(2,1fr);padding:15px}.stats-grid{grid-template-columns:1fr}.modal-overlay{padding:10px}.modal-header,.modal-image,.modal-metadata{padding:20px}.exif-section{padding:12px}.exif-item{flex-direction:column;align-items:flex-start;gap:4px;padding:8px 0}.exif-label{min-width:auto}.exif-value{text-align:left;word-break:break-word}}.visualization-container{width:100vw;height:100vh;position:relative;overflow:hidden;margin:0;padding:0;font-family:Arial Black,Impact,sans-serif}.visualization-mount{width:100%;height:100%}.search-overlay{position:absolute;top:20px;left:20px;z-index:100}.search-input{width:100%;max-width:500px;padding:12px 16px;font-size:16px;border-radius:8px;outline:none;transition:all .3s ease;color:var(--riso-dark);background:var(--riso-bg);border:4px solid var(--riso-dark);font-family:Patrick Hand,cursive;box-shadow:5px 5px #31263e33}.search-input::placeholder{color:var(--riso-dark);opacity:.5}.search-input:focus{background:var(--riso-yellow);border-color:var(--riso-red);box-shadow:5px 5px 0 var(--riso-pink)}.controls-hint{margin-top:8px;font-size:12px;color:var(--riso-dark);background:#fdfaef99;padding:6px 10px;border-radius:4px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);font-family:Helvetica Neue,Arial,sans-serif;font-weight:400}.loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:200;pointer-events:none;background:#0000001a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.progress-container{text-align:center;background:var(--riso-bg);padding:30px 40px;border:4px solid var(--riso-dark);box-shadow:8px 8px 0 var(--riso-blue);width:500px;max-width:90vw}.progress-bar{width:80%;height:25px;margin:0 auto 20px;background-color:#0000001a;border:3px solid var(--riso-dark);overflow:hidden;box-shadow:none}.progress-fill{height:100%;background-color:var(--riso-red);transition:width .4s ease-out;animation:none}.progress-text{font-family:Patrick Hand,cursive;font-size:1.8rem;font-weight:900;color:var(--riso-dark);text-transform:uppercase;text-shadow:2px 2px 0 var(--riso-pink);letter-spacing:1px}@keyframes shimmer{0%{box-shadow:0 0 10px #4facfe4d}50%{box-shadow:0 0 20px #4facfe99}to{box-shadow:0 0 10px #4facfe4d}}.nav-overlay{position:absolute;top:25px;right:25px;z-index:100;display:flex;gap:15px}.nav-button{font-family:Patrick Hand,cursive;text-transform:uppercase;font-size:1rem;font-weight:900;padding:10px 20px;border:4px solid var(--riso-dark);cursor:pointer;transition:all .2s ease-in-out;text-decoration:none;display:inline-block;box-shadow:5px 5px 0 var(--riso-dark)}.nav-button:hover{transform:translate(2px,2px);box-shadow:3px 3px 0 var(--riso-dark)}.admin-button{background-color:var(--riso-yellow);color:var(--riso-dark)}.admin-button:hover{background-color:var(--riso-pink)}.logout-button{background-color:var(--riso-blue);color:var(--riso-bg)}.logout-button:hover{background-color:var(--riso-red)}html,body,#root{margin:0;padding:0;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed}.App{min-height:100vh;background:transparent;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app-header{text-align:center;padding:40px 20px;color:#fff}.app-header h1{font-size:2.5rem;margin-bottom:10px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3)}.app-header p{font-size:1.1rem;opacity:.9;max-width:600px;margin:0 auto;line-height:1.5}.app-main{background:#fff;margin:0 20px 20px;border-radius:20px;box-shadow:0 10px 30px #0003;overflow:hidden}.app-stats{background:#f8f9fa;padding:30px;border-top:1px solid #e9ecef;text-align:center}.app-stats h3{color:#495057;margin-bottom:15px;font-weight:600}.app-stats p{margin:8px 0;color:#6c757d;font-size:1rem}.app-stats strong{color:#007bff;font-weight:600}.app-footer{text-align:center;padding:20px;color:#fffc;font-size:.9rem}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.app-header{padding:30px 15px}.app-header h1{font-size:2rem}.app-header p{font-size:1rem}.app-main{margin:0 10px 10px;border-radius:15px}.app-stats{padding:20px}}
