.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:10px;box-shadow:0 15px 35px #0000001a;max-width:400px;padding:40px;width:100%}.login-title{color:#333;font-size:28px;font-weight:700;margin-bottom:30px;text-align:center}.login-form{display:flex;flex-direction:column}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:5px}.form-group input{border:2px solid #ddd;border-radius:5px;font-size:16px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:12px;transition:transform .2s;width:100%}.login-btn:hover:not(:disabled){transform:translateY(-2px)}.login-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.message{font-size:14px}.login-hint{background:#f8f9fa;border:1px solid #dee2e6;border-radius:5px;margin-top:20px;padding:10px;text-align:center}.login-hint p{color:#6c757d;font-size:14px;margin:0}.upload-container{background-color:#f5f5f5;min-height:100vh}.upload-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:20px}.upload-header h1{font-size:28px;margin:0}.user-info{align-items:center;display:flex;gap:15px}.logout-btn{background:#fff3;border:1px solid #fff;border-radius:5px;color:#fff;cursor:pointer;padding:8px 16px;transition:background .3s}.logout-btn:hover{background:#ffffff4d}.upload-main{margin:0 auto;max-width:1200px;padding:40px 20px}.upload-section{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;margin-bottom:40px;padding:30px}.upload-section h2{color:#333;margin-bottom:20px;text-align:center}.upload-area{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:20px}.file-input{display:none}.file-input-label{background:#3498db;border-radius:5px;color:#fff;cursor:pointer;display:inline-block;padding:12px 24px;transition:background .3s}.file-input-label:hover{background:#2980b9}.upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:transform .2s}.upload-btn:hover:not(:disabled){transform:translateY(-2px)}.upload-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.preview-section{margin-top:20px;text-align:center}.preview-section h3{color:#333;margin-bottom:10px}.preview-image{border-radius:5px;box-shadow:0 3px 10px #0003;max-height:300px;max-width:300px}.gallery-section{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;padding:30px}.gallery-section h2{color:#333;margin-bottom:20px;text-align:center}.loading,.no-images{color:#666;font-size:18px;padding:40px;text-align:center}.thumbnail-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.thumbnail-item{background:#fff;border-radius:12px;box-shadow:0 4px 15px #00000014;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.thumbnail-item:hover{box-shadow:0 8px 25px #0000001f;transform:translateY(-5px)}.thumbnail-wrapper{aspect-ratio:1/1;cursor:pointer;overflow:hidden;position:relative;width:100%}.thumbnail-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.thumbnail-wrapper:hover .thumbnail-image{transform:scale(1.1)}.thumbnail-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.thumbnail-wrapper:hover .thumbnail-overlay{opacity:1}.view-btn{align-items:center;background:#ffffffe6;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;transition:background .3s,transform .2s;width:40px}.view-btn:hover{background:#3498db;color:#fff;transform:scale(1.1)}.thumbnail-info{display:flex;flex-direction:column;flex-grow:1;padding:12px}.image-name{color:#333;font-size:14px;font-weight:600;line-height:1.3;margin-bottom:8px;word-break:break-all}.image-meta{margin-top:auto}.image-time{color:#888;font-size:12px}.delete-btn-thumbnail{background:#0000;border:none;border-radius:50%;color:#aaa;cursor:pointer;font-size:16px;padding:5px;transition:color .3s,background-color .3s}.delete-btn-thumbnail:hover{background-color:#fbeeee;color:#e74c3c}.modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:10px;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden;position:relative}.modal-close{align-items:center;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:30px;justify-content:center;position:absolute;right:15px;top:10px;width:30px;z-index:1001}.modal-close:hover{background:#000000b3}.modal-image{display:block;max-height:70vh;max-width:100%;object-fit:contain}.modal-info{padding:20px;text-align:center}.modal-info h3{color:#333;margin:0 0 10px;word-break:break-word}.modal-info p{color:#666;font-size:14px;margin:0 0 15px}.modal-actions{display:flex;gap:10px;justify-content:center}.delete-btn{background:#e74c3c;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .3s}.delete-btn:hover{background:#c0392b}.message{border-radius:5px;margin-top:15px;padding:10px;text-align:center}.message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}@media (max-width:768px){.thumbnail-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.thumbnail-wrapper{height:100px}.modal-content{margin:10px}.upload-main{padding:20px 10px}}.thumbnail-actions{align-items:center;display:flex;gap:5px}.copy-btn-thumbnail{background:none;border:none;border-radius:3px;cursor:pointer;font-size:14px;padding:2px;transition:background-color .2s}.copy-btn-thumbnail:hover{background-color:#e3f2fd}.copy-btn{background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin-right:10px;padding:8px 16px;transition:background-color .2s}.copy-btn:hover{background-color:#1976d2}.image-meta{align-items:center;display:flex;justify-content:space-between;margin-top:5px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5}.App{min-height:100vh}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.c905d069.css.map*/