@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap";:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:light}body{margin:0;min-height:100vh}#root{min-height:100vh}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:40px;width:100%;max-width:450px;box-shadow:0 20px 60px #0000004d;animation:slideUp .5s ease-out}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:2rem;margin-bottom:8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:#666;font-size:.95rem}.tab-switcher{display:flex;gap:10px;margin-bottom:30px;background:#f0f0f0;padding:5px;border-radius:12px}.tab-switcher button{flex:1;padding:12px;border:none;background:transparent;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;color:#666}.tab-switcher button.active{background:#fff;color:#667eea;box-shadow:0 2px 8px #0000001a}.login-form{display:flex;flex-direction:column;gap:20px}.form-group input{padding:14px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;transition:all .3s ease;background:#fff}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.error-message{padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.9rem;text-align:center}.submit-btn{padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.submit-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.login-card{padding:30px 20px}.login-header h1{font-size:1.5rem}}.image-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #00000014;transition:all .3s ease;display:flex;flex-direction:column}.image-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026}.image-wrapper{position:relative;width:100%;padding-bottom:75%;overflow:hidden;cursor:pointer;background:#f0f0f0}.image-wrapper img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.image-wrapper:hover 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;color:#fff;font-weight:600}.image-wrapper:hover .image-overlay{opacity:1}.image-info{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1}.image-title{font-size:1.1rem;font-weight:700;color:#333;margin:0;line-height:1.3}.image-description{font-size:.9rem;color:#666;margin:0;line-height:1.5}.image-meta{display:flex;flex-direction:column;gap:8px;margin-top:auto}.meta-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#777}.meta-icon{font-size:1rem}.delete-btn{padding:10px;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem}.delete-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #ff6b6b66}.delete-btn:disabled{opacity:.6;cursor:not-allowed}.fullscreen-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fullscreen-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:16px}.fullscreen-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.fullscreen-content h2{color:#fff;margin:0;text-align:center}.fullscreen-content p{color:#ddd;margin:0;text-align:center;max-width:600px}.close-btn{position:absolute;top:-50px;right:0;background:#fff3;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.modal-content{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.modal-close{background:#f0f0f0;border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;color:#666}.modal-close:hover{background:#e0e0e0;transform:rotate(90deg)}.upload-form{padding:24px;display:flex;flex-direction:column;gap:20px}.file-drop-area{border:3px dashed #ddd;border-radius:16px;padding:40px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafafa}.file-drop-area:hover,.file-drop-area.drag-active{border-color:#667eea;background:#f0f4ff}.file-drop-area.has-preview{padding:20px;border-style:solid}.drop-message{display:flex;flex-direction:column;align-items:center;gap:12px}.upload-icon{font-size:3rem}.drop-message p{margin:0;color:#666}.or-text{color:#999;font-size:.9rem}.browse-btn{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.browse-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.file-info{font-size:.85rem;color:#999}.preview-container{display:flex;flex-direction:column;gap:12px}.preview-container img{max-width:100%;max-height:300px;object-fit:contain;border-radius:12px}.change-image-btn{padding:10px 20px;background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.change-image-btn:hover{background:#e0e0e0}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:.9rem}.form-group input,.form-group textarea{padding:12px 14px;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical}.modal-actions{display:flex;gap:12px;margin-top:10px}.cancel-btn,.upload-btn{flex:1;padding:14px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.cancel-btn{background:#f0f0f0;color:#666}.cancel-btn:hover{background:#e0e0e0}.upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.upload-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.upload-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.modal-content{max-height:100vh;border-radius:0}.file-drop-area{padding:30px 20px}}.gallery-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.gallery-header{background:#fff;box-shadow:0 2px 10px #0000000d;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:20px 24px;display:flex;justify-content:space-between;align-items:center}.header-left h1{margin:0;font-size:1.8rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{margin:4px 0 0;color:#666;font-size:.9rem}.header-right{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f5f5f5;border-radius:12px}.user-icon{font-size:1.2rem}.username{font-weight:600;color:#333}.logout-btn{padding:10px 20px;background:#f0f0f0;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;color:#666}.logout-btn:hover{background:#e0e0e0;color:#333}.gallery-controls{max-width:1400px;margin:0 auto;padding:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.filter-tabs{display:flex;gap:8px;background:#fff;padding:6px;border-radius:12px;box-shadow:0 2px 8px #0000000d}.filter-tabs button{padding:10px 20px;background:transparent;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;color:#666}.filter-tabs button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.upload-btn{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;font-size:1rem;box-shadow:0 4px 15px #667eea4d}.upload-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.images-grid{max-width:1400px;margin:0 auto;padding:0 24px 40px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loader{width:50px;height:50px;border:4px solid #f0f0f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#666;font-size:1.1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:40px 20px}.empty-icon{font-size:5rem;margin-bottom:20px;opacity:.5}.empty-state h2{margin:0 0 12px;color:#333;font-size:1.8rem}.empty-state p{margin:0 0 24px;color:#666;font-size:1.1rem}.upload-btn-large{padding:16px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.upload-btn-large:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}@media(max-width:768px){.header-content{flex-direction:column;gap:16px;align-items:flex-start}.header-right{width:100%;justify-content:space-between}.gallery-controls{flex-direction:column;align-items:stretch}.filter-tabs{width:100%}.filter-tabs button{flex:1}.upload-btn{width:100%;justify-content:center}.images-grid{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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}
