*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#1a1a1a;background:#f5f5f5;line-height:1.5}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}.container{max-width:1280px;margin:0 auto;padding:0 1rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:1rem;gap:1rem}.loading{color:#666}.error,.loading{text-align:center;padding:3rem;font-size:1.1rem}.error{color:#dc2626}.empty{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.page-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem;flex-wrap:wrap}.page-header h1{font-size:1.75rem;font-weight:800;letter-spacing:-.02em;color:#111}.page-info{font-size:.85rem;color:#666;padding:.25rem 0 .5rem}.pagination{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:1.5rem 0}.pagination-btn{padding:.4rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.85rem;cursor:pointer;transition:background .15s,border-color .15s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.4;cursor:default}.pagination-active{background:#2563eb;color:#fff;border-color:#2563eb}.pagination-active:hover{background:#1d4ed8}.pagination-dots{padding:.4rem .25rem;color:#999;font-size:.85rem}.pagination-wrap{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem;padding:1.5rem 0}.pagination-size{display:flex;align-items:center;gap:.5rem}.pagination-size-label{font-size:.85rem;color:#666}.pagination-size-select{padding:.4rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.85rem;color:#374151;cursor:pointer}.pagination-size-select:hover{border-color:#9ca3af}.pagination-sync-btn{padding:.4rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.85rem;color:#374151;cursor:pointer;transition:background .15s,border-color .15s}.pagination-sync-btn:hover{background:#f3f4f6;border-color:#9ca3af}.pagination-sync-active{background:#2563eb;color:#fff;border-color:#2563eb}.pagination-sync-active:hover{background:#1d4ed8}.media-toggle-row{display:flex;align-items:center;gap:.6rem;padding:0 0 .75rem}.media-toggle-label{font-size:.85rem;color:#666;font-weight:500}.media-toggle{display:flex;gap:0;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.media-toggle-btn{padding:.4rem .85rem;border:none;background:#fff;font-size:.85rem;color:#374151;cursor:pointer;transition:background .15s,color .15s}.media-toggle-btn:not(:last-child){border-right:1px solid #d1d5db}.media-toggle-btn:hover:not(.media-toggle-active){background:#f3f4f6}.media-toggle-active{background:#2563eb;color:#fff}.media-toggle-active:hover{background:#1d4ed8}.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;animation:modal-fade-in .15s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-content{display:flex;flex-direction:column;max-width:95vw;max-height:95vh}.modal-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .25rem;gap:1rem}.modal-title{color:#e5e5e5;font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-actions{display:flex;gap:.35rem;flex-shrink:0}.modal-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:6px;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;transition:background .15s}.modal-btn:hover{background:rgba(255,255,255,.25)}.modal-image-wrapper{flex:1 1;display:flex;align-items:center;justify-content:center;overflow:auto;min-height:0}.modal-image{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:4px}video.modal-image{outline:none}.app-header{background:#fff;border-bottom:1px solid #e5e5e5;padding:.75rem 1rem}.header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-logo{font-weight:700;font-size:1.1rem;color:#1a1a1a}.header-logo,.header-logo:hover{text-decoration:none}.user-menu{display:flex;align-items:center;gap:.6rem;font-size:.85rem}.user-avatar{width:28px;height:28px;border-radius:50%}.user-email{color:#555;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{padding:.3rem .6rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.8rem;cursor:pointer;transition:background .15s}.logout-btn:hover{background:#f3f4f6;border-color:#9ca3af}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:12px;padding:2.5rem 2rem;box-shadow:0 20px 60px rgba(0,0,0,.2);text-align:center;max-width:380px;width:100%}.login-card h1{font-size:1.5rem;font-weight:800;color:#111;margin-bottom:.5rem}.login-subtitle{color:#666;font-size:.95rem;margin-bottom:1.75rem}.login-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:8px;padding:.75rem 1rem;font-size:.85rem;margin-bottom:1.25rem}.login-btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.75rem 1.5rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:.95rem;font-weight:500;color:#374151;cursor:pointer;transition:background .15s,box-shadow .15s;width:100%}.login-btn:hover{background:#f9fafb;box-shadow:0 2px 8px rgba(0,0,0,.08)}.google-icon{flex-shrink:0}.header-nav-link{padding:.3rem .7rem;border:1px solid #d1d5db;border-radius:6px;font-size:.8rem;font-weight:500;color:#374151;text-decoration:none;transition:background .15s}.header-nav-link:hover{background:#f3f4f6;border-color:#9ca3af;text-decoration:none}.users-page{max-width:720px}.users-add-form{display:flex;gap:.5rem;padding:.75rem 0 1rem;flex-wrap:wrap}.users-input{flex:1 1;min-width:200px;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;color:#1a1a1a;outline:none;transition:border-color .15s}.users-input:focus{border-color:#2563eb}.users-role-select,.users-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.85rem;color:#374151;cursor:pointer}.users-role-select{padding:.3rem .5rem;font-size:.8rem}.users-add-btn{padding:.5rem 1rem;border:none;border-radius:6px;background:#2563eb;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s}.users-add-btn:hover:not(:disabled){background:#1d4ed8}.users-add-btn:disabled{opacity:.5;cursor:default}.users-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06)}.users-table th{text-align:left;padding:.65rem .75rem;font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #e5e5e5;background:#fafafa}.users-table td{padding:.6rem .75rem;font-size:.9rem;border-bottom:1px solid #f0f0f0;vertical-align:middle}.users-table tr:last-child td{border-bottom:none}.users-date{font-size:.8rem;color:#999}.users-you-badge{display:inline-block;margin-left:.4rem;padding:.1rem .4rem;font-size:.7rem;font-weight:600;background:#eff6ff;color:#2563eb;border-radius:4px}.users-remove-btn{padding:.3rem .6rem;border:1px solid #fecaca;border-radius:6px;background:#fff;color:#dc2626;font-size:.8rem;cursor:pointer;transition:background .15s}.users-remove-btn:hover:not(:disabled){background:#fef2f2}.users-remove-btn:disabled{opacity:.3;cursor:default}.users-empty{text-align:center;color:#999;padding:1.5rem}