.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.modal-close{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f0f0f0;color:#333}.modal-content form{padding:1.5rem}.modal-content .form-group{margin-bottom:1.5rem}.modal-content .form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.modal-content .form-group input[type=text],.modal-content .form-group input[type=url]{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.modal-content .form-group input[type=file]{width:100%;padding:.5rem;border:2px dashed #e0e0e0;border-radius:8px;cursor:pointer;background:#f9f9f9}.modal-content .form-group input[type=file]:hover{border-color:#4caf50;background:#f1f8f4}.modal-content .form-group input:focus{outline:none;border-color:#4caf50}.image-preview{margin-bottom:1.5rem}.image-preview label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.image-preview img{width:100%;max-height:300px;object-fit:contain;border-radius:8px;border:2px solid #e0e0e0}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid #e0e0e0}.modal-actions .btn{padding:.75rem 1.5rem}.password-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.password-card{background:#fff;padding:3rem 2.5rem;border-radius:16px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px;text-align:center}.password-card h1{font-size:2.5rem;color:#333;margin-bottom:.5rem}.password-card p{color:#666;margin-bottom:2rem;font-size:1rem}.password-error{background-color:#ffebee;color:#c62828;padding:.75rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.password-input{width:100%;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1.1rem;margin-bottom:1rem;transition:border-color .3s;text-align:center;font-family:inherit}.password-input:focus{outline:none;border-color:#667eea}.password-submit{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.password-submit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.password-submit:active{transform:translateY(0)}.app{max-width:1200px;margin:0 auto;padding:2rem}.header{text-align:center;margin-bottom:3rem}.header h1{font-size:2.5rem;color:#333;margin-bottom:.5rem}.header p{color:#666;font-size:1.1rem}.add-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:3rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4caf50}.form-group textarea{resize:vertical;min-height:80px}.btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.btn-primary{background-color:#4caf50;color:#fff}.btn-primary:hover{background-color:#45a049}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.btn-success{background-color:#4caf50;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-success:hover{background-color:#45a049}.btn-secondary{background-color:#757575;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-secondary:hover{background-color:#616161}.btn-danger{background-color:#f44336;color:#fff;padding:.5rem 1rem;font-size:.9rem}.btn-danger:hover{background-color:#da190b}.filter-bar{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.filter-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.sort-controls{display:flex;align-items:center;justify-content:center;padding-top:.5rem;border-top:1px solid #e0e0e0}.filter-btn{padding:.75rem 1.5rem;border:2px solid #e0e0e0;background:#fff;color:#666;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.filter-btn:hover{border-color:#4caf50;color:#4caf50;background:#f1f8f4}.filter-btn.active{border-color:#4caf50;background:#4caf50;color:#fff}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.item-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:transform .3s,box-shadow .3s;position:relative}.item-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.item-card.printed{opacity:.75;border:2px solid #4CAF50}.item-card.printed:hover{opacity:.9}.printed-badge{position:absolute;top:10px;right:10px;background:#4caf50;color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.85rem;z-index:10;box-shadow:0 2px 6px #0003}.item-image{width:100%;height:200px;object-fit:cover;background-color:#e0e0e0}.item-content{padding:1.5rem}.item-title{font-size:1.25rem;font-weight:600;color:#333;margin-bottom:.75rem}.item-link{color:#4caf50;text-decoration:none;word-break:break-all;font-size:.9rem;display:block;margin-bottom:1rem}.item-link:hover{text-decoration:underline}.item-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.loading{text-align:center;padding:2rem;color:#666}.error{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:8px;margin-bottom:1rem}.empty-state{text-align:center;padding:3rem;color:#999}.empty-state svg{width:80px;height:80px;margin-bottom:1rem;opacity:.5}*{margin:0;padding:0;box-sizing:border-box}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-color:#f5f5f5}#root{min-height:100vh}
