*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a;color:#fff;padding:40px 20px;text-align:center}.app-header h1{font-size:2.5rem;margin-bottom:10px}.app-header .subtitle{font-size:1.1rem;opacity:.9}.app-main{flex:1 1;margin:0 auto;max-width:1400px;padding:40px 20px;width:100%}.upload-section{margin-bottom:50px}.gallery-section{margin-bottom:40px}.app-footer{background:#333;color:#fff;margin-top:auto;padding:20px;text-align:center}.app-footer p{font-size:.9rem;margin:0}@media (max-width:768px){.app-header h1{font-size:1.8rem}.app-header .subtitle{font-size:.95rem}.app-main{padding:20px 10px}.upload-section{margin-bottom:30px}}.photo-upload{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:600px;padding:30px}.photo-upload h2{color:#333;font-size:1.5rem;margin-bottom:25px}.upload-form{display:flex;flex-direction:column;gap:20px}.drag-drop-area{background:#f9fafb;border:2px dashed #cbd5e0;border-radius:8px;cursor:pointer;padding:40px 20px;text-align:center;transition:all .3s ease}.drag-drop-area:hover{background:#f3f4ff;border-color:#667eea}.drag-drop-area.active{background:#e6e6ff;border-color:#667eea;box-shadow:0 0 10px #667eea33}.file-input{display:none}.file-label{cursor:pointer;display:block}.upload-icon{font-size:3rem;margin-bottom:10px}.drag-text{color:#333;font-size:1.1rem;font-weight:500;margin:10px 0 5px}.file-types{color:#666;font-size:.9rem;margin:0}.file-preview{background:#f0f4ff;border-left:4px solid #667eea;border-radius:6px;padding:15px}.file-name{color:#333;font-weight:600;margin:0 0 5px}.file-size{color:#666;font-size:.9rem;margin:0}.password-field{display:flex;flex-direction:column;gap:8px}.password-label{align-items:center;color:#333;display:flex;font-size:.95rem;font-weight:600;gap:4px}.required{color:#dc3545;font-weight:700}.password-input{border:2px solid #cbd5e0;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .3s ease}.password-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.password-input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.password-hint{color:#666;font-size:.85rem;font-style:italic;margin:0}.upload-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.upload-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.upload-button:disabled{cursor:not-allowed;opacity:.6}.upload-button:active:not(:disabled){transform:translateY(0)}.alert{animation:slideIn .3s ease;border-radius:6px;font-size:.95rem;padding:12px 16px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-success{background:#efe;border-left:4px solid #3c3;color:#3c3}@media (max-width:768px){.photo-upload{padding:20px}.photo-upload h2{font-size:1.2rem;margin-bottom:20px}.drag-drop-area{padding:30px 15px}.upload-icon{font-size:2.5rem}.drag-text{font-size:1rem}}.gallery-container{width:100%}.gallery-container h2{color:#333;font-size:1.5rem;margin-bottom:25px}.gallery-grid{grid-gap:20px;animation:fadeIn .5s ease;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gallery-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.gallery-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-4px)}.card-image-wrapper{background:#f0f0f0;height:200px;overflow:hidden;width:100%}.card-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.gallery-card:hover .card-image{transform:scale(1.05)}.card-content{display:flex;flex:1 1;flex-direction:column;justify-content:space-between;padding:15px}.card-filename{color:#333;font-size:.95rem;font-weight:600;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:break-word}.card-timestamp{color:#888;font-size:.85rem;margin:0}.loading{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:15px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading p{color:#666;font-size:1rem;margin:0}.empty-state{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{font-size:3rem;margin-bottom:15px}.empty-text{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 10px}.empty-subtext{color:#888;font-size:.95rem;margin:0}.alert{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:15px;justify-content:space-between;padding:20px}.alert-error{background:#fee;border-left:4px solid #c33;color:#c33}.retry-button{background:#c33;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.retry-button:hover{background:#b22;transform:translateY(-1px)}@media (max-width:768px){.gallery-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.gallery-container h2{font-size:1.2rem;margin-bottom:20px}.card-image-wrapper{height:150px}.card-content{padding:12px}.card-filename{font-size:.85rem}.card-timestamp{font-size:.75rem}}@media (max-width:480px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.card-image-wrapper{height:120px}}
/*# sourceMappingURL=main.cb97ad7d.css.map*/