.logo-container{display:flex;align-items:center;gap:.75rem;text-decoration:none}.logo-icon{width:40px;height:40px;flex-shrink:0;animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.logo-text{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}@media (max-width: 640px){.logo-icon{width:32px;height:32px}.logo-text{font-size:1.25rem}}.puzzle-captcha{width:100%;max-width:340px;display:flex;flex-direction:column;gap:.5rem}.puzzle-captcha.is-disabled{opacity:.8;pointer-events:none}.puzzle-header{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:var(--text-secondary)}.puzzle-refresh{border:none;background:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:.1rem .25rem}.puzzle-refresh:disabled{opacity:.6;cursor:not-allowed}.puzzle-viewport{position:relative;width:340px;height:70px;border:2px dashed var(--border-color);border-radius:12px;overflow:hidden;background:#f1f5f9}.puzzle-viewport.success{border-color:var(--success-color)}.puzzle-viewport.error{border-color:var(--error-color)}.puzzle-background{width:100%;height:100%;object-fit:cover;pointer-events:none;user-select:none}.puzzle-piece{position:absolute;border-radius:10px;box-shadow:0 8px 16px #0003;transition:left .15s ease;pointer-events:none}.puzzle-piece.dragging{transition:none}.puzzle-slider{width:340px}.puzzle-slider-track{position:relative;height:56px;border-radius:999px;background:var(--background);border:2px solid var(--border-color);overflow:hidden}.puzzle-slider-progress{height:100%;background:#6366f126;transition:width .15s ease}.puzzle-slider-thumb{position:absolute;top:50%;width:50px;height:50px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:#fff;cursor:grab;box-shadow:var(--shadow-lg);transition:background .2s ease;transform:translateY(-50%)}.puzzle-slider-thumb.dragging{cursor:grabbing}.puzzle-slider.success .puzzle-slider-thumb{background:var(--success-color)}.puzzle-slider.error .puzzle-slider-thumb{background:var(--error-color)}.thumb-grip{width:14px;height:14px;border-radius:4px;border:2px solid #fff}.spinner{width:18px;height:18px;border:3px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.puzzle-message{font-size:.85rem;text-align:center;color:var(--text-secondary);min-height:1.2rem}.puzzle-message.success{color:var(--success-color)}.puzzle-message.error{color:var(--error-color)}.puzzle-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-secondary);font-size:.9rem}.puzzle-overlay{position:absolute;inset:0;background:#ffffffa6;backdrop-filter:blur(2px)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2)}:root{--auth-field-width: 340px}.auth-card{background:var(--surface);border-radius:16px;padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center}.auth-logo{display:flex;justify-content:center;margin-bottom:.5rem}.auth-logo .logo-container{justify-content:center}.auth-logo .logo-text{font-size:1.75rem}.auth-title{font-size:2rem;font-weight:700;margin-bottom:1rem;text-align:center;color:var(--text-primary)}.auth-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:var(--auth-field-width)}.auth-form .form-group{width:100%}.form-group input,.form-group textarea{padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s;background:var(--surface);color:var(--text-primary);width:100%}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;transition:all .2s;cursor:pointer;width:100%}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--background);border-color:var(--text-secondary)}.auth-link{text-align:center;margin-top:1rem;color:var(--text-secondary)}.auth-link a{color:var(--primary-color);text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.captcha-group{gap:.5rem}.captcha-group label{font-weight:600;color:var(--text-primary)}@media (max-width: 640px){.auth-card{padding:2rem 1.5rem}.auth-title{font-size:1.75rem}}.upload-container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}.upload-card{background:var(--surface);border-radius:16px;padding:2rem;box-shadow:var(--shadow)}.page-title{font-size:1.75rem;font-weight:700;margin-bottom:2rem;color:var(--text-primary)}.upload-form{display:flex;flex-direction:column;gap:1.5rem}.file-upload-area{position:relative}.file-input{position:absolute;opacity:0;width:0;height:0}.file-label{display:block;cursor:pointer;border:2px dashed var(--border-color);border-radius:12px;padding:3rem 2rem;text-align:center;transition:all .2s;background:var(--background)}.file-label:hover{border-color:var(--primary-color);background:#6366f10d}.file-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-secondary)}.upload-icon{font-size:3rem;margin-bottom:.5rem}.file-hint{font-size:.875rem;color:var(--text-secondary)}.file-selected{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-primary)}.file-icon{font-size:2.5rem}.file-name{font-weight:600;font-size:1.1rem}.file-size{font-size:.9rem;color:var(--text-secondary)}.preview-container{margin-top:1rem;border-radius:12px;overflow:hidden;border:2px solid var(--border-color);background:var(--background)}.preview-image{width:100%;height:auto;max-height:400px;object-fit:contain;display:block}.form-group{display:flex;flex-direction:column;gap:.5rem}.captcha-group{align-items:center}.captcha-group label{text-align:center}.form-group label{font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group textarea{padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s;background:var(--surface);color:var(--text-primary);resize:vertical;font-family:inherit}.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.error-message{background:#fee2e2;color:var(--error-color);padding:.75rem;border-radius:8px;font-size:.9rem;border:1px solid #fecaca}.files-table-container{margin-top:1rem;overflow-x:auto}.files-table-container h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.files-table,.uploaded-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}.files-table thead,.uploaded-table thead{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff}.files-table th,.uploaded-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem}.files-table td,.uploaded-table td{padding:1rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.files-table tbody tr:hover,.uploaded-table tbody tr:hover{background:var(--background)}.files-table tbody tr:last-child td,.uploaded-table tbody tr:last-child td{border-bottom:none}.file-size-cell{color:var(--text-secondary);font-size:.9rem}.comment-input{width:100%;min-width:200px;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;font-size:.9rem;transition:all .2s;background:var(--surface);color:var(--text-primary)}.comment-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.remove-file-btn-table{width:32px;height:32px;border-radius:50%;border:none;background:var(--error-color);color:#fff;font-size:1.5rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.remove-file-btn-table:hover{background:#dc2626;transform:scale(1.1)}.uploaded-images{margin-top:2rem}.uploaded-images h3{font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;color:var(--text-primary)}.btn-secondary.copied{background:var(--success-color);border-color:var(--success-color);color:#fff;cursor:default}.btn-secondary:disabled{opacity:1;cursor:default}.btn-secondary:hover:not(:disabled):not(.copied){background:var(--background);border-color:var(--text-secondary)}@media (max-width: 768px){.page-title{font-size:1.25rem}.files-table,.uploaded-table{display:none}.files-table-container,.uploaded-images,.table-mobile-cards{display:block}.mobile-card{background:var(--surface);border:2px solid var(--border-color);border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:var(--shadow)}.mobile-card-header{display:flex;gap:1rem;margin-bottom:1rem;align-items:flex-start}.mobile-card-thumbnail{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid var(--border-color);flex-shrink:0}.mobile-card-info{flex:1;min-width:0}.mobile-card-title{font-weight:600;color:var(--text-primary);margin-bottom:.25rem;word-break:break-word}.mobile-card-meta{font-size:.85rem;color:var(--text-secondary);margin-bottom:.25rem}.mobile-card-field{margin-bottom:.75rem}.mobile-card-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.25rem;display:block}.mobile-card-value{color:var(--text-primary);word-break:break-word}.mobile-card-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.mobile-link-input{flex:1;min-width:0;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;font-size:.85rem;background:var(--surface);color:var(--text-primary);font-family:monospace}.mobile-comment-input{width:100%;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;font-size:.9rem;background:var(--surface);color:var(--text-primary)}}@media (max-width: 640px){.upload-container{padding:0 1rem}.page-title{font-size:1.1rem}.upload-card{padding:1.5rem}.file-label{padding:2rem 1rem}.preview-image{max-height:300px}.mobile-card{padding:.75rem}.mobile-card-thumbnail{width:60px;height:60px}}.my-images-container{width:100%}.my-images-card{background:var(--surface);border-radius:16px;padding:2rem;box-shadow:var(--shadow)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}.page-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.btn-refresh{white-space:nowrap}.images-count{margin-bottom:1rem;color:var(--text-secondary);font-weight:500}.table-container{overflow-x:auto;margin-top:1rem}.table-mobile-cards{display:none}.my-images-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}.my-images-table thead{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff}.my-images-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;white-space:nowrap}.my-images-table td{padding:1rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.my-images-table tbody tr:hover{background:var(--background)}.my-images-table tbody tr:last-child td{border-bottom:none}.table-thumbnail{width:80px;height:80px;object-fit:cover;border-radius:6px;border:2px solid var(--border-color)}.file-name-cell{max-width:200px}.file-name{font-weight:500;color:var(--text-primary);word-break:break-word}.file-size-cell,.dimensions-cell{color:var(--text-secondary);font-size:.9rem;white-space:nowrap}.comment-cell{max-width:200px;color:var(--text-primary);word-break:break-word}.no-comment{color:var(--text-secondary);font-style:italic}.date-cell{color:var(--text-secondary);font-size:.9rem;white-space:nowrap}.link-cell{display:flex;align-items:center;gap:.5rem;min-width:300px}.link-input-table{flex:1;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;font-size:.85rem;background:var(--surface);color:var(--text-primary);font-family:monospace}.view-link-table{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background:var(--primary-color);color:#fff;text-decoration:none;font-size:1.2rem;transition:all .2s;flex-shrink:0}.view-link-table:hover{background:var(--primary-hover);transform:scale(1.1)}.btn-small{padding:.5rem 1rem;font-size:.85rem;white-space:nowrap}.loading{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.1rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state p{margin:.5rem 0;font-size:1.1rem}.empty-hint{font-size:.9rem;color:var(--text-secondary)}.error-message{background:#fee2e2;color:var(--error-color);padding:.75rem;border-radius:8px;font-size:.9rem;border:1px solid #fecaca;margin-bottom:1rem}@media (max-width: 768px){.page-title{font-size:1.25rem}.my-images-table{display:none}.table-container,.table-mobile-cards{display:block}.mobile-card{background:var(--surface);border:2px solid var(--border-color);border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:var(--shadow)}.mobile-card-header{display:flex;gap:1rem;margin-bottom:1rem;align-items:flex-start}.mobile-card-thumbnail{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid var(--border-color);flex-shrink:0}.mobile-card-info{flex:1;min-width:0}.mobile-card-title{font-weight:600;color:var(--text-primary);margin-bottom:.25rem;word-break:break-word;font-size:.95rem}.mobile-card-meta{font-size:.85rem;color:var(--text-secondary)}.mobile-card-field{margin-bottom:.75rem}.mobile-card-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.25rem;display:block}.mobile-card-value{color:var(--text-primary);word-break:break-word;font-size:.9rem}.mobile-card-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.mobile-link-input{flex:1;min-width:0;padding:.5rem;border:2px solid var(--border-color);border-radius:6px;font-size:.85rem;background:var(--surface);color:var(--text-primary);font-family:monospace}.page-header{flex-direction:column;align-items:flex-start}}@media (max-width: 640px){.page-title{font-size:1.1rem}.mobile-card{padding:.75rem}.mobile-card-thumbnail{width:60px;height:60px}.my-images-card{padding:1.5rem}}.settings-container{max-width:800px;margin:0 auto;padding:2rem}.page-title{font-size:2rem;font-weight:600;margin-bottom:2rem;color:#333}.loading{text-align:center;padding:2rem;color:#666}.message{padding:1rem;border-radius:4px;margin-bottom:1.5rem}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.settings-form{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a}.settings-group{margin-bottom:1.5rem}.settings-label{display:block;font-weight:500;margin-bottom:.5rem;color:#333}.settings-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.settings-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.settings-input:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.7}.settings-actions{display:flex;gap:1rem;margin-top:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}@media (max-width: 768px){.settings-container{padding:1rem}.page-title{font-size:1.25rem}.settings-form{padding:1.5rem}.settings-actions{flex-direction:column}.btn{width:100%}}@media (max-width: 640px){.page-title{font-size:1.1rem}}.viewer-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--background)}.viewer-header{width:100%;max-width:1200px;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}.viewer-title{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.image-wrapper{width:100%;max-width:1200px;background:var(--surface);border-radius:16px;padding:2rem;box-shadow:var(--shadow-lg);display:flex;justify-content:center;align-items:center}.viewer-image{max-width:100%;max-height:80vh;height:auto;border-radius:8px;box-shadow:var(--shadow);object-fit:contain}.loading{font-size:1.25rem;color:var(--text-secondary);text-align:center}.error-card{background:var(--surface);border-radius:16px;padding:3rem;text-align:center;box-shadow:var(--shadow);max-width:500px}.error-icon{font-size:4rem;margin-bottom:1rem}.error-card h2{color:var(--error-color);margin-bottom:1rem}.error-card p{color:var(--text-secondary)}@media (max-width: 640px){.viewer-header{flex-direction:column;align-items:flex-start}.viewer-title{font-size:1.5rem}.image-wrapper{padding:1rem}.viewer-image{max-height:70vh}}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--surface);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.header-nav{display:flex;gap:.5rem;flex:1;justify-content:center}.nav-link{padding:.5rem 1rem;text-decoration:none;color:var(--text-secondary);font-weight:500;border-radius:6px;transition:all .2s}.nav-link:hover{color:var(--primary-color);background:#6366f11a}.nav-link.active{color:var(--primary-color);background:#6366f126}.header-actions{display:flex;align-items:center;gap:1rem}.user-name{color:var(--text-secondary);font-weight:500}.mobile-menu{display:none;position:relative}.burger-button{display:flex;flex-direction:column;justify-content:space-around;width:28px;height:28px;background:transparent;border:none;cursor:pointer;padding:0;z-index:10}.burger-line{width:100%;height:3px;background:var(--text-primary);border-radius:2px;transition:all .3s ease;transform-origin:center}.burger-line.open:nth-child(1){transform:rotate(45deg) translate(8px,8px)}.burger-line.open:nth-child(2){opacity:0}.burger-line.open:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.mobile-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1000;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-user{padding:1rem;border-bottom:1px solid var(--border-color)}.mobile-user-name{color:var(--text-primary);font-weight:600;font-size:.95rem}.mobile-menu-divider{height:1px;background:var(--border-color)}.mobile-menu-item{width:100%;padding:.875rem 1rem;text-align:left;background:transparent;border:none;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:background .2s;display:block;text-decoration:none}.mobile-menu-item:hover{background:#6366f11a}.mobile-menu-link{color:var(--text-primary);font-weight:500}.mobile-menu-link.active{color:var(--primary-color);background:#6366f126}.mobile-menu-link:hover{background:#6366f11a}.mobile-menu-logout{color:var(--error-color, #ef4444);font-weight:500}.mobile-menu-logout:hover{background:#ef44441a}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem 1.5rem}@media (max-width: 768px){.header-content{padding:.75rem 1rem}.header-nav,.header-actions{display:none}.mobile-menu{display:block}}@media (max-width: 640px){.header-content{padding:.75rem 1rem}.main-content{padding:1.5rem 1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #6366f1;--primary-hover: #4f46e5;--secondary-color: #8b5cf6;--background: #f8fafc;--surface: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--error-color: #ef4444;--success-color: #10b981;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}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:var(--background);color:var(--text-primary);line-height:1.6}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}
